aboutsummaryrefslogtreecommitdiff
path: root/test/unit
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2021-08-27 12:52:25 +0200
committerGitHub <noreply@github.com>2021-08-27 12:52:25 +0200
commit2a3384e9b2b45f4ad37974607f2a0f05f2fc67c9 (patch)
treea1c820ea23381273a56f51eabcf2e1f957b75c26 /test/unit
parentdb5a6e683bdd80dedc7140b8f8af65e586b72e02 (diff)
parent1e5bd1ac696186d985a418c61bb5a68951b3e0a4 (diff)
downloadPROJ-2a3384e9b2b45f4ad37974607f2a0f05f2fc67c9.tar.gz
PROJ-2a3384e9b2b45f4ad37974607f2a0f05f2fc67c9.zip
Merge pull request #2823 from rouault/fix_8353
WKT importer: better detect ESRI WKT
Diffstat (limited to 'test/unit')
-rw-r--r--test/unit/test_crs.cpp32
-rw-r--r--test/unit/test_io.cpp4
2 files changed, 34 insertions, 2 deletions
diff --git a/test/unit/test_crs.cpp b/test/unit/test_crs.cpp
index c36aa9b7..2ac26d3a 100644
--- a/test/unit/test_crs.cpp
+++ b/test/unit/test_crs.cpp
@@ -3014,6 +3014,38 @@ TEST(crs, projectedCRS_identify_db) {
EXPECT_EQ(res.front().first->getEPSGCode(), 32631);
EXPECT_GE(res.front().second, 70.0);
}
+ {
+ // Identify a ESRI WKT where the datum name doesn't start with D_
+ auto wkt = "PROJCS[\"S-JTSK_[JTSK03]_Krovak_East_North\","
+ "GEOGCS[\"S-JTSK_[JTSK03]\","
+ " DATUM[\"S-JTSK_[JTSK03]\","
+ " SPHEROID[\"Bessel_1841\",6377397.155,299.1528128]],"
+ " PRIMEM[\"Greenwich\",0.0],"
+ " UNIT[\"Degree\",0.0174532925199433]],"
+ "PROJECTION[\"Krovak\"],"
+ "PARAMETER[\"False_Easting\",0.0],"
+ "PARAMETER[\"False_Northing\",0.0],"
+ "PARAMETER[\"Pseudo_Standard_Parallel_1\",78.5],"
+ "PARAMETER[\"Scale_Factor\",0.9999],"
+ "PARAMETER[\"Azimuth\",30.2881397527778],"
+ "PARAMETER[\"Longitude_Of_Center\",24.8333333333333],"
+ "PARAMETER[\"Latitude_Of_Center\",49.5],"
+ "PARAMETER[\"X_Scale\",-1.0],"
+ "PARAMETER[\"Y_Scale\",1.0],"
+ "PARAMETER[\"XY_Plane_Rotation\",90.0],"
+ "UNIT[\"Meter\",1.0]]";
+ EXPECT_EQ(WKTParser().guessDialect(wkt),
+ WKTParser::WKTGuessedDialect::WKT1_ESRI);
+ auto obj =
+ WKTParser().attachDatabaseContext(dbContext).createFromWKT(wkt);
+ auto crs = nn_dynamic_pointer_cast<ProjectedCRS>(obj);
+ ASSERT_TRUE(crs != nullptr);
+ auto factoryAll = AuthorityFactory::create(dbContext, std::string());
+ auto res = crs->identify(factoryAll);
+ ASSERT_EQ(res.size(), 1U);
+ EXPECT_EQ(res.front().first->getEPSGCode(), 8353);
+ EXPECT_EQ(res.front().second, 100);
+ }
}
// ---------------------------------------------------------------------------
diff --git a/test/unit/test_io.cpp b/test/unit/test_io.cpp
index 0235a0c1..a899482e 100644
--- a/test/unit/test_io.cpp
+++ b/test/unit/test_io.cpp
@@ -5929,8 +5929,8 @@ static const struct {
TEST(wkt_parse, esri_projcs) {
for (const auto &projDef : esriProjDefs) {
- std::string wkt("PROJCS[\"unnamed\",GEOGCS[\"GCS_WGS_1984\","
- "DATUM[\"D_WGS_1984\",SPHEROID[\"WGS_1984\","
+ std::string wkt("PROJCS[\"unnamed\",GEOGCS[\"unnamed\","
+ "DATUM[\"unnamed\",SPHEROID[\"unnamed\","
"6378137.0,298.257223563]],PRIMEM[\"Greenwich\",0.0],"
"UNIT[\"Degree\",0.0174532925199433]],PROJECTION[\"");
wkt += projDef.esriProjectionName;