From e7778509c546f4d1e0dd73e2d1deceb146c90de2 Mon Sep 17 00:00:00 2001 From: John Firebaugh Date: Mon, 9 Jan 2017 13:05:13 -0800 Subject: [core] Fix flickering caused by regression in #7586 It should be safe to invoke GeometryTileWorker::setData multiple times without invoking GeometryTileWorker::setLayers. Therefore GeometryTileWorker::redoLayout() must not consume the layers. --- test/tile/geojson_tile.test.cpp | 72 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 test/tile/geojson_tile.test.cpp (limited to 'test/tile') diff --git a/test/tile/geojson_tile.test.cpp b/test/tile/geojson_tile.test.cpp new file mode 100644 index 0000000000..920e946a2b --- /dev/null +++ b/test/tile/geojson_tile.test.cpp @@ -0,0 +1,72 @@ +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include + +using namespace mbgl; +using namespace mbgl::style; + +class GeoJSONTileTest { +public: + FakeFileSource fileSource; + TransformState transformState; + util::RunLoop loop; + ThreadPool threadPool { 1 }; + AnnotationManager annotationManager { 1.0 }; + style::Style style { fileSource, 1.0 }; + Tileset tileset { { "https://example.com" }, { 0, 22 }, "none" }; + + style::UpdateParameters updateParameters { + 1.0, + MapDebugOptions(), + transformState, + threadPool, + fileSource, + MapMode::Continuous, + annotationManager, + style + }; +}; + +TEST(GeoJSONTile, Issue7648) { + GeoJSONTileTest test; + GeoJSONTile tile(OverscaledTileID(0, 0, 0), "source", test.updateParameters); + + test.style.addLayer(std::make_unique("circle", "source")); + + StubTileObserver observer; + observer.tileChanged = [&] (const Tile&) { + // Once present, the bucket should never "disappear", which would cause + // flickering. + ASSERT_NE(nullptr, tile.getBucket(*test.style.getLayer("circle"))); + }; + tile.setObserver(&observer); + + tile.setPlacementConfig({}); + + mapbox::geometry::feature_collection features; + features.push_back(mapbox::geometry::feature { + mapbox::geometry::point(0, 0) + }); + + tile.updateData(features); + while (!tile.isComplete()) { + test.loop.runOnce(); + } + + tile.updateData(features); + while (!tile.isComplete()) { + test.loop.runOnce(); + } +} -- cgit v1.2.1