summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorAnsis Brammanis <ansis.brammanis@gmail.com>2019-04-08 16:28:55 -0400
committerGitHub <noreply@github.com>2019-04-08 16:28:55 -0400
commit104091cd9302c1377b9e4ffb56fc47fac36a2024 (patch)
tree6833e3f7aac80260631c1df4be660efc2face4ac /test
parent37a886570345ea00d705c3cbe58059be33dda130 (diff)
downloadqtlocation-mapboxgl-104091cd9302c1377b9e4ffb56fc47fac36a2024.tar.gz
fix firing onStyleImageMissing after sprite has loaded (#14369)
Diffstat (limited to 'test')
-rw-r--r--test/renderer/image_manager.test.cpp75
1 files changed, 75 insertions, 0 deletions
diff --git a/test/renderer/image_manager.test.cpp b/test/renderer/image_manager.test.cpp
index b73d9b5c7a..d124e67e10 100644
--- a/test/renderer/image_manager.test.cpp
+++ b/test/renderer/image_manager.test.cpp
@@ -157,3 +157,78 @@ TEST(ImageManager, NotifiesRequestorImmediatelyIfDependenciesAreSatisfied) {
ASSERT_TRUE(notified);
}
+
+
+class StubImageManagerObserver : public ImageManagerObserver {
+ public:
+ int count = 0;
+ virtual void onStyleImageMissing(const std::string&, std::function<void()> done) override {
+ count++;
+ done();
+ }
+};
+
+TEST(ImageManager, OnStyleImageMissingBeforeSpriteLoaded) {
+ ImageManager imageManager;
+ StubImageRequestor requestor;
+ StubImageManagerObserver observer;
+
+ imageManager.setObserver(&observer);
+
+ bool notified = false;
+
+ requestor.imagesAvailable = [&] (ImageMap, ImageMap, std::unordered_map<std::string, uint32_t>) {
+ notified = true;
+ };
+
+ uint64_t imageCorrelationID = 0;
+ ImageDependencies dependencies;
+ dependencies.emplace("pre", ImageType::Icon);
+ imageManager.getImages(requestor, std::make_pair(dependencies, imageCorrelationID));
+
+ EXPECT_EQ(observer.count, 0);
+ ASSERT_FALSE(notified);
+
+ imageManager.setLoaded(true);
+
+ EXPECT_EQ(observer.count, 1);
+ ASSERT_FALSE(notified);
+
+ imageManager.notifyIfMissingImageAdded();
+
+ EXPECT_EQ(observer.count, 1);
+ ASSERT_TRUE(notified);
+
+}
+
+TEST(ImageManager, OnStyleImageMissingAfterSpriteLoaded) {
+ ImageManager imageManager;
+ StubImageRequestor requestor;
+ StubImageManagerObserver observer;
+
+ imageManager.setObserver(&observer);
+
+ bool notified = false;
+
+ requestor.imagesAvailable = [&] (ImageMap, ImageMap, std::unordered_map<std::string, uint32_t>) {
+ notified = true;
+ };
+
+ EXPECT_EQ(observer.count, 0);
+ ASSERT_FALSE(notified);
+
+ imageManager.setLoaded(true);
+
+ uint64_t imageCorrelationID = 0;
+ ImageDependencies dependencies;
+ dependencies.emplace("after", ImageType::Icon);
+ imageManager.getImages(requestor, std::make_pair(dependencies, imageCorrelationID));
+
+ EXPECT_EQ(observer.count, 1);
+ ASSERT_FALSE(notified);
+
+ imageManager.notifyIfMissingImageAdded();
+
+ EXPECT_EQ(observer.count, 1);
+ ASSERT_TRUE(notified);
+}