2016-03-01 11:56:55 -05:00
|
|
|
#include "catch.hpp"
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
#include <osmium/geom/mercator_projection.hpp>
|
2016-03-01 11:56:55 -05:00
|
|
|
#include <osmium/geom/wkb.hpp>
|
|
|
|
#include "wnl_helper.hpp"
|
|
|
|
|
|
|
|
#if __BYTE_ORDER == __LITTLE_ENDIAN
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
TEST_CASE("WKB geometry factory (byte-order-dependant), points") {
|
|
|
|
const osmium::Location loc{3.2, 4.2};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("point") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
const std::string wkb{factory.create_point(loc)};
|
|
|
|
REQUIRE(wkb == "01010000009A99999999990940CDCCCCCCCCCC1040");
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("point in web mercator") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<osmium::geom::MercatorProjection> factory{osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
const std::string wkb{factory.create_point(loc)};
|
|
|
|
REQUIRE(wkb == "010100000028706E7BF9BD1541B03E0D93E48F1C41");
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("point in ewkb") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::ewkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
const std::string wkb{factory.create_point(loc)};
|
|
|
|
REQUIRE(wkb == "0101000020E61000009A99999999990940CDCCCCCCCCCC1040");
|
2016-03-01 11:56:55 -05:00
|
|
|
}
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("point in ewkb in web mercator") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<osmium::geom::MercatorProjection> factory{osmium::geom::wkb_type::ewkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
const std::string wkb{factory.create_point(loc)};
|
|
|
|
REQUIRE(wkb == "0101000020110F000028706E7BF9BD1541B03E0D93E48F1C41");
|
2016-03-01 11:56:55 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
TEST_CASE("WKB geometry factory (byte-order-dependant)") {
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
osmium::memory::Buffer buffer{10000};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("linestring") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex};
|
2016-10-03 13:08:59 -04:00
|
|
|
const auto& wnl = create_test_wnl_okay(buffer);
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
{
|
|
|
|
const std::string wkb{factory.create_linestring(wnl)};
|
|
|
|
REQUIRE(wkb == "0102000000030000009A99999999990940CDCCCCCCCCCC10400000000000000C40CDCCCCCCCCCC1240CDCCCCCCCCCC0C409A99999999991340");
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
{
|
|
|
|
const std::string wkb{factory.create_linestring(wnl, osmium::geom::use_nodes::unique, osmium::geom::direction::backward)};
|
|
|
|
REQUIRE(wkb == "010200000003000000CDCCCCCCCCCC0C409A999999999913400000000000000C40CDCCCCCCCCCC12409A99999999990940CDCCCCCCCCCC1040");
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
{
|
|
|
|
const std::string wkb{factory.create_linestring(wnl, osmium::geom::use_nodes::all)};
|
|
|
|
REQUIRE(wkb == "0102000000040000009A99999999990940CDCCCCCCCCCC10400000000000000C40CDCCCCCCCCCC12400000000000000C40CDCCCCCCCCCC1240CDCCCCCCCCCC0C409A99999999991340");
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
{
|
|
|
|
const std::string wkb{factory.create_linestring(wnl, osmium::geom::use_nodes::all, osmium::geom::direction::backward)};
|
|
|
|
REQUIRE(wkb == "010200000004000000CDCCCCCCCCCC0C409A999999999913400000000000000C40CDCCCCCCCCCC12400000000000000C40CDCCCCCCCCCC12409A99999999990940CDCCCCCCCCCC1040");
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
}
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("linestring as ewkb") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::ewkb, osmium::geom::out_type::hex};
|
2016-10-03 13:08:59 -04:00
|
|
|
|
|
|
|
const auto& wnl = create_test_wnl_okay(buffer);
|
|
|
|
|
|
|
|
const std::string ewkb{factory.create_linestring(wnl)};
|
|
|
|
REQUIRE(ewkb == "0102000020E6100000030000009A99999999990940CDCCCCCCCCCC10400000000000000C40CDCCCCCCCCCC1240CDCCCCCCCCCC0C409A99999999991340");
|
2016-03-01 11:56:55 -05:00
|
|
|
}
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("linestring with two same locations") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
const auto& wnl = create_test_wnl_same_location(buffer);
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("unique forwards (default)") {
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl), osmium::geometry_error);
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("unique backwards") {
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl, osmium::geom::use_nodes::unique, osmium::geom::direction::backward), osmium::geometry_error);
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("all forwards") {
|
|
|
|
const std::string wkb{factory.create_linestring(wnl, osmium::geom::use_nodes::all)};
|
|
|
|
REQUIRE(wkb == "0102000000020000000000000000000C40CDCCCCCCCCCC12400000000000000C40CDCCCCCCCCCC1240");
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("all backwards") {
|
|
|
|
const std::string wkb{factory.create_linestring(wnl, osmium::geom::use_nodes::all, osmium::geom::direction::backward)};
|
|
|
|
REQUIRE(wkb == "0102000000020000000000000000000C40CDCCCCCCCCCC12400000000000000C40CDCCCCCCCCCC1240");
|
|
|
|
}
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("linestring with undefined location") {
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
const auto& wnl = create_test_wnl_undefined_location(buffer);
|
|
|
|
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl), osmium::invalid_location);
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
TEST_CASE("WKB geometry (byte-order-independent)") {
|
|
|
|
|
2016-11-11 09:50:02 -05:00
|
|
|
osmium::geom::WKBFactory<> factory{osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex};
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("empty point") {
|
|
|
|
REQUIRE_THROWS_AS(factory.create_point(osmium::Location{}), osmium::invalid_location);
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
2016-10-03 13:08:59 -04:00
|
|
|
SECTION("empty linestring") {
|
|
|
|
osmium::memory::Buffer buffer{10000};
|
|
|
|
const auto& wnl = create_test_wnl_empty(buffer);
|
|
|
|
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl), osmium::geometry_error);
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl, osmium::geom::use_nodes::unique, osmium::geom::direction::backward), osmium::geometry_error);
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl, osmium::geom::use_nodes::all), osmium::geometry_error);
|
|
|
|
REQUIRE_THROWS_AS(factory.create_linestring(wnl, osmium::geom::use_nodes::all, osmium::geom::direction::backward), osmium::geometry_error);
|
|
|
|
}
|
2016-03-01 11:56:55 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|