Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(382)

Unified Diff: services/ui/ws/frame_generator_unittest.cc

Issue 2099893002: Mus: Fixes rendering of transparent containers. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix namespace comments Created 4 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « services/ui/ws/frame_generator.cc ('k') | services/ui/ws/test_utils.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: services/ui/ws/frame_generator_unittest.cc
diff --git a/services/ui/ws/frame_generator_unittest.cc b/services/ui/ws/frame_generator_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..0af81b4fc95559589183b8a4ac7a8783069a8f46
--- /dev/null
+++ b/services/ui/ws/frame_generator_unittest.cc
@@ -0,0 +1,131 @@
+// Copyright 2016 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 "services/ui/ws/frame_generator.h"
+
+#include <memory>
+
+#include "base/test/test_message_loop.h"
+#include "cc/quads/render_pass.h"
+#include "cc/quads/shared_quad_state.h"
+#include "services/ui/gles2/gpu_state.h"
+#include "services/ui/ws/platform_display_init_params.h"
+#include "services/ui/ws/server_window.h"
+#include "services/ui/ws/server_window_surface_manager.h"
+#include "services/ui/ws/test_server_window_delegate.h"
+#include "services/ui/ws/test_utils.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace ui {
+namespace ws {
+namespace test {
+namespace {
+
+// Makes the window visible and creates the default surface for it.
+void InitWindow(ServerWindow* window) {
+ window->SetVisible(true);
+ ServerWindowSurfaceManager* surface_manager =
+ window->GetOrCreateSurfaceManager();
+ surface_manager->CreateSurface(mojom::SurfaceType::DEFAULT,
+ mojo::InterfaceRequest<mojom::Surface>(),
+ mojom::SurfaceClientPtr());
+}
+
+} // namespace
+
+class FrameGeneratorTest : public testing::Test {
+ public:
+ FrameGeneratorTest() {}
+ ~FrameGeneratorTest() override {}
+
+ // Calls DrawWindowTree() on |frame_generator_|
+ void DrawWindowTree(cc::RenderPass* pass);
+
+ ServerWindow* root_window() {
+ return frame_generator_delegate_->GetRootWindow();
+ }
+
+ TestServerWindowDelegate* test_window_delegate() { return &window_delegate_; }
+
+ private:
+ // testing::Test:
+ void SetUp() override;
+ void TearDown() override;
+
+ std::unique_ptr<FrameGenerator> frame_generator_;
+ std::unique_ptr<TestFrameGeneratorDelegate> frame_generator_delegate_;
+ TestServerWindowDelegate window_delegate_;
+
+ // Needed so that Mojo classes can be initialized for ServerWindow use.
+ base::TestMessageLoop message_loop_;
+
+ DISALLOW_COPY_AND_ASSIGN(FrameGeneratorTest);
+};
+
+void FrameGeneratorTest::DrawWindowTree(cc::RenderPass* pass) {
+ frame_generator_->DrawWindowTree(
+ pass, frame_generator_delegate_->GetRootWindow(), gfx::Vector2d(), 1.0f);
+}
+
+void FrameGeneratorTest::SetUp() {
+ testing::Test::SetUp();
+ frame_generator_delegate_.reset(new TestFrameGeneratorDelegate(
+ base::WrapUnique(new ServerWindow(&window_delegate_, WindowId()))));
+ PlatformDisplayInitParams init_params;
+ frame_generator_.reset(new FrameGenerator(frame_generator_delegate_.get(),
+ init_params.gpu_state,
+ init_params.surfaces_state));
+ InitWindow(root_window());
+}
+
+void FrameGeneratorTest::TearDown() {
+ frame_generator_.reset();
+ frame_generator_delegate_.reset();
+}
+
+// Tests correctness of the SharedQuadStateList generated by
+// FrameGenerator::DrawWindowTree().
+TEST_F(FrameGeneratorTest, DrawWindowTree) {
+ ServerWindow child_window(test_window_delegate(), WindowId());
+ root_window()->Add(&child_window);
+ InitWindow(&child_window);
+ const float root_opacity = .5f;
+ const float child_opacity = .4f;
+ root_window()->SetOpacity(root_opacity);
+ child_window.SetOpacity(child_opacity);
+
+ std::unique_ptr<cc::RenderPass> render_pass = cc::RenderPass::Create();
+ DrawWindowTree(render_pass.get());
+ cc::SharedQuadStateList* quad_state_list =
+ &render_pass->shared_quad_state_list;
+
+ // Both child and root have a DEFAULT Surface and no underlay Surfaces, so
+ // there should be two SharedQuadStates in the list.
+ EXPECT_EQ(2u, quad_state_list->size());
+ cc::SharedQuadState* root_sqs = quad_state_list->back();
+ cc::SharedQuadState* child_sqs = quad_state_list->front();
+ EXPECT_EQ(root_opacity, root_sqs->opacity);
+ // Child's SharedQuadState contains the effective opacity of the child layer,
+ // which should be a product of the child and the parent opacity.
+ EXPECT_EQ(child_opacity * root_opacity, child_sqs->opacity);
+
+ // Create the UNDERLAY Surface for the child window, and confirm that this
+ // creates an extra SharedQuadState in the CompositorFrame.
+ child_window.GetOrCreateSurfaceManager()->CreateSurface(
+ mojom::SurfaceType::UNDERLAY, mojo::InterfaceRequest<mojom::Surface>(),
+ mojom::SurfaceClientPtr());
+
+ render_pass = cc::RenderPass::Create();
+ DrawWindowTree(render_pass.get());
+ quad_state_list = &render_pass->shared_quad_state_list;
+ EXPECT_EQ(3u, quad_state_list->size());
+ auto it = quad_state_list->begin();
+ EXPECT_EQ(child_opacity * root_opacity, (*it)->opacity);
+ EXPECT_EQ(child_opacity * root_opacity, (*++it)->opacity);
+ EXPECT_EQ(root_opacity, (*++it)->opacity);
+}
+
+} // namespace test
+} // namespace ws
+} // namespace ui
« no previous file with comments | « services/ui/ws/frame_generator.cc ('k') | services/ui/ws/test_utils.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698