diff options
Diffstat (limited to 'chromium/components/exo/shell_surface_unittest.cc')
-rw-r--r-- | chromium/components/exo/shell_surface_unittest.cc | 122 |
1 files changed, 18 insertions, 104 deletions
diff --git a/chromium/components/exo/shell_surface_unittest.cc b/chromium/components/exo/shell_surface_unittest.cc index d92a731337d..ab7cc8176d8 100644 --- a/chromium/components/exo/shell_surface_unittest.cc +++ b/chromium/components/exo/shell_surface_unittest.cc @@ -10,9 +10,11 @@ #include "ash/public/interfaces/window_pin_type.mojom.h" #include "ash/shell.h" #include "ash/shell_port.h" +#include "ash/test/shell_test_api.h" +#include "ash/test/workspace_controller_test_api.h" #include "ash/wm/window_state.h" -#include "ash/wm/window_state_aura.h" #include "ash/wm/wm_event.h" +#include "ash/wm/workspace/workspace_window_resizer.h" #include "ash/wm_window.h" #include "base/message_loop/message_loop.h" #include "base/strings/utf_string_conversions.h" @@ -25,11 +27,9 @@ #include "testing/gtest/include/gtest/gtest.h" #include "ui/aura/client/aura_constants.h" #include "ui/aura/window.h" -#include "ui/aura/window_targeter.h" #include "ui/base/hit_test.h" #include "ui/display/display.h" #include "ui/display/screen.h" -#include "ui/events/base_event_utils.h" #include "ui/views/widget/widget.h" #include "ui/wm/core/shadow.h" #include "ui/wm/core/shadow_controller.h" @@ -838,9 +838,8 @@ TEST_F(ShellSurfaceTest, ShadowStartMaximized) { EXPECT_TRUE(shell_surface->shadow_underlay()->IsVisible()); shell_surface->SetRectangularShadowEnabled(false); surface->Commit(); - // Underlay should be created even without shadow. - ASSERT_TRUE(shell_surface->shadow_underlay()); - EXPECT_TRUE(shell_surface->shadow_underlay()->IsVisible()); + // No underlay if there is no shadow. + EXPECT_FALSE(shell_surface->shadow_underlay()); shell_surface->SetRectangularShadowEnabled(true); shell_surface->SetRectangularSurfaceShadow(gfx::Rect(10, 10, 100, 100)); @@ -890,7 +889,11 @@ TEST_F(ShellSurfaceTest, ToggleFullscreen) { shell_surface->GetWidget()->GetWindowBoundsInScreen().width()); } -TEST_F(ShellSurfaceTest, MaximizedAndImmersiveFullscreenBackground) { +TEST_F(ShellSurfaceTest, MaximizedAndImmersiveFullscreenBackdrop) { + ash::WorkspaceController* wc = + ash::test::ShellTestApi(ash::Shell::Get()).workspace_controller(); + ash::test::WorkspaceControllerTestApi test_helper(wc); + const gfx::Size display_size = display::Screen::GetScreen()->GetPrimaryDisplay().size(); const gfx::Size buffer_size(display_size); @@ -913,6 +916,8 @@ TEST_F(ShellSurfaceTest, MaximizedAndImmersiveFullscreenBackground) { EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), shell_surface->surface_for_testing()->window()->bounds().size()); + EXPECT_FALSE(test_helper.GetBackdropWindow()); + ash::wm::WMEvent fullscreen_event(ash::wm::WM_EVENT_TOGGLE_FULLSCREEN); ash::WmWindow* window = ash::WmWindow::Get(shell_surface->GetWidget()->GetNativeWindow()); @@ -920,112 +925,21 @@ TEST_F(ShellSurfaceTest, MaximizedAndImmersiveFullscreenBackground) { // Enter immersive fullscreen mode. Shadow underlay is fullscreen. window->GetWindowState()->OnWMEvent(&fullscreen_event); - EXPECT_TRUE(shell_surface->shadow_underlay()->IsVisible()); - EXPECT_EQ(1.f, shell_surface->shadow_underlay()->layer()->opacity()); - EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), - shell_surface->shadow_underlay()->bounds().size()); + EXPECT_TRUE(test_helper.GetBackdropWindow()); // Leave fullscreen mode. Shadow underlay is restored. window->GetWindowState()->OnWMEvent(&fullscreen_event); - EXPECT_TRUE(shell_surface->shadow_underlay()->IsVisible()); - EXPECT_EQ(shadow_bounds, shell_surface->shadow_underlay()->bounds()); + EXPECT_FALSE(test_helper.GetBackdropWindow()); ash::wm::WMEvent maximize_event(ash::wm::WM_EVENT_TOGGLE_MAXIMIZE); - // Enter maximized mode. Shadow underlay is fullscreen. + // Enter maximized mode. window->GetWindowState()->OnWMEvent(&maximize_event); - EXPECT_TRUE(shell_surface->shadow_underlay()->IsVisible()); - EXPECT_EQ(1.f, shell_surface->shadow_underlay()->layer()->opacity()); - EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), - shell_surface->shadow_underlay()->bounds().size()); + EXPECT_TRUE(test_helper.GetBackdropWindow()); - // Leave maximized mode. Shadow underlay is fullscreen. + // Leave maximized mode. window->GetWindowState()->OnWMEvent(&maximize_event); - EXPECT_TRUE(shell_surface->shadow_underlay()->IsVisible()); - EXPECT_EQ(1.f, shell_surface->shadow_underlay()->layer()->opacity()); - EXPECT_EQ(shadow_bounds, shell_surface->shadow_underlay()->bounds()); -} - -TEST_F(ShellSurfaceTest, SpokenFeedbackFullscreenBackground) { - const gfx::Size display_size = - display::Screen::GetScreen()->GetPrimaryDisplay().size(); - const gfx::Size buffer_size(display_size); - Buffer buffer(exo_test_helper()->CreateGpuMemoryBuffer(buffer_size)); - Surface surface; - ShellSurface shell_surface(&surface, nullptr, - ShellSurface::BoundsMode::CLIENT, gfx::Point(), - true, false, ash::kShellWindowId_DefaultContainer); - surface.Attach(&buffer); - - gfx::Rect shadow_bounds(10, 10, 100, 100); - shell_surface.SetGeometry(shadow_bounds); - shell_surface.SetRectangularSurfaceShadow(shadow_bounds); - surface.Commit(); - EXPECT_EQ(shadow_bounds, - shell_surface.GetWidget()->GetWindowBoundsInScreen()); - ASSERT_EQ(shadow_bounds, shell_surface.shadow_underlay()->bounds()); - - aura::Window* shell_window = shell_surface.GetWidget()->GetNativeWindow(); - aura::WindowTargeter* targeter = static_cast<aura::WindowTargeter*>( - static_cast<ui::EventTarget*>(shell_window)->GetEventTargeter()); - - gfx::Point pt_out(300, 300); - ui::MouseEvent ev_out(ui::ET_MOUSE_PRESSED, pt_out, pt_out, - ui::EventTimeForNow(), ui::EF_LEFT_MOUSE_BUTTON, - ui::EF_LEFT_MOUSE_BUTTON); - gfx::Point pt_in(70, 70); - ui::MouseEvent ev_in(ui::ET_MOUSE_PRESSED, pt_in, pt_in, - ui::EventTimeForNow(), ui::EF_LEFT_MOUSE_BUTTON, - ui::EF_LEFT_MOUSE_BUTTON); - - EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(shell_window, ev_out)); - - // Enable spoken feedback. - ash::Shell::Get()->accessibility_delegate()->ToggleSpokenFeedback( - ash::A11Y_NOTIFICATION_NONE); - shell_surface.OnAccessibilityModeChanged(); - - EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().bounds(), - shell_surface.shadow_underlay()->bounds()); - EXPECT_TRUE(shell_surface.shadow_underlay()->IsVisible()); - EXPECT_NE(shell_surface.GetWidget()->GetWindowBoundsInScreen(), - shell_surface.shadow_underlay()->bounds()); - - // Test event capture - EXPECT_TRUE(targeter->SubtreeShouldBeExploredForEvent(shell_window, ev_out)); - EXPECT_EQ(shell_surface.shadow_underlay(), - static_cast<ui::EventTargeter*>(targeter)->FindTargetForEvent( - shell_window, &ev_out)); - EXPECT_NE(shell_surface.shadow_underlay(), - static_cast<ui::EventTargeter*>(targeter)->FindTargetForEvent( - shell_window, &ev_in)); - - // Create a new surface - Buffer buffer2(exo_test_helper()->CreateGpuMemoryBuffer(buffer_size)); - Surface surface2; - ShellSurface shell_surface2( - &surface2, nullptr, ShellSurface::BoundsMode::CLIENT, gfx::Point(), true, - false, ash::kShellWindowId_DefaultContainer); - surface2.Attach(&buffer2); - shell_surface2.SetRectangularSurfaceShadow(shadow_bounds); - surface2.Commit(); - - // spoken-feedback was already on, so underlay should fill screen - EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().bounds(), - shell_surface2.shadow_underlay()->bounds()); - - // De-activated shell-surface should NOT have fullscreen underlay - EXPECT_EQ(shadow_bounds, shell_surface.shadow_underlay()->bounds()); - - // Disable spoken feedback. Shadow underlay is restored. - ash::Shell::Get()->accessibility_delegate()->ToggleSpokenFeedback( - ash::A11Y_NOTIFICATION_NONE); - shell_surface.OnAccessibilityModeChanged(); - shell_surface2.OnAccessibilityModeChanged(); - - EXPECT_TRUE(shell_surface.shadow_underlay()->IsVisible()); - EXPECT_EQ(shadow_bounds, shell_surface.shadow_underlay()->bounds()); - EXPECT_EQ(shadow_bounds, shell_surface2.shadow_underlay()->bounds()); + EXPECT_FALSE(test_helper.GetBackdropWindow()); } // Make sure that a surface shell started in maximize creates deprecated |