Index: ash/wm/overview/window_selector_unittest.cc |
diff --git a/ash/wm/overview/window_selector_unittest.cc b/ash/wm/overview/window_selector_unittest.cc |
index f114e13f9cf07c7b1f418c1d5683ffa70e54ef3d..d173a5979c22a1a1b8a137c1b8b6b7263afae2e3 100644 |
--- a/ash/wm/overview/window_selector_unittest.cc |
+++ b/ash/wm/overview/window_selector_unittest.cc |
@@ -12,7 +12,6 @@ |
#include "ash/common/shelf/wm_shelf.h" |
#include "ash/common/system/tray/system_tray.h" |
#include "ash/common/test/test_shelf_delegate.h" |
-#include "ash/common/wm/dock/docked_window_layout_manager.h" |
#include "ash/common/wm/maximize_mode/maximize_mode_controller.h" |
#include "ash/common/wm/mru_window_tracker.h" |
#include "ash/common/wm/overview/scoped_transform_overview_window.h" |
@@ -549,289 +548,6 @@ TEST_F(WindowSelectorTest, WindowsOrder) { |
ToggleOverview(); |
} |
-// Test class used for tests that need docked windows enabled. |
-class EnabledDockedWindowsWindowSelectorTest : public WindowSelectorTest { |
- public: |
- EnabledDockedWindowsWindowSelectorTest() = default; |
- ~EnabledDockedWindowsWindowSelectorTest() override = default; |
- |
- void SetUp() override { |
- base::CommandLine::ForCurrentProcess()->AppendSwitch( |
- ash::switches::kAshEnableDockedWindows); |
- WindowSelectorTest::SetUp(); |
- } |
- |
- private: |
- DISALLOW_COPY_AND_ASSIGN(EnabledDockedWindowsWindowSelectorTest); |
-}; |
- |
-// Tests entering overview mode with docked windows |
-TEST_F(EnabledDockedWindowsWindowSelectorTest, BasicWithDocked) { |
- // aura::Window* root_window = Shell::GetPrimaryRootWindow(); |
- gfx::Rect bounds(300, 0, 200, 200); |
- std::unique_ptr<aura::Window> window1(CreateWindow(bounds)); |
- std::unique_ptr<aura::Window> window2(CreateWindow(bounds)); |
- std::unique_ptr<aura::Window> docked1(CreateWindow(bounds)); |
- std::unique_ptr<aura::Window> docked2(CreateWindow(bounds)); |
- |
- wm::WMEvent dock_event(wm::WM_EVENT_DOCK); |
- wm::GetWindowState(docked1.get())->OnWMEvent(&dock_event); |
- |
- wm::WindowState* docked_state2 = wm::GetWindowState(docked2.get()); |
- docked_state2->OnWMEvent(&dock_event); |
- wm::WMEvent minimize_event(wm::WM_EVENT_MINIMIZE); |
- docked_state2->OnWMEvent(&minimize_event); |
- |
- EXPECT_TRUE(WindowsOverlapping(window1.get(), window2.get())); |
- gfx::Rect docked_bounds = docked1->GetBoundsInScreen(); |
- |
- EXPECT_NE(bounds.ToString(), docked_bounds.ToString()); |
- EXPECT_FALSE(WindowsOverlapping(window1.get(), docked1.get())); |
- EXPECT_FALSE(WindowsOverlapping(window1.get(), docked2.get())); |
- EXPECT_FALSE(docked2->IsVisible()); |
- |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, |
- wm::GetWindowState(docked1.get())->GetStateType()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, |
- wm::GetWindowState(docked2.get())->GetStateType()); |
- |
- ToggleOverview(); |
- |
- EXPECT_FALSE(WindowsOverlapping(window1.get(), window2.get())); |
- |
- gfx::Rect container_bounds = docked1->parent()->bounds(); |
- ShelfWidget* shelf = GetPrimaryShelf()->shelf_widget(); |
- DockedWindowLayoutManager* manager = |
- DockedWindowLayoutManager::Get(WmWindow::Get(docked1.get())); |
- |
- // Minimized docked windows stays invisible. |
- EXPECT_FALSE(docked2->IsVisible()); |
- EXPECT_TRUE(GetOverviewWindowForMinimizedState(0, docked2.get())); |
- |
- // Docked area shrinks. |
- EXPECT_EQ(0, manager->docked_bounds().width()); |
- |
- // Work area takes the whole screen minus the shelf. |
- gfx::Rect work_area = display::Screen::GetScreen() |
- ->GetDisplayNearestWindow(docked1.get()) |
- .work_area(); |
- gfx::Size expected_work_area_bounds(container_bounds.size()); |
- expected_work_area_bounds.Enlarge(0, |
- -shelf->GetWindowBoundsInScreen().height()); |
- EXPECT_EQ(expected_work_area_bounds.ToString(), work_area.size().ToString()); |
- |
- // Docked window can still be activated, which will exit the overview mode. |
- ClickWindow(docked1.get()); |
- EXPECT_TRUE(wm::IsActiveWindow(docked1.get())); |
- EXPECT_FALSE(window_selector_controller()->IsSelecting()); |
- |
- // Docked area has a window in it. |
- EXPECT_GT(manager->docked_bounds().width(), 0); |
- |
- // Work area takes the whole screen minus the shelf and the docked area. |
- work_area = display::Screen::GetScreen() |
- ->GetDisplayNearestWindow(docked1.get()) |
- .work_area(); |
- expected_work_area_bounds = container_bounds.size(); |
- expected_work_area_bounds.Enlarge(-manager->docked_bounds().width(), |
- -shelf->GetWindowBoundsInScreen().height()); |
- EXPECT_EQ(expected_work_area_bounds.ToString(), work_area.size().ToString()); |
-} |
- |
-// Tests that selecting a docked window updates docked layout pushing another |
-// window to get docked-minimized. |
-TEST_F(EnabledDockedWindowsWindowSelectorTest, ActivateDockedWindow) { |
- // aura::Window* root_window = Shell::GetPrimaryRootWindow(); |
- gfx::Rect bounds(300, 0, 200, 200); |
- std::unique_ptr<views::Widget> widget1 = CreateWindowWidget(bounds); |
- std::unique_ptr<views::Widget> widget2 = CreateWindowWidget(bounds); |
- |
- aura::test::TestWindowDelegate delegate; |
- delegate.set_minimum_size(gfx::Size(200, 500)); |
- std::unique_ptr<aura::Window> docked_window1( |
- CreateTestWindowInShellWithDelegate(&delegate, -1, bounds)); |
- docked_window1->SetProperty(aura::client::kTopViewInset, kHeaderHeight); |
- std::unique_ptr<aura::Window> docked_window2( |
- CreateTestWindowInShellWithDelegate(&delegate, -1, bounds)); |
- docked_window2->SetProperty(aura::client::kTopViewInset, kHeaderHeight); |
- wm::WindowState* state1 = wm::GetWindowState(docked_window1.get()); |
- wm::WindowState* state2 = wm::GetWindowState(docked_window2.get()); |
- |
- // Dock the second window first, then the first window. |
- wm::WMEvent dock_event(wm::WM_EVENT_DOCK); |
- state2->OnWMEvent(&dock_event); |
- state1->OnWMEvent(&dock_event); |
- |
- // Both windows' restored bounds are same. |
- const gfx::Rect expected_bounds = docked_window1->bounds(); |
- EXPECT_EQ(expected_bounds.ToString(), docked_window2->bounds().ToString()); |
- |
- // |docked_window1| is docked and visible. |
- EXPECT_TRUE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state1->GetStateType()); |
- // |docked_window2| is docked-minimized and hidden. |
- EXPECT_FALSE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state2->GetStateType()); |
- |
- ToggleOverview(); |
- |
- // Minimized should stay minimized. |
- EXPECT_FALSE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state2->GetStateType()); |
- |
- aura::Window* window_for_minimized_docked_window2 = |
- GetOverviewWindowForMinimizedState(0, docked_window2.get()); |
- ASSERT_TRUE(window_for_minimized_docked_window2); |
- |
- // Activate |docked_window2| leaving the overview. |
- const gfx::Rect rect = |
- GetTransformedBoundsInRootWindow(window_for_minimized_docked_window2); |
- gfx::Point point(rect.top_right().x() - 50, rect.top_right().y() + 50); |
- ui::test::EventGenerator event_generator(docked_window2->GetRootWindow(), |
- point); |
- event_generator.ClickLeftButton(); |
- |
- EXPECT_FALSE(IsSelecting()); |
- |
- // Windows' bounds are still the same. |
- EXPECT_EQ(expected_bounds.ToString(), docked_window1->bounds().ToString()); |
- EXPECT_EQ(expected_bounds.ToString(), docked_window2->bounds().ToString()); |
- |
- // |docked_window1| is docked-minimized and hidden. |
- EXPECT_FALSE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state1->GetStateType()); |
- // |docked_window2| is docked and visible. |
- EXPECT_TRUE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state2->GetStateType()); |
-} |
- |
-// Tests that clicking on the close button closes the docked window. |
-TEST_F(EnabledDockedWindowsWindowSelectorTest, CloseDockedWindow) { |
- // aura::Window* root_window = Shell::GetPrimaryRootWindow(); |
- gfx::Rect bounds(300, 0, 200, 200); |
- std::unique_ptr<views::Widget> widget1 = CreateWindowWidget(bounds); |
- std::unique_ptr<views::Widget> widget2 = CreateWindowWidget(bounds); |
- |
- aura::test::TestWindowDelegate delegate; |
- delegate.set_minimum_size(gfx::Size(200, 500)); |
- std::unique_ptr<aura::Window> docked_window1( |
- CreateTestWindowInShellWithDelegate(&delegate, -1, bounds)); |
- docked_window1->SetProperty(aura::client::kTopViewInset, kHeaderHeight); |
- std::unique_ptr<views::Widget> docked2 = CreateWindowWidget(bounds); |
- aura::Window* docked_window2 = docked2->GetNativeWindow(); |
- wm::WindowState* state1 = wm::GetWindowState(docked_window1.get()); |
- wm::WindowState* state2 = wm::GetWindowState(docked_window2); |
- |
- // Dock the first window first, then the second window. |
- wm::WMEvent dock_event(wm::WM_EVENT_DOCK); |
- state1->OnWMEvent(&dock_event); |
- state2->OnWMEvent(&dock_event); |
- |
- const gfx::Rect expected_bounds1 = docked_window1->bounds(); |
- |
- // |docked_window1| is docked-minimized and hidden. |
- EXPECT_FALSE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state1->GetStateType()); |
- // |docked_window2| is docked and visible. |
- EXPECT_TRUE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state2->GetStateType()); |
- |
- ToggleOverview(); |
- |
- // Close |docked_window2| (staying in overview). |
- const gfx::Rect rect = GetTransformedBoundsInRootWindow(docked_window2); |
- gfx::Point point(rect.top_right().x() - 5, rect.top_right().y() + 5); |
- ui::test::EventGenerator event_generator(docked_window2->GetRootWindow(), |
- point); |
- |
- // Minimized window stays invisible and in the minimized state while in |
- // overview. |
- EXPECT_FALSE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state1->GetStateType()); |
- EXPECT_TRUE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state2->GetStateType()); |
- |
- EXPECT_TRUE(GetOverviewWindowForMinimizedState(0, docked_window1.get())); |
- |
- event_generator.ClickLeftButton(); |
- // |docked2| widget is closed. |
- EXPECT_TRUE(docked2->IsClosed()); |
- |
- // Exit overview. |
- ToggleOverview(); |
- |
- // Window bounds are still the same. |
- EXPECT_EQ(expected_bounds1.ToString(), docked_window1->bounds().ToString()); |
- |
- // |docked_window1| returns to docked-minimized and hidden state. |
- EXPECT_FALSE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state1->GetStateType()); |
-} |
- |
-// Tests that clicking on the close button closes the docked-minimized window. |
-TEST_F(EnabledDockedWindowsWindowSelectorTest, CloseDockedMinimizedWindow) { |
- // aura::Window* root_window = Shell::GetPrimaryRootWindow(); |
- gfx::Rect bounds(300, 0, 200, 200); |
- std::unique_ptr<views::Widget> widget1 = CreateWindowWidget(bounds); |
- std::unique_ptr<views::Widget> widget2 = CreateWindowWidget(bounds); |
- |
- aura::test::TestWindowDelegate delegate; |
- delegate.set_minimum_size(gfx::Size(200, 500)); |
- std::unique_ptr<aura::Window> docked_window1( |
- CreateTestWindowInShellWithDelegate(&delegate, -1, bounds)); |
- docked_window1->SetProperty(aura::client::kTopViewInset, kHeaderHeight); |
- std::unique_ptr<views::Widget> docked2 = CreateWindowWidget(bounds); |
- aura::Window* docked_window2 = docked2->GetNativeWindow(); |
- wm::WindowState* state1 = wm::GetWindowState(docked_window1.get()); |
- wm::WindowState* state2 = wm::GetWindowState(docked_window2); |
- |
- // Dock the second window first, then the first window. |
- wm::WMEvent dock_event(wm::WM_EVENT_DOCK); |
- state2->OnWMEvent(&dock_event); |
- state1->OnWMEvent(&dock_event); |
- |
- const gfx::Rect expected_bounds1 = docked_window1->bounds(); |
- |
- // |docked_window1| is docked and visible. |
- EXPECT_TRUE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state1->GetStateType()); |
- // |docked_window2| is docked-minimized and hidden. |
- EXPECT_FALSE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state2->GetStateType()); |
- |
- ToggleOverview(); |
- |
- // Both windows are visible while in overview. |
- EXPECT_TRUE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state1->GetStateType()); |
- EXPECT_FALSE(docked_window2->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED, state2->GetStateType()); |
- |
- // Close |docked_window2| (staying in overview). |
- aura::Window* window_for_minimized_docked_window2 = |
- GetOverviewWindowForMinimizedState(0, docked_window2); |
- ASSERT_TRUE(window_for_minimized_docked_window2); |
- const gfx::Rect rect = |
- GetTransformedBoundsInRootWindow(window_for_minimized_docked_window2); |
- gfx::Point point(rect.top_right().x() - 10, rect.top_right().y() - 10); |
- ui::test::EventGenerator event_generator(docked_window2->GetRootWindow(), |
- point); |
- event_generator.ClickLeftButton(); |
- // |docked2| widget is closed. |
- EXPECT_TRUE(docked2->IsClosed()); |
- |
- // Exit overview. |
- ToggleOverview(); |
- |
- // Window bounds are still the same. |
- EXPECT_EQ(expected_bounds1.ToString(), |
- docked_window1->GetTargetBounds().ToString()); |
- |
- // |docked_window1| returns to docked and visible state. |
- EXPECT_TRUE(docked_window1->IsVisible()); |
- EXPECT_EQ(wm::WINDOW_STATE_TYPE_DOCKED, state1->GetStateType()); |
-} |
- |
// Tests selecting a window by tapping on it. |
TEST_F(WindowSelectorTest, BasicGesture) { |
gfx::Rect bounds(0, 0, 400, 400); |