| Index: athena/wm/window_manager_unittest.cc
|
| diff --git a/athena/wm/window_manager_unittest.cc b/athena/wm/window_manager_unittest.cc
|
| index 0f03ae12ce2229b7ae13b6349965fb06353452b6..f3876ec5f2d7348f9363e70007c60723fdd98d75 100644
|
| --- a/athena/wm/window_manager_unittest.cc
|
| +++ b/athena/wm/window_manager_unittest.cc
|
| @@ -19,36 +19,34 @@
|
| #include "ui/gfx/screen.h"
|
| #include "ui/wm/core/window_util.h"
|
|
|
| -namespace {
|
| -
|
| -scoped_ptr<aura::Window> CreateWindow(aura::WindowDelegate* delegate) {
|
| - scoped_ptr<aura::Window> window(new aura::Window(delegate));
|
| - window->SetType(ui::wm::WINDOW_TYPE_NORMAL);
|
| - window->Init(aura::WINDOW_LAYER_SOLID_COLOR);
|
| - window->Show();
|
| - return window.Pass();
|
| -}
|
| +namespace athena {
|
|
|
| -} // namespace
|
| +class WindowManagerTest : public test::AthenaTestBase {
|
| + public:
|
| + WindowManagerTest() {}
|
| + virtual ~WindowManagerTest() {}
|
|
|
| -namespace athena {
|
| + scoped_ptr<aura::Window> CreateAndActivateWindow(
|
| + aura::WindowDelegate* delegate) {
|
| + scoped_ptr<aura::Window> window(CreateTestWindow(delegate, gfx::Rect()));
|
| + window->Show();
|
| + wm::ActivateWindow(window.get());
|
| + return window.Pass();
|
| + }
|
|
|
| -typedef test::AthenaTestBase WindowManagerTest;
|
| + private:
|
| + DISALLOW_COPY_AND_ASSIGN(WindowManagerTest);
|
| +};
|
|
|
| TEST_F(WindowManagerTest, Empty) {
|
| }
|
|
|
| TEST_F(WindowManagerTest, OverviewModeBasics) {
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> second(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndActivateWindow(&delegate));
|
|
|
| test::WindowManagerImplTestApi wm_api;
|
| - aura::client::ParentWindowWithContext(
|
| - first.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - second.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - wm::ActivateWindow(second.get());
|
|
|
| ASSERT_FALSE(WindowManager::GetInstance()->IsOverviewModeActive());
|
| EXPECT_EQ(first->bounds().ToString(), second->bounds().ToString());
|
| @@ -85,10 +83,9 @@ TEST_F(WindowManagerTest, OverviewToSplitViewMode) {
|
| test::WindowManagerImplTestApi wm_api;
|
|
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> w1(CreateTestWindow(&delegate, gfx::Rect()));
|
| - scoped_ptr<aura::Window> w2(CreateTestWindow(&delegate, gfx::Rect()));
|
| - scoped_ptr<aura::Window> w3(CreateTestWindow(&delegate, gfx::Rect()));
|
| - wm::ActivateWindow(w3.get());
|
| + scoped_ptr<aura::Window> w1(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> w2(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> w3(CreateAndActivateWindow(&delegate));
|
|
|
| WindowManager::GetInstance()->ToggleOverview();
|
| EXPECT_TRUE(w1->IsVisible());
|
| @@ -97,7 +94,7 @@ TEST_F(WindowManagerTest, OverviewToSplitViewMode) {
|
|
|
| // Go into split-view mode.
|
| WindowOverviewModeDelegate* overview_delegate = wm_api.wm();
|
| - overview_delegate->OnSplitViewMode(NULL, w2.get());
|
| + overview_delegate->OnSplitViewMode(w3.get(), NULL);
|
| EXPECT_TRUE(w3->IsVisible());
|
| EXPECT_TRUE(w2->IsVisible());
|
| EXPECT_FALSE(w1->IsVisible());
|
| @@ -105,17 +102,11 @@ TEST_F(WindowManagerTest, OverviewToSplitViewMode) {
|
|
|
| TEST_F(WindowManagerTest, BezelGestureToSplitViewMode) {
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> second(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> third(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndActivateWindow(&delegate));
|
|
|
| test::WindowManagerImplTestApi wm_api;
|
| - aura::client::ParentWindowWithContext(
|
| - first.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - second.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - third.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
|
|
| // Test that going into split-view mode with two-finger gesture selects the
|
| // correct windows on left and right splits.
|
| @@ -136,20 +127,13 @@ TEST_F(WindowManagerTest, BezelGestureToSplitViewMode) {
|
|
|
| TEST_F(WindowManagerTest, BezelGestureToSwitchBetweenWindows) {
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> second(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> third(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndActivateWindow(&delegate));
|
| first->Hide();
|
| second->Hide();
|
|
|
| test::WindowManagerImplTestApi wm_api;
|
| - aura::client::ParentWindowWithContext(
|
| - first.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - second.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - third.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| -
|
| EXPECT_EQ(third.get(),
|
| wm_api.GetWindowListProvider()->GetWindowList().back());
|
|
|
| @@ -173,18 +157,11 @@ TEST_F(WindowManagerTest, BezelGestureToSwitchBetweenWindows) {
|
| TEST_F(WindowManagerTest, TitleDragSwitchBetweenWindows) {
|
| aura::test::TestWindowDelegate delegate;
|
| delegate.set_window_component(HTCAPTION);
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> second(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> third(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndActivateWindow(&delegate));
|
|
|
| test::WindowManagerImplTestApi wm_api;
|
| - aura::client::ParentWindowWithContext(
|
| - first.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - second.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - third.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| -
|
| EXPECT_EQ(third.get(),
|
| wm_api.GetWindowListProvider()->GetWindowList().back());
|
|
|
| @@ -226,20 +203,12 @@ TEST_F(WindowManagerTest, TitleDragSwitchBetweenWindows) {
|
| TEST_F(WindowManagerTest, TitleDragSwitchBetweenWindowsInSplitViewMode) {
|
| aura::test::TestWindowDelegate delegate;
|
| delegate.set_window_component(HTCAPTION);
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> second(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> third(CreateWindow(&delegate));
|
| - scoped_ptr<aura::Window> fourth(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> fourth(CreateAndActivateWindow(&delegate));
|
|
|
| test::WindowManagerImplTestApi wm_api;
|
| - aura::client::ParentWindowWithContext(
|
| - first.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - second.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - third.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| - aura::client::ParentWindowWithContext(
|
| - fourth.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
|
|
| // Test that going into split-view mode with two-finger gesture selects the
|
| // correct windows on left and right splits.
|
| @@ -262,12 +231,13 @@ TEST_F(WindowManagerTest, TitleDragSwitchBetweenWindowsInSplitViewMode) {
|
| 5);
|
| EXPECT_EQ(second.get(), wm_api.GetSplitViewController()->left_window());
|
| EXPECT_EQ(fourth.get(), wm_api.GetSplitViewController()->right_window());
|
| + EXPECT_TRUE(wm::IsActiveWindow(second.get()));
|
| aura::Window::Windows windows =
|
| wm_api.GetWindowListProvider()->GetWindowList();
|
| ASSERT_EQ(4u, windows.size());
|
| EXPECT_EQ(second.get(), windows[3]);
|
| - EXPECT_EQ(third.get(), windows[2]);
|
| - EXPECT_EQ(fourth.get(), windows[1]);
|
| + EXPECT_EQ(fourth.get(), windows[2]);
|
| + EXPECT_EQ(third.get(), windows[1]);
|
|
|
| // Swipe the title of the right window now. It should switch to |third|.
|
| generator.GestureScrollSequence(gfx::Point(x_middle + 20, 10),
|
| @@ -276,15 +246,20 @@ TEST_F(WindowManagerTest, TitleDragSwitchBetweenWindowsInSplitViewMode) {
|
| 5);
|
| EXPECT_EQ(second.get(), wm_api.GetSplitViewController()->left_window());
|
| EXPECT_EQ(third.get(), wm_api.GetSplitViewController()->right_window());
|
| + EXPECT_TRUE(wm::IsActiveWindow(third.get()));
|
| + windows = wm_api.GetWindowListProvider()->GetWindowList();
|
| + ASSERT_EQ(4u, windows.size());
|
| + EXPECT_EQ(third.get(), windows[3]);
|
| + EXPECT_EQ(second.get(), windows[2]);
|
| + EXPECT_EQ(fourth.get(), windows[1]);
|
| }
|
|
|
| TEST_F(WindowManagerTest, NewWindowBounds) {
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndActivateWindow(&delegate));
|
|
|
| test::WindowManagerImplTestApi wm_api;
|
| - aura::client::ParentWindowWithContext(
|
| - first.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| +
|
| // The window should have the same size as the container.
|
| const gfx::Size work_area =
|
| gfx::Screen::GetNativeScreen()->GetPrimaryDisplay().work_area().size();
|
| @@ -293,22 +268,18 @@ TEST_F(WindowManagerTest, NewWindowBounds) {
|
| EXPECT_TRUE(first->bounds().origin().IsOrigin());
|
|
|
| // A second window should have the same bounds as the first one.
|
| - scoped_ptr<aura::Window> second(CreateWindow(&delegate));
|
| - aura::client::ParentWindowWithContext(
|
| - second.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| + scoped_ptr<aura::Window> second(CreateAndActivateWindow(&delegate));
|
| EXPECT_EQ(first->bounds().ToString(), second->bounds().ToString());
|
|
|
| // Get into split view.
|
| - wm_api.GetSplitViewController()->ActivateSplitMode(NULL, NULL);
|
| + wm_api.GetSplitViewController()->ActivateSplitMode(NULL, second.get());
|
| const gfx::Rect left_bounds =
|
| wm_api.GetSplitViewController()->left_window()->bounds();
|
| EXPECT_NE(work_area.ToString(),
|
| left_bounds.size().ToString());
|
|
|
| // A new window should replace the left window when in split view.
|
| - scoped_ptr<aura::Window> third(CreateWindow(&delegate));
|
| - aura::client::ParentWindowWithContext(
|
| - third.get(), ScreenManager::Get()->GetContext(), gfx::Rect());
|
| + scoped_ptr<aura::Window> third(CreateAndActivateWindow(&delegate));
|
| EXPECT_EQ(wm_api.GetSplitViewController()->left_window(), third.get());
|
| EXPECT_EQ(left_bounds.ToString(), third->bounds().ToString());
|
| }
|
| @@ -317,21 +288,15 @@ TEST_F(WindowManagerTest, SplitModeActivationByShortcut) {
|
| test::WindowManagerImplTestApi wm_api;
|
|
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> w1(CreateTestWindow(&delegate, gfx::Rect()));
|
| - w1->Show();
|
| -
|
| - ui::test::EventGenerator generator(root_window());
|
| + scoped_ptr<aura::Window> w1(CreateAndActivateWindow(&delegate));
|
|
|
| // Splitview mode needs at least two windows.
|
| - generator.PressKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| - generator.ReleaseKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| + wm_api.wm()->ToggleSplitView();
|
| EXPECT_FALSE(wm_api.GetSplitViewController()->IsSplitViewModeActive());
|
|
|
| - scoped_ptr<aura::Window> w2(CreateTestWindow(&delegate, gfx::Rect()));
|
| - w2->Show();
|
| + scoped_ptr<aura::Window> w2(CreateAndActivateWindow(&delegate));
|
|
|
| - generator.PressKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| - generator.ReleaseKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| + wm_api.wm()->ToggleSplitView();
|
| EXPECT_TRUE(wm_api.GetSplitViewController()->IsSplitViewModeActive());
|
| int width =
|
| gfx::Screen::GetNativeScreen()->GetPrimaryDisplay().work_area().width();
|
| @@ -340,8 +305,7 @@ TEST_F(WindowManagerTest, SplitModeActivationByShortcut) {
|
| EXPECT_EQ(width / 2, w2->bounds().width());
|
|
|
| // Toggle back to normal mode.
|
| - generator.PressKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| - generator.ReleaseKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| + wm_api.wm()->ToggleSplitView();
|
| EXPECT_FALSE(wm_api.GetSplitViewController()->IsSplitViewModeActive());
|
|
|
| EXPECT_EQ(width, w1->bounds().width());
|
| @@ -352,12 +316,12 @@ TEST_F(WindowManagerTest, OverviewModeFromSplitMode) {
|
| test::WindowManagerImplTestApi wm_api;
|
|
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> w1(CreateTestWindow(&delegate, gfx::Rect()));
|
| - scoped_ptr<aura::Window> w2(CreateTestWindow(&delegate, gfx::Rect()));
|
| - scoped_ptr<aura::Window> w3(CreateTestWindow(&delegate, gfx::Rect()));
|
| + scoped_ptr<aura::Window> w1(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> w2(CreateAndActivateWindow(&delegate));
|
| + scoped_ptr<aura::Window> w3(CreateAndActivateWindow(&delegate));
|
|
|
| // Get into split-view mode, and then turn on overview mode.
|
| - wm_api.GetSplitViewController()->ActivateSplitMode(NULL, NULL);
|
| + wm_api.GetSplitViewController()->ActivateSplitMode(w3.get(), NULL);
|
| WindowManager::GetInstance()->ToggleOverview();
|
| EXPECT_TRUE(wm_api.GetSplitViewController()->IsSplitViewModeActive());
|
| EXPECT_EQ(w3.get(), wm_api.GetSplitViewController()->left_window());
|
|
|