diff options
| author | Even Rouault <even.rouault@spatialys.com> | 2021-11-10 17:56:27 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-11-10 17:56:27 +0100 |
| commit | cf8c1a825bb80b472900c0ca2d0530f86271995d (patch) | |
| tree | 61562ae25e859e4a37428b45a127a75e33512ad4 | |
| parent | ce6be7d20c13cd83ddbdea33efa182987a2441bd (diff) | |
| parent | a461817ade4b77110f95db6b5f7dd6e8aa8254b9 (diff) | |
| download | PROJ-cf8c1a825bb80b472900c0ca2d0530f86271995d.tar.gz PROJ-cf8c1a825bb80b472900c0ca2d0530f86271995d.zip | |
Merge pull request #2935 from OSGeo/backport-2934-to-8.2
[Backport 8.2] test: Make CApi test cross-platform
| -rw-r--r-- | test/unit/test_c_api.cpp | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/test/unit/test_c_api.cpp b/test/unit/test_c_api.cpp index d416457b..9c1329a7 100644 --- a/test/unit/test_c_api.cpp +++ b/test/unit/test_c_api.cpp @@ -47,6 +47,10 @@ #include <sqlite3.h> +#if !defined(_WIN32) +#include <sys/resource.h> +#endif + #ifndef __MINGW32__ #include <thread> #endif @@ -6104,9 +6108,18 @@ TEST_F(CApi, open_plenty_of_contexts) { // database std::vector<FILE *> dummyFilePointers; std::vector<PJ_CONTEXT *> ctxts; - // 1024 is the number of file descriptors that can be opened simultaneously - // by a Linux process (by default) - for (int i = 0; i < 1024 - 50; i++) { + // The number of file descriptors that can be opened simultaneously by a + // process varies across platforms so we make use of getrlimit(2) to + // retrieve it. + struct rlimit open_max; + getrlimit(RLIMIT_NOFILE, &open_max); + // On some platforms fopen returned nullptrs before reaching limit - 50, we + // can avoid this by capping the limit to 1024. + if (open_max.rlim_cur > 1024) { + open_max.rlim_cur = 1024; + setrlimit(RLIMIT_NOFILE, &open_max); + } + for (rlim_t i = 0; i < open_max.rlim_cur - 50; i++) { FILE *f = fopen("/dev/null", "rb"); ASSERT_TRUE(f != nullptr); dummyFilePointers.push_back(f); |
