From f1a0ede4d5f57c9612a42d7424a8d7229e5be6b7 Mon Sep 17 00:00:00 2001 From: Lukasz Dorau Date: Tue, 5 Nov 2024 08:18:00 +0100 Subject: [PATCH 1/2] Extract IPC tests from devdax tests Extract the IPC tests from the devdax tests to a separate file, because the IPC tests do not work with the proxy library yet and they should be run separately. Signed-off-by: Lukasz Dorau --- test/CMakeLists.txt | 4 ++ test/provider_devdax_memory.cpp | 45 ---------------------- test/provider_devdax_memory_ipc.cpp | 59 +++++++++++++++++++++++++++++ 3 files changed, 63 insertions(+), 45 deletions(-) create mode 100644 test/provider_devdax_memory_ipc.cpp diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 2d5eca255..475e2b19f 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -274,6 +274,10 @@ if(LINUX AND (NOT UMF_DISABLE_HWLOC)) # OS-specific functions are implemented add_umf_test( NAME provider_devdax_memory SRCS provider_devdax_memory.cpp + LIBS ${UMF_UTILS_FOR_TEST}) + add_umf_test( + NAME provider_devdax_memory_ipc + SRCS provider_devdax_memory_ipc.cpp LIBS ${UMF_UTILS_FOR_TEST} ${LIB_JEMALLOC_POOL}) add_umf_test( NAME provider_file_memory diff --git a/test/provider_devdax_memory.cpp b/test/provider_devdax_memory.cpp index dba8efff7..c41fb8769 100644 --- a/test/provider_devdax_memory.cpp +++ b/test/provider_devdax_memory.cpp @@ -12,17 +12,10 @@ #include "base.hpp" #include "cpp_helpers.hpp" -#include "ipcFixtures.hpp" #include "test_helpers.h" #include #include -#ifdef UMF_POOL_JEMALLOC_ENABLED -#include -#endif -#ifdef UMF_POOL_SCALABLE_ENABLED -#include -#endif using umf_test::test; @@ -357,41 +350,3 @@ TEST_F(test, create_wrong_size_0) { EXPECT_EQ(ret, UMF_RESULT_ERROR_INVALID_ARGUMENT); EXPECT_EQ(hProvider, nullptr); } - -HostMemoryAccessor hostAccessor; - -static std::vector getIpcProxyPoolTestParamsList(void) { - std::vector ipcProxyPoolTestParamsList = {}; - - char *path = getenv("UMF_TESTS_DEVDAX_PATH"); - if (path == nullptr || path[0] == 0) { - // Test skipped, UMF_TESTS_DEVDAX_PATH is not set - return ipcProxyPoolTestParamsList; - } - - char *size = getenv("UMF_TESTS_DEVDAX_SIZE"); - if (size == nullptr || size[0] == 0) { - // Test skipped, UMF_TESTS_DEVDAX_PATH is not set - return ipcProxyPoolTestParamsList; - } - - ipcProxyPoolTestParamsList = { - {umfProxyPoolOps(), nullptr, umfDevDaxMemoryProviderOps(), - &defaultDevDaxParams, &hostAccessor, true}, -#ifdef UMF_POOL_JEMALLOC_ENABLED - {umfJemallocPoolOps(), nullptr, umfDevDaxMemoryProviderOps(), - &defaultDevDaxParams, &hostAccessor, false}, -#endif -#ifdef UMF_POOL_SCALABLE_ENABLED - {umfScalablePoolOps(), nullptr, umfDevDaxMemoryProviderOps(), - &defaultDevDaxParams, &hostAccessor, false}, -#endif - }; - - return ipcProxyPoolTestParamsList; -} - -GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(umfIpcTest); - -INSTANTIATE_TEST_SUITE_P(DevDaxProviderDifferentPoolsTest, umfIpcTest, - ::testing::ValuesIn(getIpcProxyPoolTestParamsList())); diff --git a/test/provider_devdax_memory_ipc.cpp b/test/provider_devdax_memory_ipc.cpp new file mode 100644 index 000000000..071196c94 --- /dev/null +++ b/test/provider_devdax_memory_ipc.cpp @@ -0,0 +1,59 @@ +// Copyright (C) 2024 Intel Corporation +// Under the Apache License v2.0 with LLVM Exceptions. See LICENSE.TXT. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception + +#include +#include +#ifdef UMF_POOL_JEMALLOC_ENABLED +#include +#endif +#ifdef UMF_POOL_SCALABLE_ENABLED +#include +#endif + +#include "ipcFixtures.hpp" + +using umf_test::test; + +auto defaultDevDaxParams = umfDevDaxMemoryProviderParamsDefault( + getenv("UMF_TESTS_DEVDAX_PATH"), + atol(getenv("UMF_TESTS_DEVDAX_SIZE") ? getenv("UMF_TESTS_DEVDAX_SIZE") + : "0")); + +HostMemoryAccessor hostAccessor; + +static std::vector getIpcProxyPoolTestParamsList(void) { + std::vector ipcProxyPoolTestParamsList = {}; + + char *path = getenv("UMF_TESTS_DEVDAX_PATH"); + if (path == nullptr || path[0] == 0) { + // skipping the test, UMF_TESTS_DEVDAX_PATH is not set + return ipcProxyPoolTestParamsList; + } + + char *size = getenv("UMF_TESTS_DEVDAX_SIZE"); + if (size == nullptr || size[0] == 0) { + // skipping the test, UMF_TESTS_DEVDAX_SIZE is not set + return ipcProxyPoolTestParamsList; + } + + ipcProxyPoolTestParamsList = { + {umfProxyPoolOps(), nullptr, umfDevDaxMemoryProviderOps(), + &defaultDevDaxParams, &hostAccessor, true}, +#ifdef UMF_POOL_JEMALLOC_ENABLED + {umfJemallocPoolOps(), nullptr, umfDevDaxMemoryProviderOps(), + &defaultDevDaxParams, &hostAccessor, false}, +#endif +#ifdef UMF_POOL_SCALABLE_ENABLED + {umfScalablePoolOps(), nullptr, umfDevDaxMemoryProviderOps(), + &defaultDevDaxParams, &hostAccessor, false}, +#endif + }; + + return ipcProxyPoolTestParamsList; +} + +GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(umfIpcTest); + +INSTANTIATE_TEST_SUITE_P(DevDaxProviderDifferentPoolsTest, umfIpcTest, + ::testing::ValuesIn(getIpcProxyPoolTestParamsList())); From edc1ca88f2c06606716fb3c4ed4d0dbe527733ca Mon Sep 17 00:00:00 2001 From: Lukasz Dorau Date: Tue, 5 Nov 2024 14:52:57 +0100 Subject: [PATCH 2/2] Add DEVDAX and FSDAX tests with the proxy library Signed-off-by: Lukasz Dorau --- .github/workflows/reusable_dax.yml | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) diff --git a/.github/workflows/reusable_dax.yml b/.github/workflows/reusable_dax.yml index 24e5a1bdb..787fe5360 100644 --- a/.github/workflows/reusable_dax.yml +++ b/.github/workflows/reusable_dax.yml @@ -101,10 +101,28 @@ jobs: - name: Run the FSDAX tests working-directory: ${{env.BUILD_DIR}} - run: | - UMF_TESTS_FSDAX_PATH=${{env.UMF_TESTS_FSDAX_PATH}} UMF_TESTS_FSDAX_PATH_2=${{env.UMF_TESTS_FSDAX_PATH_2}} ctest -C ${{matrix.build_type}} -R umf-provider_file_memory -V - UMF_TESTS_FSDAX_PATH=${{env.UMF_TESTS_FSDAX_PATH}} UMF_TESTS_FSDAX_PATH_2=${{env.UMF_TESTS_FSDAX_PATH_2}} ctest -C ${{matrix.build_type}} -R umf_example_dram_and_fsdax -V - UMF_TESTS_FSDAX_PATH=${{env.UMF_TESTS_FSDAX_PATH}} UMF_TESTS_FSDAX_PATH_2=${{env.UMF_TESTS_FSDAX_PATH_2}} ctest -C ${{matrix.build_type}} -R umf-ipc_file_prov_fsdax -V + run: > + UMF_TESTS_FSDAX_PATH=${{env.UMF_TESTS_FSDAX_PATH}} + UMF_TESTS_FSDAX_PATH_2=${{env.UMF_TESTS_FSDAX_PATH_2}} + ctest -C ${{matrix.build_type}} -V -R "umf-provider_file_memory|umf_example_dram_and_fsdax|umf-ipc_file_prov_fsdax" + + # TODO: enable the provider_devdax_memory_ipc test when the IPC tests with the proxy library are fixed + # see the issue: https://github.com/oneapi-src/unified-memory-framework/issues/864 + - name: Run the DEVDAX tests with the proxy library + working-directory: ${{env.BUILD_DIR}} + run: > + LD_PRELOAD=./lib/libumf_proxy.so + UMF_TESTS_DEVDAX_PATH="/dev/dax${{env.DEVDAX_NAMESPACE}}" + UMF_TESTS_DEVDAX_SIZE="$(ndctl list --namespace=namespace${{env.DEVDAX_NAMESPACE}} | grep size | cut -d':' -f2 | cut -d',' -f1)" + ctest -C ${{matrix.build_type}} -R devdax -E provider_devdax_memory_ipc -V + + - name: Run the FSDAX tests with the proxy library + working-directory: ${{env.BUILD_DIR}} + run: > + LD_PRELOAD=./lib/libumf_proxy.so + UMF_TESTS_FSDAX_PATH=${{env.UMF_TESTS_FSDAX_PATH}} + UMF_TESTS_FSDAX_PATH_2=${{env.UMF_TESTS_FSDAX_PATH_2}} + ctest -C ${{matrix.build_type}} -V -R "umf-provider_file_memory|umf_example_dram_and_fsdax|umf-ipc_file_prov_fsdax" - name: Check coverage if: ${{ matrix.build_type == 'Debug' }}