From 7ddec282ca1134f30d9041d51341915310ebe161 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Franz=20P=C3=B6schel?= Date: Fri, 18 Aug 2023 11:34:24 +0200 Subject: [PATCH] SerialIOTests: Windows compatibility Initialize Winsock API --- CMakeLists.txt | 6 +++++- test/SerialIOTest.cpp | 20 ++++++++++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 66fda3c627..fcbbd7fb12 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -552,7 +552,11 @@ target_include_directories(openPMD PUBLIC # Winsock library for gethostname() function on Windows if(WIN32) - target_link_libraries(openPMD PRIVATE ws2_32) + # need to link this publically as WSAStartup() and WSACleanup() need to be + # called surrounding the gethostname() function on Windows + # and it needs to be done at client site since the winsocks API is + # initialized statically per process.... + target_link_libraries(openPMD PUBLIC ws2_32) endif() # Catch2 for unit tests diff --git a/test/SerialIOTest.cpp b/test/SerialIOTest.cpp index 859765c472..e3b15de1d5 100644 --- a/test/SerialIOTest.cpp +++ b/test/SerialIOTest.cpp @@ -40,6 +40,12 @@ #include #endif +#ifdef _WIN32 +#include +// windows.h defines this macro and it breaks any function with the same name +#undef max +#endif + using namespace openPMD; struct BackendSelection @@ -1527,6 +1533,10 @@ TEST_CASE("dtype_test", "[serial]") inline void write_test(const std::string &backend) { +#ifdef _WIN32 + WSADATA wsaData; + WSAStartup(MAKEWORD(2, 0), &wsaData); +#endif Series o = Series( "../samples/serial_write." + backend, Access::CREATE, @@ -1635,6 +1645,9 @@ inline void write_test(const std::string &backend) REQUIRE( (read.mpiRanksMetaInfo(/* collective = */ false) == chunk_assignment::RankMeta{{0, host_info::hostname()}})); +#ifdef _WIN32 + WSACleanup(); +#endif } TEST_CASE("write_test", "[serial]") @@ -1789,6 +1802,10 @@ fileBased_add_EDpic(ParticleSpecies &e, uint64_t const num_particles) inline void fileBased_write_test(const std::string &backend) { +#ifdef _WIN32 + WSADATA wsaData; + WSAStartup(MAKEWORD(2, 0), &wsaData); +#endif if (auxiliary::directory_exists("../samples/subdir")) auxiliary::remove_directory("../samples/subdir"); @@ -2169,6 +2186,9 @@ inline void fileBased_write_test(const std::string &backend) close(dirfd); } #endif // defined(__unix__) +#ifdef _WIN32 + WSACleanup(); +#endif } TEST_CASE("fileBased_write_test", "[serial]")