osrm-backend/third_party/libosmium/test/data-tests/testcases/test-110.cpp

64 lines
1.7 KiB
C++
Raw Normal View History

#include <cmath>
#include <cstring>
#include <stdexcept>
#include "common.hpp"
class TestHandler110 : public osmium::handler::Handler {
public:
TestHandler110() :
osmium::handler::Handler() {
}
void node(const osmium::Node& node) {
constexpr const double epsilon = 0.00000001;
if (node.id() == 110000) {
REQUIRE(std::abs(node.location().lon() - 1.02) < epsilon);
REQUIRE(std::abs(node.location().lat() - 1.12) < epsilon);
} else if (node.id() == 110001) {
REQUIRE(std::abs(node.location().lon() - 1.07) < epsilon);
REQUIRE(std::abs(node.location().lat() - 1.13) < epsilon);
} else {
throw std::runtime_error{"Unknown ID"};
}
}
void way(const osmium::Way& way) {
if (way.id() == 110800) {
REQUIRE(way.version() == 1);
REQUIRE(way.nodes().size() == 2);
REQUIRE(!way.is_closed());
const char *test_id = way.tags().get_value_by_key("test:id");
REQUIRE(test_id);
REQUIRE(!std::strcmp(test_id, "110"));
} else {
throw std::runtime_error{"Unknown ID"};
}
}
}; // class TestHandler110
TEST_CASE("110") {
SECTION("test 110") {
osmium::io::Reader reader(dirname + "/1/110/data.osm");
index_pos_type index_pos;
index_neg_type index_neg;
location_handler_type location_handler(index_pos, index_neg);
location_handler.ignore_errors();
CheckBasicsHandler check_basics_handler(110, 2, 1, 0);
CheckWKTHandler check_wkt_handler(dirname, 110);
TestHandler110 test_handler;
osmium::apply(reader, location_handler, check_basics_handler, check_wkt_handler, test_handler);
}
}