git-subtree-dir: third_party/libosmium git-subtree-split: 2282c8450bae55839372a2002db7ca754530d2fc
		
			
				
	
	
		
			93 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
#include "catch.hpp"
 | 
						|
 | 
						|
#include <osmium/geom/geos.hpp>
 | 
						|
#include <osmium/geom/wkb.hpp>
 | 
						|
 | 
						|
#include "helper.hpp"
 | 
						|
#include "area_helper.hpp"
 | 
						|
#include "wnl_helper.hpp"
 | 
						|
 | 
						|
TEST_CASE("WKB_Geometry_with_GEOS") {
 | 
						|
 | 
						|
SECTION("point") {
 | 
						|
    osmium::geom::WKBFactory<> wkb_factory(osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex);
 | 
						|
    osmium::geom::GEOSFactory<> geos_factory;
 | 
						|
 | 
						|
    std::string wkb {wkb_factory.create_point(osmium::Location(3.2, 4.2))};
 | 
						|
 | 
						|
    std::unique_ptr<geos::geom::Point> geos_point = geos_factory.create_point(osmium::Location(3.2, 4.2));
 | 
						|
    REQUIRE(geos_to_wkb(geos_point.get()) == wkb);
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
SECTION("linestring") {
 | 
						|
    osmium::geom::WKBFactory<> wkb_factory(osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex);
 | 
						|
    osmium::geom::GEOSFactory<> geos_factory;
 | 
						|
 | 
						|
    osmium::memory::Buffer buffer(10000);
 | 
						|
    auto &wnl = create_test_wnl_okay(buffer);
 | 
						|
 | 
						|
    {
 | 
						|
        std::string wkb = wkb_factory.create_linestring(wnl);
 | 
						|
        std::unique_ptr<geos::geom::LineString> geos = geos_factory.create_linestring(wnl);
 | 
						|
        REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
    }
 | 
						|
 | 
						|
    {
 | 
						|
        std::string wkb = wkb_factory.create_linestring(wnl, osmium::geom::use_nodes::unique, osmium::geom::direction::backward);
 | 
						|
        std::unique_ptr<geos::geom::LineString> geos = geos_factory.create_linestring(wnl, osmium::geom::use_nodes::unique, osmium::geom::direction::backward);
 | 
						|
        REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
    }
 | 
						|
 | 
						|
    {
 | 
						|
        std::string wkb = wkb_factory.create_linestring(wnl, osmium::geom::use_nodes::all);
 | 
						|
        std::unique_ptr<geos::geom::LineString> geos = geos_factory.create_linestring(wnl, osmium::geom::use_nodes::all);
 | 
						|
        REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
    }
 | 
						|
 | 
						|
    {
 | 
						|
        std::string wkb = wkb_factory.create_linestring(wnl, osmium::geom::use_nodes::all, osmium::geom::direction::backward);
 | 
						|
        std::unique_ptr<geos::geom::LineString> geos = geos_factory.create_linestring(wnl, osmium::geom::use_nodes::all, osmium::geom::direction::backward);
 | 
						|
        REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
SECTION("area_1outer_0inner") {
 | 
						|
    osmium::geom::WKBFactory<> wkb_factory(osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex);
 | 
						|
    osmium::geom::GEOSFactory<> geos_factory;
 | 
						|
 | 
						|
    osmium::memory::Buffer buffer(10000);
 | 
						|
    const osmium::Area& area = create_test_area_1outer_0inner(buffer);
 | 
						|
 | 
						|
    std::string wkb = wkb_factory.create_multipolygon(area);
 | 
						|
    std::unique_ptr<geos::geom::MultiPolygon> geos = geos_factory.create_multipolygon(area);
 | 
						|
    REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
}
 | 
						|
 | 
						|
SECTION("area_1outer_1inner") {
 | 
						|
    osmium::geom::WKBFactory<> wkb_factory(osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex);
 | 
						|
    osmium::geom::GEOSFactory<> geos_factory;
 | 
						|
 | 
						|
    osmium::memory::Buffer buffer(10000);
 | 
						|
    const osmium::Area& area = create_test_area_1outer_1inner(buffer);
 | 
						|
 | 
						|
    std::string wkb = wkb_factory.create_multipolygon(area);
 | 
						|
    std::unique_ptr<geos::geom::MultiPolygon> geos = geos_factory.create_multipolygon(area);
 | 
						|
    REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
}
 | 
						|
 | 
						|
SECTION("area_2outer_2inner") {
 | 
						|
    osmium::geom::WKBFactory<> wkb_factory(osmium::geom::wkb_type::wkb, osmium::geom::out_type::hex);
 | 
						|
    osmium::geom::GEOSFactory<> geos_factory;
 | 
						|
 | 
						|
    osmium::memory::Buffer buffer(10000);
 | 
						|
    const osmium::Area& area = create_test_area_2outer_2inner(buffer);
 | 
						|
 | 
						|
    std::string wkb = wkb_factory.create_multipolygon(area);
 | 
						|
    std::unique_ptr<geos::geom::MultiPolygon> geos = geos_factory.create_multipolygon(area);
 | 
						|
    REQUIRE(geos_to_wkb(geos.get()) == wkb);
 | 
						|
}
 | 
						|
 | 
						|
}
 | 
						|
 |