1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
#include <cstring>
#include <stdexcept>
#include "common.hpp"
class TestHandler110 : public osmium::handler::Handler {
public:
TestHandler110() :
osmium::handler::Handler() {
}
void node(const osmium::Node& node) const {
constexpr const double epsilon = 0.00000001;
if (node.id() == 110000) {
REQUIRE(node.location().lon() == Approx(1.02).epsilon(epsilon));
REQUIRE(node.location().lat() == Approx(1.12).epsilon(epsilon));
} else if (node.id() == 110001) {
REQUIRE(node.location().lon() == Approx(1.07).epsilon(epsilon));
REQUIRE(node.location().lat() == Approx(1.13).epsilon(epsilon));
} else {
throw std::runtime_error{"Unknown ID"};
}
}
void way(const osmium::Way& way) const {
if (way.id() == 110800) {
REQUIRE(way.version() == 1);
REQUIRE(way.nodes().size() == 2);
REQUIRE_FALSE(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") {
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);
}
|