diff options
-rw-r--r-- | test/gl/object.cpp | 91 |
1 files changed, 85 insertions, 6 deletions
diff --git a/test/gl/object.cpp b/test/gl/object.cpp index c804040950..4511fc4d1c 100644 --- a/test/gl/object.cpp +++ b/test/gl/object.cpp @@ -6,6 +6,7 @@ #include <mbgl/gl/gl_helper.hpp> #include <mbgl/gl/gl_config.hpp> #include <mbgl/gl/object_store.hpp> +#include <mbgl/gl/texture_pool.hpp> #include <memory> @@ -73,35 +74,35 @@ TEST(GLObject, Store) { EXPECT_TRUE(store.empty()); mbgl::gl::UniqueProgram program = store.createProgram(); - EXPECT_TRUE(program.get() != 0); + EXPECT_NE(program.get(), 0); program.reset(); EXPECT_FALSE(store.empty()); store.performCleanup(); EXPECT_TRUE(store.empty()); mbgl::gl::UniqueShader shader = store.createShader(GL_VERTEX_SHADER); - EXPECT_TRUE(shader.get() != 0); + EXPECT_NE(shader.get(), 0); shader.reset(); EXPECT_FALSE(store.empty()); store.performCleanup(); EXPECT_TRUE(store.empty()); mbgl::gl::UniqueBuffer buffer = store.createBuffer(); - EXPECT_TRUE(buffer.get() != 0); + EXPECT_NE(buffer.get(), 0); buffer.reset(); EXPECT_FALSE(store.empty()); store.performCleanup(); EXPECT_TRUE(store.empty()); mbgl::gl::UniqueTexture texture = store.createTexture(); - EXPECT_TRUE(texture.get() != 0); + EXPECT_NE(texture.get(), 0); texture.reset(); EXPECT_FALSE(store.empty()); store.performCleanup(); EXPECT_TRUE(store.empty()); mbgl::gl::UniqueVAO vao = store.createVAO(); - EXPECT_TRUE(vao.get() != 0); + EXPECT_NE(vao.get(), 0); vao.reset(); EXPECT_FALSE(store.empty()); store.performCleanup(); @@ -109,8 +110,9 @@ TEST(GLObject, Store) { mbgl::gl::UniqueTexturePool texturePool = store.createTexturePool(); for (auto& id : texturePool.get()) { - EXPECT_TRUE(id != 0); + EXPECT_NE(id, 0); } + EXPECT_TRUE(texturePool.get().size() == size_t(mbgl::gl::TextureMax)); texturePool.reset(); EXPECT_FALSE(store.empty()); store.performCleanup(); @@ -118,3 +120,80 @@ TEST(GLObject, Store) { view.deactivate(); } + +TEST(GLObject, TexturePool) { + mbgl::HeadlessView view(std::make_shared<mbgl::HeadlessDisplay>(), 1); + view.activate(); + + mbgl::gl::ObjectStore store; + EXPECT_TRUE(store.empty()); + + mbgl::gl::TexturePool pool; + + // Fill an entire texture pool. + for (auto i = 0; i != mbgl::gl::TextureMax; ++i) { + EXPECT_EQ(pool.getTextureID(store), GLuint(i + 1)); + EXPECT_TRUE(store.empty()); + } + + // Reuse texture ids from the same pool. + for (auto i = 0; i != mbgl::gl::TextureMax; ++i) { + GLuint id = i + 1; + pool.releaseTextureID(id); + EXPECT_EQ(id, 0); + EXPECT_EQ(pool.getTextureID(store), GLuint(i + 1)); + EXPECT_TRUE(store.empty()); + } + + // Trigger a new texture pool creation. + { + GLuint id = pool.getTextureID(store); + EXPECT_EQ(id, mbgl::gl::TextureMax + 1); + EXPECT_TRUE(store.empty()); + + pool.releaseTextureID(id); + EXPECT_EQ(id, 0); + // Last used texture from pool triggers pool recycling. + EXPECT_FALSE(store.empty()); + + store.performCleanup(); + EXPECT_TRUE(store.empty()); + } + + // First pool is still full, thus creating a new pool. + GLuint id1 = pool.getTextureID(store); + EXPECT_GT(id1, mbgl::gl::TextureMax); + EXPECT_TRUE(store.empty()); + + // Release all textures from the first pool. + for (auto i = 0; i != mbgl::gl::TextureMax; ++i) { + GLuint id = i + 1; + pool.releaseTextureID(id); + if (i == mbgl::gl::TextureMax - 1) { + // Last texture from pool triggers pool recycling. + EXPECT_FALSE(store.empty()); + } else { + EXPECT_TRUE(store.empty()); + } + } + + store.performCleanup(); + EXPECT_TRUE(store.empty()); + + // The first pool is now gone, the next pool is now in use. + GLuint id2 = pool.getTextureID(store); + EXPECT_GT(id2, id1); + pool.releaseTextureID(id2); + EXPECT_EQ(id2, 0); + EXPECT_TRUE(store.empty()); + + // Last used texture from the pool triggers pool recycling. + pool.releaseTextureID(id1); + EXPECT_EQ(id1, 0); + EXPECT_FALSE(store.empty()); + + store.performCleanup(); + EXPECT_TRUE(store.empty()); + + view.deactivate(); +} |