From 7a13bee72e7c31185219dc0e1fb97b80a155ca11 Mon Sep 17 00:00:00 2001 From: Ivo van Dongen Date: Mon, 13 Mar 2017 12:58:09 +0200 Subject: =?UTF-8?q?[core]=20don=E2=80=99t=20query=20rendered=20features=20?= =?UTF-8?q?until=20all=20data=20is=20available?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- test/tile/annotation_tile.test.cpp | 88 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 88 insertions(+) create mode 100644 test/tile/annotation_tile.test.cpp (limited to 'test') diff --git a/test/tile/annotation_tile.test.cpp b/test/tile/annotation_tile.test.cpp new file mode 100644 index 0000000000..4e28a3101c --- /dev/null +++ b/test/tile/annotation_tile.test.cpp @@ -0,0 +1,88 @@ +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include + +using namespace mbgl; + +class AnnotationTileTest { +public: + FakeFileSource fileSource; + TransformState transformState; + util::RunLoop loop; + ThreadPool threadPool { 1 }; + AnnotationManager annotationManager { 1.0 }; + style::Style style { fileSource, 1.0 }; + + style::UpdateParameters updateParameters { + 1.0, + MapDebugOptions(), + transformState, + threadPool, + fileSource, + MapMode::Continuous, + annotationManager, + style + }; +}; + +// Don't query stale collision tile +TEST(AnnotationTile, Issue8289) { + AnnotationTileTest test; + AnnotationTile tile(OverscaledTileID(0, 0, 0), test.updateParameters); + + auto data = std::make_unique(); + data->layers.emplace("test", AnnotationTileLayer("test")); + data->layers.at("test").features.push_back(AnnotationTileFeature(0, FeatureType::Point, GeometryCollection())); + + // Simulate layout and placement of a symbol layer. + tile.onLayout(GeometryTile::LayoutResult { + {}, + std::make_unique(), + std::move(data), + 0 + }); + + auto collisionTile = std::make_unique(PlacementConfig()); + + IndexedSubfeature subfeature { 0, "", "", 0 }; + CollisionFeature feature(GeometryCoordinates(), Anchor(0, 0, 0, 0), -5, 5, -5, 5, 1, 0, style::SymbolPlacementType::Point, subfeature, false); + collisionTile->insertFeature(feature, 0, true); + collisionTile->placeFeature(feature, false, false); + + tile.onPlacement(GeometryTile::PlacementResult { + {}, + std::move(collisionTile), + 0 + }); + + // Simulate a second layout with empty data. + tile.onLayout(GeometryTile::LayoutResult { + {}, + std::make_unique(), + std::make_unique(), + 0 + }); + + std::unordered_map> result; + GeometryCoordinates queryGeometry {{ Point(0, 0) }}; + TransformState transformState; + RenderedQueryOptions options; + + tile.queryRenderedFeatures(result, queryGeometry, transformState, options); + + EXPECT_TRUE(result.empty()); +} + -- cgit v1.2.1