diff options
| author | Kristian Evers <kristianevers@gmail.com> | 2018-06-21 21:51:13 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-06-21 21:51:13 +0200 |
| commit | 8ee389a6f44fb9ac0380ddbd3706b9354269d62f (patch) | |
| tree | c9b5448d7fb1241f47d30de8fb01c2b014f6f468 | |
| parent | 292d6f045546e3e3b915602e97fcdde9d469cd9d (diff) | |
| parent | b87b59106879188ffc684a41a9de638ac5fd02bf (diff) | |
| download | PROJ-8ee389a6f44fb9ac0380ddbd3706b9354269d62f.tar.gz PROJ-8ee389a6f44fb9ac0380ddbd3706b9354269d62f.zip | |
Merge pull request #1050 from kbevers/add-proj_errno_string-proj.def
Add proj_errno_string() to proj.def
| -rw-r--r-- | src/proj.def | 2 | ||||
| -rw-r--r-- | test/unit/CMakeLists.txt | 9 | ||||
| -rw-r--r-- | test/unit/Makefile.am | 9 | ||||
| -rw-r--r-- | test/unit/proj_errno_string_test.cpp | 68 |
4 files changed, 87 insertions, 1 deletions
diff --git a/src/proj.def b/src/proj.def index 9b0a95d8..3dd7cf0e 100644 --- a/src/proj.def +++ b/src/proj.def @@ -157,3 +157,5 @@ EXPORTS proj_context_errno @141 pj_isnan @142 + + proj_errno_string @143 diff --git a/test/unit/CMakeLists.txt b/test/unit/CMakeLists.txt index a22665f8..d6f6b068 100644 --- a/test/unit/CMakeLists.txt +++ b/test/unit/CMakeLists.txt @@ -58,6 +58,15 @@ target_link_libraries(proj_test_unit ${PROJ_LIBRARIES}) add_test(NAME proj_test_unit COMMAND proj_test_unit) +add_executable(proj_errno_string_test + main.cpp + proj_errno_string_test.cpp) +target_link_libraries(proj_errno_string_test + gtest + ${PROJ_LIBRARIES}) +add_test(NAME proj_errno_string_test COMMAND proj_errno_string_test) + + if (MSVC AND BUILD_LIBPROJ_SHARED) # ph_phi2_test not compatible of a .dll build else() diff --git a/test/unit/Makefile.am b/test/unit/Makefile.am index 8c8b60d8..b625c592 100644 --- a/test/unit/Makefile.am +++ b/test/unit/Makefile.am @@ -9,6 +9,7 @@ AM_CXXFLAGS = @CXX_WFLAGS@ @NO_ZERO_AS_NULL_POINTER_CONSTANT_FLAG@ bin_PROGRAMS = basic_test bin_PROGRAMS += pj_phi2_test +bin_PROGRAMS += proj_errno_string_test basic_test_SOURCES = basic_test.cpp main.cpp basic_test_LDADD = ../../src/libproj.la ../../test/googletest/libgtest.la @@ -22,5 +23,11 @@ pj_phi2_test_LDADD = ../../src/libproj.la ../../test/googletest/libgtest.la pj_phi2_test-check: pj_phi2_test ./pj_phi2_test +proj_errno_string_test_SOURCES = proj_errno_string_test.cpp main.cpp +proj_errno_string_test_LDADD= ../../src/libproj.la ../../test/googletest/libgtest.la + +proj_errno_string_test-check: proj_errno_string_test + ./proj_errno_string_test + check-local: basic_test-check -check-local: pj_phi2_test-check +check-local: pj_phi2_test-check proj_errno_string_test-check diff --git a/test/unit/proj_errno_string_test.cpp b/test/unit/proj_errno_string_test.cpp new file mode 100644 index 00000000..0e4cff7f --- /dev/null +++ b/test/unit/proj_errno_string_test.cpp @@ -0,0 +1,68 @@ +/****************************************************************************** + * + * Project: PROJ + * Purpose: Unit test for proj_errno_string() + * Author: Kristian Evers <kristianevers@gmail.com> + * + ****************************************************************************** + * Copyright (c) 2018, Kristian Evers. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included + * in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + ****************************************************************************/ + +#include <cstring> + +#include "proj.h" + +#include "gtest_include.h" + +namespace { + +TEST(ProjErrnoStringTest, NoError) { + EXPECT_EQ(0, proj_errno_string(0)); +} + +TEST(ProjErrnoStringTest, ProjErrnos) { + EXPECT_STREQ("no arguments in initialization list", proj_errno_string(-1)); + EXPECT_STREQ("invalid projection system error (-1000)", proj_errno_string(-1000)); + EXPECT_STREQ("invalid projection system error (-9999)", proj_errno_string(-9999)); + // for errnos < -9999, -9999 is always returned + constexpr int min = std::numeric_limits<int>::min(); + EXPECT_STREQ("invalid projection system error (-9999)",proj_errno_string(min)); + EXPECT_STREQ("invalid projection system error (-9999)", proj_errno_string(-10000)); +} + +TEST(ProjErrnoStringTest, SystemErrnos) { + constexpr int max = std::numeric_limits<int>::max(); + +#ifdef HAVE_STRERROR + EXPECT_STREQ(strerror(5), proj_errno_string(5)); + EXPECT_STREQ(strerror(9999), proj_errno_string(9999)); + EXPECT_STREQ(strerror(10000), proj_errno_string(10000)); + EXPECT_STREQ(strerror(max), proj_errno_string(max)); +#else + EXPECT_STREQ("no system list, errno: 5\n", proj_errno_string(5)); + EXPECT_STREQ("no system list, errno: 9999\n", proj_errno_string(9999)); + // for errnos > 9999, 9999 is always returned + EXPECT_STREQ("no system list, errno: 9999\n", proj_errno_string(10000)); + EXPECT_STREQ("no system list, errno: 9999\n", proj_errno_string(max)); +#endif +} + +} // namespace |
