Index: mojo/ui/gl_renderer_unittest.cc |
diff --git a/mojo/ui/gl_renderer_unittest.cc b/mojo/ui/gl_renderer_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..c9ffabdfc612ed64f681c857476146c0ccd8914e |
--- /dev/null |
+++ b/mojo/ui/gl_renderer_unittest.cc |
@@ -0,0 +1,209 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/bind.h" |
+#include "base/message_loop/message_loop.h" |
+#include "mojo/gpu/gl_context.h" |
+#include "mojo/gpu/gl_texture.h" |
+#include "mojo/public/cpp/application/application_impl.h" |
+#include "mojo/public/cpp/application/application_test_base.h" |
+#include "mojo/services/geometry/interfaces/geometry.mojom.h" |
+#include "mojo/services/gfx/composition/interfaces/resources.mojom.h" |
+#include "mojo/ui/gl_renderer.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace { |
+ |
+static const base::TimeDelta kDefaultMessageDelay = |
+ base::TimeDelta::FromMilliseconds(20); |
+ |
+class GLRendererTest : public mojo::test::ApplicationTestBase { |
+ public: |
+ GLRendererTest() : weak_factory_(this) {} |
+ ~GLRendererTest() override {} |
+ |
+ void SetUp() override { |
+ mojo::test::ApplicationTestBase::SetUp(); |
+ gl_context_ = mojo::GLContext::CreateOffscreen( |
+ mojo::MakeProxy(application_impl()->CreateApplicationConnector()) |
+ .get()); |
+ quit_message_loop_callback_ = base::Bind( |
+ &GLRendererTest::QuitMessageLoopCallback, weak_factory_.GetWeakPtr()); |
+ } |
+ |
+ void QuitMessageLoopCallback() { base::MessageLoop::current()->Quit(); } |
+ |
+ void KickMessageLoop() { |
+ base::MessageLoop::current()->PostDelayedTask( |
+ FROM_HERE, quit_message_loop_callback_, kDefaultMessageDelay); |
+ base::MessageLoop::current()->Run(); |
+ } |
+ |
+ protected: |
+ base::WeakPtr<mojo::GLContext> gl_context_; |
+ base::Closure quit_message_loop_callback_; |
+ base::WeakPtrFactory<GLRendererTest> weak_factory_; |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(GLRendererTest); |
+}; |
+ |
+TEST_F(GLRendererTest, GetTextureOnce) { |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size; |
+ size.width = 100; |
+ size.height = 100; |
+ |
+ std::unique_ptr<mojo::GLTexture> texture = renderer.GetTexture(size); |
+ EXPECT_NE(texture.get(), nullptr); |
+ |
+ mojo::gfx::composition::ResourcePtr resource = |
+ renderer.BindTextureResource(std::move(texture)); |
+ EXPECT_NE(resource.get(), nullptr); |
+ EXPECT_NE(resource->get_mailbox_texture().get(), nullptr); |
+ EXPECT_FALSE(resource->get_mailbox_texture()->mailbox_name.is_null()); |
+ EXPECT_TRUE(resource->get_mailbox_texture()->size->Equals(size)); |
+ EXPECT_NE(resource->get_mailbox_texture()->sync_point, 0u); |
+ EXPECT_NE(resource->get_mailbox_texture()->callback.get(), nullptr); |
+} |
+ |
+TEST_F(GLRendererTest, GetTextureTwiceSameSize) { |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size; |
+ size.width = 100; |
+ size.height = 100; |
+ |
+ std::unique_ptr<mojo::GLTexture> texture1 = renderer.GetTexture(size); |
+ EXPECT_NE(texture1.get(), nullptr); |
+ |
+ std::unique_ptr<mojo::GLTexture> texture2 = renderer.GetTexture(size); |
+ EXPECT_NE(texture2.get(), nullptr); |
+ |
+ EXPECT_NE(texture2.get(), texture1.get()); |
+ EXPECT_NE(texture2->texture_id(), texture1->texture_id()); |
+ |
+ mojo::gfx::composition::ResourcePtr resource1 = |
+ renderer.BindTextureResource(std::move(texture1)); |
+ EXPECT_NE(resource1.get(), nullptr); |
+ EXPECT_NE(resource1->get_mailbox_texture().get(), nullptr); |
+ EXPECT_FALSE(resource1->get_mailbox_texture()->mailbox_name.is_null()); |
+ EXPECT_TRUE(resource1->get_mailbox_texture()->size->Equals(size)); |
+ EXPECT_NE(resource1->get_mailbox_texture()->sync_point, 0u); |
+ EXPECT_NE(resource1->get_mailbox_texture()->callback.get(), nullptr); |
+ |
+ mojo::gfx::composition::ResourcePtr resource2 = |
+ renderer.BindTextureResource(std::move(texture2)); |
+ EXPECT_NE(resource2.get(), nullptr); |
+ EXPECT_NE(resource2->get_mailbox_texture().get(), nullptr); |
+ EXPECT_FALSE(resource2->get_mailbox_texture()->mailbox_name.is_null()); |
+ EXPECT_TRUE(resource2->get_mailbox_texture()->size->Equals(size)); |
+ EXPECT_NE(resource2->get_mailbox_texture()->sync_point, 0u); |
+ EXPECT_NE(resource2->get_mailbox_texture()->callback.get(), nullptr); |
+ |
+ EXPECT_NE(resource2->get_mailbox_texture()->sync_point, |
+ resource1->get_mailbox_texture()->sync_point); |
+} |
+ |
+TEST_F(GLRendererTest, GetTextureAfterRecycleSameSize) { |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size; |
+ size.width = 100; |
+ size.height = 100; |
+ |
+ std::unique_ptr<mojo::GLTexture> texture1 = renderer.GetTexture(size); |
+ EXPECT_NE(texture1.get(), nullptr); |
+ mojo::GLTexture* original_texture = texture1.get(); |
+ |
+ // Return the texture. |
+ mojo::gfx::composition::ResourcePtr resource1 = |
+ renderer.BindTextureResource(std::move(texture1)); |
+ EXPECT_NE(resource1.get(), nullptr); |
+ resource1->get_mailbox_texture()->callback->OnMailboxTextureReleased(); |
+ |
+ KickMessageLoop(); |
+ |
+ // Get a texture of the same size, it should be the same one as before. |
+ std::unique_ptr<mojo::GLTexture> texture2 = renderer.GetTexture(size); |
+ EXPECT_EQ(texture2.get(), original_texture); |
+} |
+ |
+TEST_F(GLRendererTest, GetTextureAfterRecycleDifferentSize) { |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size1; |
+ size1.width = 100; |
+ size1.height = 100; |
+ std::unique_ptr<mojo::GLTexture> texture1 = renderer.GetTexture(size1); |
+ EXPECT_NE(texture1.get(), nullptr); |
+ EXPECT_TRUE(texture1->size().Equals(size1)); |
+ |
+ // Return the texture. |
+ mojo::gfx::composition::ResourcePtr resource1 = |
+ renderer.BindTextureResource(std::move(texture1)); |
+ EXPECT_NE(resource1.get(), nullptr); |
+ resource1->get_mailbox_texture()->callback->OnMailboxTextureReleased(); |
+ |
+ KickMessageLoop(); |
+ |
+ // Get a texture of the a different size, it should be a new one |
+ // with the new size. |
+ mojo::Size size2; |
+ size2.width = size1.width - 1; |
+ size2.height = size1.height - 1; |
+ std::unique_ptr<mojo::GLTexture> texture2 = renderer.GetTexture(size2); |
+ EXPECT_NE(texture2.get(), nullptr); |
+ EXPECT_TRUE(texture2->size().Equals(size2)); |
+} |
+ |
+TEST_F(GLRendererTest, GetTextureReleasedGlContext) { |
+ gl_context_->Destroy(); |
+ |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size; |
+ size.width = 100; |
+ size.height = 100; |
+ |
+ std::unique_ptr<mojo::GLTexture> texture = renderer.GetTexture(size); |
+ EXPECT_EQ(texture.get(), nullptr); |
+} |
+ |
+TEST_F(GLRendererTest, BindTextureResourceReleasedGlContext) { |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size; |
+ size.width = 100; |
+ size.height = 100; |
+ |
+ std::unique_ptr<mojo::GLTexture> texture = renderer.GetTexture(size); |
+ EXPECT_NE(texture.get(), nullptr); |
+ |
+ gl_context_->Destroy(); |
+ |
+ mojo::gfx::composition::ResourcePtr resource = |
+ renderer.BindTextureResource(std::move(texture)); |
+ EXPECT_EQ(resource.get(), nullptr); |
+} |
+ |
+TEST_F(GLRendererTest, RecycledAfterReleasedGlContext) { |
+ mojo::ui::GLRenderer renderer(gl_context_); |
+ mojo::Size size; |
+ size.width = 100; |
+ size.height = 100; |
+ |
+ std::unique_ptr<mojo::GLTexture> texture1 = renderer.GetTexture(size); |
+ EXPECT_NE(texture1.get(), nullptr); |
+ |
+ mojo::gfx::composition::ResourcePtr resource1 = |
+ renderer.BindTextureResource(std::move(texture1)); |
+ EXPECT_NE(resource1.get(), nullptr); |
+ |
+ gl_context_->Destroy(); |
+ resource1->get_mailbox_texture()->callback->OnMailboxTextureReleased(); |
+ |
+ KickMessageLoop(); |
+ |
+ // Get a texture of the same size, should be null due to the released context. |
+ std::unique_ptr<mojo::GLTexture> texture2 = renderer.GetTexture(size); |
+ EXPECT_EQ(texture2.get(), nullptr); |
+} |
+ |
+} // namespace |