| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/exo/shell_surface.h" | 5 #include "components/exo/shell_surface.h" |
| 6 | 6 |
| 7 #include "ash/accessibility_delegate.h" | 7 #include "ash/accessibility_delegate.h" |
| 8 #include "ash/public/cpp/shell_window_ids.h" | 8 #include "ash/public/cpp/shell_window_ids.h" |
| 9 #include "ash/public/cpp/window_properties.h" | 9 #include "ash/public/cpp/window_properties.h" |
| 10 #include "ash/public/interfaces/window_pin_type.mojom.h" | 10 #include "ash/public/interfaces/window_pin_type.mojom.h" |
| 11 #include "ash/shell.h" | 11 #include "ash/shell.h" |
| 12 #include "ash/shell_port.h" | 12 #include "ash/shell_port.h" |
| 13 #include "ash/test/shell_test_api.h" | 13 #include "ash/test/shell_test_api.h" |
| 14 #include "ash/test/workspace_controller_test_api.h" | 14 #include "ash/test/workspace_controller_test_api.h" |
| 15 #include "ash/wm/window_state.h" | 15 #include "ash/wm/window_state.h" |
| 16 #include "ash/wm/wm_event.h" | 16 #include "ash/wm/wm_event.h" |
| 17 #include "ash/wm/workspace/workspace_window_resizer.h" | 17 #include "ash/wm/workspace/workspace_window_resizer.h" |
| 18 #include "ash/wm_window.h" | |
| 19 #include "base/message_loop/message_loop.h" | 18 #include "base/message_loop/message_loop.h" |
| 20 #include "base/strings/utf_string_conversions.h" | 19 #include "base/strings/utf_string_conversions.h" |
| 21 #include "components/exo/buffer.h" | 20 #include "components/exo/buffer.h" |
| 22 #include "components/exo/display.h" | 21 #include "components/exo/display.h" |
| 23 #include "components/exo/sub_surface.h" | 22 #include "components/exo/sub_surface.h" |
| 24 #include "components/exo/surface.h" | 23 #include "components/exo/surface.h" |
| 25 #include "components/exo/test/exo_test_base.h" | 24 #include "components/exo/test/exo_test_base.h" |
| 26 #include "components/exo/test/exo_test_helper.h" | 25 #include "components/exo/test/exo_test_helper.h" |
| 27 #include "testing/gtest/include/gtest/gtest.h" | 26 #include "testing/gtest/include/gtest/gtest.h" |
| 28 #include "ui/aura/client/aura_constants.h" | 27 #include "ui/aura/client/aura_constants.h" |
| (...skipping 836 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 865 surface->Commit(); | 864 surface->Commit(); |
| 866 EXPECT_EQ( | 865 EXPECT_EQ( |
| 867 buffer_size.ToString(), | 866 buffer_size.ToString(), |
| 868 shell_surface->GetWidget()->GetWindowBoundsInScreen().size().ToString()); | 867 shell_surface->GetWidget()->GetWindowBoundsInScreen().size().ToString()); |
| 869 | 868 |
| 870 shell_surface->Maximize(); | 869 shell_surface->Maximize(); |
| 871 EXPECT_EQ(CurrentContext()->bounds().width(), | 870 EXPECT_EQ(CurrentContext()->bounds().width(), |
| 872 shell_surface->GetWidget()->GetWindowBoundsInScreen().width()); | 871 shell_surface->GetWidget()->GetWindowBoundsInScreen().width()); |
| 873 | 872 |
| 874 ash::wm::WMEvent event(ash::wm::WM_EVENT_TOGGLE_FULLSCREEN); | 873 ash::wm::WMEvent event(ash::wm::WM_EVENT_TOGGLE_FULLSCREEN); |
| 875 ash::WmWindow* window = | 874 aura::Window* window = shell_surface->GetWidget()->GetNativeWindow(); |
| 876 ash::WmWindow::Get(shell_surface->GetWidget()->GetNativeWindow()); | |
| 877 | 875 |
| 878 // Enter fullscreen mode. | 876 // Enter fullscreen mode. |
| 879 window->GetWindowState()->OnWMEvent(&event); | 877 ash::wm::GetWindowState(window)->OnWMEvent(&event); |
| 880 | 878 |
| 881 EXPECT_EQ(CurrentContext()->bounds().ToString(), | 879 EXPECT_EQ(CurrentContext()->bounds().ToString(), |
| 882 shell_surface->GetWidget()->GetWindowBoundsInScreen().ToString()); | 880 shell_surface->GetWidget()->GetWindowBoundsInScreen().ToString()); |
| 883 | 881 |
| 884 // Leave fullscreen mode. | 882 // Leave fullscreen mode. |
| 885 window->GetWindowState()->OnWMEvent(&event); | 883 ash::wm::GetWindowState(window)->OnWMEvent(&event); |
| 886 | 884 |
| 887 // Check that shell surface is maximized. | 885 // Check that shell surface is maximized. |
| 888 EXPECT_EQ(CurrentContext()->bounds().width(), | 886 EXPECT_EQ(CurrentContext()->bounds().width(), |
| 889 shell_surface->GetWidget()->GetWindowBoundsInScreen().width()); | 887 shell_surface->GetWidget()->GetWindowBoundsInScreen().width()); |
| 890 } | 888 } |
| 891 | 889 |
| 892 TEST_F(ShellSurfaceTest, MaximizedAndImmersiveFullscreenBackdrop) { | 890 TEST_F(ShellSurfaceTest, MaximizedAndImmersiveFullscreenBackdrop) { |
| 893 ash::WorkspaceController* wc = | 891 ash::WorkspaceController* wc = |
| 894 ash::test::ShellTestApi(ash::Shell::Get()).workspace_controller(); | 892 ash::test::ShellTestApi(ash::Shell::Get()).workspace_controller(); |
| 895 ash::test::WorkspaceControllerTestApi test_helper(wc); | 893 ash::test::WorkspaceControllerTestApi test_helper(wc); |
| (...skipping 16 matching lines...) Expand all Loading... |
| 912 surface->Commit(); | 910 surface->Commit(); |
| 913 EXPECT_EQ(shadow_bounds, | 911 EXPECT_EQ(shadow_bounds, |
| 914 shell_surface->GetWidget()->GetWindowBoundsInScreen()); | 912 shell_surface->GetWidget()->GetWindowBoundsInScreen()); |
| 915 ASSERT_EQ(shadow_bounds, shell_surface->shadow_underlay()->bounds()); | 913 ASSERT_EQ(shadow_bounds, shell_surface->shadow_underlay()->bounds()); |
| 916 EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), | 914 EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), |
| 917 shell_surface->surface_for_testing()->window()->bounds().size()); | 915 shell_surface->surface_for_testing()->window()->bounds().size()); |
| 918 | 916 |
| 919 EXPECT_FALSE(test_helper.GetBackdropWindow()); | 917 EXPECT_FALSE(test_helper.GetBackdropWindow()); |
| 920 | 918 |
| 921 ash::wm::WMEvent fullscreen_event(ash::wm::WM_EVENT_TOGGLE_FULLSCREEN); | 919 ash::wm::WMEvent fullscreen_event(ash::wm::WM_EVENT_TOGGLE_FULLSCREEN); |
| 922 ash::WmWindow* window = | 920 aura::Window* window = shell_surface->GetWidget()->GetNativeWindow(); |
| 923 ash::WmWindow::Get(shell_surface->GetWidget()->GetNativeWindow()); | |
| 924 | 921 |
| 925 // Enter immersive fullscreen mode. Shadow underlay is fullscreen. | 922 // Enter immersive fullscreen mode. Shadow underlay is fullscreen. |
| 926 window->GetWindowState()->OnWMEvent(&fullscreen_event); | 923 ash::wm::GetWindowState(window)->OnWMEvent(&fullscreen_event); |
| 927 | 924 |
| 928 EXPECT_TRUE(test_helper.GetBackdropWindow()); | 925 EXPECT_TRUE(test_helper.GetBackdropWindow()); |
| 929 | 926 |
| 930 // Leave fullscreen mode. Shadow underlay is restored. | 927 // Leave fullscreen mode. Shadow underlay is restored. |
| 931 window->GetWindowState()->OnWMEvent(&fullscreen_event); | 928 ash::wm::GetWindowState(window)->OnWMEvent(&fullscreen_event); |
| 932 EXPECT_FALSE(test_helper.GetBackdropWindow()); | 929 EXPECT_FALSE(test_helper.GetBackdropWindow()); |
| 933 | 930 |
| 934 ash::wm::WMEvent maximize_event(ash::wm::WM_EVENT_TOGGLE_MAXIMIZE); | 931 ash::wm::WMEvent maximize_event(ash::wm::WM_EVENT_TOGGLE_MAXIMIZE); |
| 935 | 932 |
| 936 // Enter maximized mode. | 933 // Enter maximized mode. |
| 937 window->GetWindowState()->OnWMEvent(&maximize_event); | 934 ash::wm::GetWindowState(window)->OnWMEvent(&maximize_event); |
| 938 EXPECT_TRUE(test_helper.GetBackdropWindow()); | 935 EXPECT_TRUE(test_helper.GetBackdropWindow()); |
| 939 | 936 |
| 940 // Leave maximized mode. | 937 // Leave maximized mode. |
| 941 window->GetWindowState()->OnWMEvent(&maximize_event); | 938 ash::wm::GetWindowState(window)->OnWMEvent(&maximize_event); |
| 942 EXPECT_FALSE(test_helper.GetBackdropWindow()); | 939 EXPECT_FALSE(test_helper.GetBackdropWindow()); |
| 943 } | 940 } |
| 944 | 941 |
| 945 // Make sure that a surface shell started in maximize creates deprecated | 942 // Make sure that a surface shell started in maximize creates deprecated |
| 946 // shadow correctly. | 943 // shadow correctly. |
| 947 TEST_F(ShellSurfaceTest, | 944 TEST_F(ShellSurfaceTest, |
| 948 StartMaximizedThenMinimizeWithSetRectangularShadow_DEPRECATED) { | 945 StartMaximizedThenMinimizeWithSetRectangularShadow_DEPRECATED) { |
| 949 const gfx::Size display_size = | 946 const gfx::Size display_size = |
| 950 display::Screen::GetScreen()->GetPrimaryDisplay().size(); | 947 display::Screen::GetScreen()->GetPrimaryDisplay().size(); |
| 951 const gfx::Size buffer_size(display_size); | 948 const gfx::Size buffer_size(display_size); |
| (...skipping 14 matching lines...) Expand all Loading... |
| 966 shell_surface->SetGeometry(shadow_bounds); | 963 shell_surface->SetGeometry(shadow_bounds); |
| 967 shell_surface->SetRectangularShadow_DEPRECATED(shadow_bounds); | 964 shell_surface->SetRectangularShadow_DEPRECATED(shadow_bounds); |
| 968 surface->Commit(); | 965 surface->Commit(); |
| 969 EXPECT_EQ(shadow_bounds, | 966 EXPECT_EQ(shadow_bounds, |
| 970 shell_surface->GetWidget()->GetWindowBoundsInScreen()); | 967 shell_surface->GetWidget()->GetWindowBoundsInScreen()); |
| 971 ASSERT_EQ(shadow_bounds, shell_surface->shadow_underlay()->bounds()); | 968 ASSERT_EQ(shadow_bounds, shell_surface->shadow_underlay()->bounds()); |
| 972 EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), | 969 EXPECT_EQ(display::Screen::GetScreen()->GetPrimaryDisplay().size(), |
| 973 shell_surface->surface_for_testing()->window()->bounds().size()); | 970 shell_surface->surface_for_testing()->window()->bounds().size()); |
| 974 | 971 |
| 975 ash::wm::WMEvent minimize_event(ash::wm::WM_EVENT_MINIMIZE); | 972 ash::wm::WMEvent minimize_event(ash::wm::WM_EVENT_MINIMIZE); |
| 976 ash::WmWindow* window = | 973 aura::Window* window = shell_surface->GetWidget()->GetNativeWindow(); |
| 977 ash::WmWindow::Get(shell_surface->GetWidget()->GetNativeWindow()); | 974 ash::wm::GetWindowState(window)->OnWMEvent(&minimize_event); |
| 978 window->GetWindowState()->OnWMEvent(&minimize_event); | |
| 979 } | 975 } |
| 980 | 976 |
| 981 } // namespace | 977 } // namespace |
| 982 } // namespace exo | 978 } // namespace exo |
| OLD | NEW |