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

Unified Diff: ash/wm/overview/window_selector_unittest.cc

Issue 2700523004: Remove docked windows entirely in M59. (Closed)
Patch Set: oshima + mfomitchev comments Created 3 years, 10 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
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 154ef4346ece2e54d60fc143b661de39a2138b43..c1fbd97da9a8faade65d4283a7c03de4d994af26 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"
@@ -551,289 +550,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);

Powered by Google App Engine
This is Rietveld 408576698