diff options
| author | Kristian Evers <kristianevers@gmail.com> | 2019-09-16 09:23:00 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-09-16 09:23:00 +0200 |
| commit | 355f43ca41ac4e9a01037e6481ce611da9c13805 (patch) | |
| tree | a6bc06f084d92b806f266d588a9d66bd49dfa261 /test/unit | |
| parent | 1aaca77c2aa548a7be16fc2a2a00a5ef8e867e2a (diff) | |
| parent | 83a14b87ae9707b9233b0e630f02d4a38ee5ea30 (diff) | |
| download | PROJ-355f43ca41ac4e9a01037e6481ce611da9c13805.tar.gz PROJ-355f43ca41ac4e9a01037e6481ce611da9c13805.zip | |
[6.2 backport] cs2cs: autopromote CRS to 3D when there's a mix… (#1615)
[6.2 backport] cs2cs: autopromote CRS to 3D when there's a mix of 2D and 3D (fixes #1563)
Diffstat (limited to 'test/unit')
| -rw-r--r-- | test/unit/test_c_api.cpp | 74 | ||||
| -rw-r--r-- | test/unit/test_crs.cpp | 57 |
2 files changed, 131 insertions, 0 deletions
diff --git a/test/unit/test_c_api.cpp b/test/unit/test_c_api.cpp index 2a1c8577..db4b768b 100644 --- a/test/unit/test_c_api.cpp +++ b/test/unit/test_c_api.cpp @@ -3737,4 +3737,78 @@ TEST_F(CApi, proj_create_crs_to_crs_from_pj) { "+step +proj=utm +zone=31 +ellps=WGS84"); } +// --------------------------------------------------------------------------- + +TEST_F(CApi, proj_crs_promote_to_3D) { + + auto crs2D = + proj_create(m_ctxt, GeographicCRS::EPSG_4326 + ->exportToWKT(WKTFormatter::create().get()) + .c_str()); + ObjectKeeper keeper_crs2D(crs2D); + EXPECT_NE(crs2D, nullptr); + + auto crs3D = proj_crs_promote_to_3D(m_ctxt, nullptr, crs2D); + ObjectKeeper keeper_crs3D(crs3D); + EXPECT_NE(crs3D, nullptr); + + auto cs = proj_crs_get_coordinate_system(m_ctxt, crs3D); + ASSERT_NE(cs, nullptr); + ObjectKeeper keeperCs(cs); + EXPECT_EQ(proj_cs_get_axis_count(m_ctxt, cs), 3); + + auto code = proj_get_id_code(crs3D, 0); + ASSERT_TRUE(code != nullptr); + EXPECT_EQ(code, std::string("4979")); +} + +// --------------------------------------------------------------------------- + +TEST_F(CApi, proj_crs_create_projected_3D_crs_from_2D) { + + auto projCRS = proj_create_from_database(m_ctxt, "EPSG", "32631", + PJ_CATEGORY_CRS, false, nullptr); + ASSERT_NE(projCRS, nullptr); + ObjectKeeper keeper_projCRS(projCRS); + + { + auto geog3DCRS = proj_create_from_database( + m_ctxt, "EPSG", "4979", PJ_CATEGORY_CRS, false, nullptr); + ASSERT_NE(geog3DCRS, nullptr); + ObjectKeeper keeper_geog3DCRS(geog3DCRS); + + auto crs3D = proj_crs_create_projected_3D_crs_from_2D( + m_ctxt, nullptr, projCRS, geog3DCRS); + ObjectKeeper keeper_crs3D(crs3D); + EXPECT_NE(crs3D, nullptr); + + EXPECT_EQ(proj_get_type(crs3D), PJ_TYPE_PROJECTED_CRS); + + EXPECT_EQ(std::string(proj_get_name(crs3D)), + std::string(proj_get_name(projCRS))); + + auto cs = proj_crs_get_coordinate_system(m_ctxt, crs3D); + ASSERT_NE(cs, nullptr); + ObjectKeeper keeperCs(cs); + EXPECT_EQ(proj_cs_get_axis_count(m_ctxt, cs), 3); + } + + { + auto crs3D = proj_crs_create_projected_3D_crs_from_2D(m_ctxt, nullptr, + projCRS, nullptr); + ObjectKeeper keeper_crs3D(crs3D); + EXPECT_NE(crs3D, nullptr); + + EXPECT_EQ(proj_get_type(crs3D), PJ_TYPE_PROJECTED_CRS); + + EXPECT_EQ(std::string(proj_get_name(crs3D)), + std::string(proj_get_name(projCRS))); + + auto cs = proj_crs_get_coordinate_system(m_ctxt, crs3D); + ASSERT_NE(cs, nullptr); + ObjectKeeper keeperCs(cs); + EXPECT_EQ(proj_cs_get_axis_count(m_ctxt, cs), 3); + } +} + } // namespace diff --git a/test/unit/test_crs.cpp b/test/unit/test_crs.cpp index 0f0304b1..0df128e6 100644 --- a/test/unit/test_crs.cpp +++ b/test/unit/test_crs.cpp @@ -5224,3 +5224,60 @@ TEST(crs, getNonDeprecated) { ASSERT_EQ(list.size(), 1U); } } + +// --------------------------------------------------------------------------- + +TEST(crs, promoteTo3D) { + auto dbContext = DatabaseContext::create(); + { + auto crs = GeographicCRS::EPSG_4326; + auto crs3D = crs->promoteTo3D(std::string(), nullptr); + auto crs3DAsGeog = nn_dynamic_pointer_cast<GeographicCRS>(crs3D); + ASSERT_TRUE(crs3DAsGeog != nullptr); + EXPECT_EQ(crs3DAsGeog->coordinateSystem()->axisList().size(), 3U); + EXPECT_TRUE(crs3D->promoteTo3D(std::string(), nullptr) + ->isEquivalentTo(crs3D.get())); + } + { + auto crs = GeographicCRS::EPSG_4326; + auto crs3D = crs->promoteTo3D(std::string(), dbContext); + auto crs3DAsGeog = nn_dynamic_pointer_cast<GeographicCRS>(crs3D); + ASSERT_TRUE(crs3DAsGeog != nullptr); + EXPECT_EQ(crs3DAsGeog->coordinateSystem()->axisList().size(), 3U); + EXPECT_TRUE(!crs3DAsGeog->identifiers().empty()); + } + { + auto crs = createProjected(); + auto crs3D = crs->promoteTo3D(std::string(), nullptr); + auto crs3DAsProjected = nn_dynamic_pointer_cast<ProjectedCRS>(crs3D); + ASSERT_TRUE(crs3DAsProjected != nullptr); + EXPECT_EQ(crs3DAsProjected->coordinateSystem()->axisList().size(), 3U); + EXPECT_EQ( + crs3DAsProjected->baseCRS()->coordinateSystem()->axisList().size(), + 3U); + EXPECT_TRUE(crs3D->promoteTo3D(std::string(), nullptr) + ->isEquivalentTo(crs3D.get())); + } + { + auto crs = createProjected(); + auto crs3D = crs->promoteTo3D(std::string(), dbContext); + auto crs3DAsProjected = nn_dynamic_pointer_cast<ProjectedCRS>(crs3D); + ASSERT_TRUE(crs3DAsProjected != nullptr); + EXPECT_EQ(crs3DAsProjected->coordinateSystem()->axisList().size(), 3U); + EXPECT_EQ( + crs3DAsProjected->baseCRS()->coordinateSystem()->axisList().size(), + 3U); + EXPECT_TRUE(!crs3DAsProjected->baseCRS()->identifiers().empty()); + } + { + auto crs = BoundCRS::createFromTOWGS84( + createProjected(), std::vector<double>{1, 2, 3, 4, 5, 6, 7}); + auto crs3D = crs->promoteTo3D(std::string(), dbContext); + auto crs3DAsBound = nn_dynamic_pointer_cast<BoundCRS>(crs3D); + ASSERT_TRUE(crs3DAsBound != nullptr); + auto baseCRS = + nn_dynamic_pointer_cast<ProjectedCRS>(crs3DAsBound->baseCRS()); + ASSERT_TRUE(baseCRS != nullptr); + EXPECT_EQ(baseCRS->coordinateSystem()->axisList().size(), 3U); + } +} |
