aboutsummaryrefslogtreecommitdiff
path: root/test/unit/test_c_api.cpp
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2019-08-09 17:50:35 +0200
committerEven Rouault <even.rouault@spatialys.com>2019-08-09 18:03:17 +0200
commit99b25fcf9009a6cc098cf2e0703f994d74968985 (patch)
treebc4c67a6c0c1d63db82709963a793108c57c4ba4 /test/unit/test_c_api.cpp
parent124eb228c464eaf170c03b70fd461fd1a06b82f2 (diff)
downloadPROJ-99b25fcf9009a6cc098cf2e0703f994d74968985.tar.gz
PROJ-99b25fcf9009a6cc098cf2e0703f994d74968985.zip
C API: add proj_as_projjson()
Diffstat (limited to 'test/unit/test_c_api.cpp')
-rw-r--r--test/unit/test_c_api.cpp52
1 files changed, 52 insertions, 0 deletions
diff --git a/test/unit/test_c_api.cpp b/test/unit/test_c_api.cpp
index bfbae1a5..5649ca9f 100644
--- a/test/unit/test_c_api.cpp
+++ b/test/unit/test_c_api.cpp
@@ -3489,4 +3489,56 @@ TEST_F(CApi, proj_concatoperation_get_step) {
}
}
+// ---------------------------------------------------------------------------
+
+TEST_F(CApi, proj_as_projjson) {
+ auto obj = proj_create(
+ m_ctxt,
+ Ellipsoid::WGS84->exportToJSON(JSONFormatter::create().get()).c_str());
+ ObjectKeeper keeper(obj);
+ ASSERT_NE(obj, nullptr);
+
+ {
+ auto projjson = proj_as_projjson(m_ctxt, obj, nullptr);
+ ASSERT_NE(projjson, nullptr);
+ EXPECT_EQ(std::string(projjson),
+ "{\n"
+ " \"type\": \"Ellipsoid\",\n"
+ " \"name\": \"WGS 84\",\n"
+ " \"semi_major_axis\": 6378137,\n"
+ " \"inverse_flattening\": 298.257223563,\n"
+ " \"id\": {\n"
+ " \"authority\": \"EPSG\",\n"
+ " \"code\": 7030\n"
+ " }\n"
+ "}");
+ }
+ {
+ const char *const options[] = {"INDENTATION_WIDTH=4", nullptr};
+ auto projjson = proj_as_projjson(m_ctxt, obj, options);
+ ASSERT_NE(projjson, nullptr);
+ EXPECT_EQ(std::string(projjson),
+ "{\n"
+ " \"type\": \"Ellipsoid\",\n"
+ " \"name\": \"WGS 84\",\n"
+ " \"semi_major_axis\": 6378137,\n"
+ " \"inverse_flattening\": 298.257223563,\n"
+ " \"id\": {\n"
+ " \"authority\": \"EPSG\",\n"
+ " \"code\": 7030\n"
+ " }\n"
+ "}");
+ }
+ {
+ const char *const options[] = {"MULTILINE=NO", nullptr};
+ auto projjson = proj_as_projjson(m_ctxt, obj, options);
+ ASSERT_NE(projjson, nullptr);
+ EXPECT_EQ(std::string(projjson),
+ "{\"type\":\"Ellipsoid\",\"name\":\"WGS 84\","
+ "\"semi_major_axis\":6378137,"
+ "\"inverse_flattening\":298.257223563,"
+ "\"id\":{\"authority\":\"EPSG\",\"code\":7030}}");
+ }
+}
+
} // namespace