| Index: athena/wm/window_manager_unittest.cc
|
| diff --git a/athena/wm/window_manager_unittest.cc b/athena/wm/window_manager_unittest.cc
|
| index 9641c4854ca98d7c4fcce0fc8426487af6fafb79..9bcb5b8906a199207f9035e2f95fdbdb5d531a52 100644
|
| --- a/athena/wm/window_manager_unittest.cc
|
| +++ b/athena/wm/window_manager_unittest.cc
|
| @@ -19,32 +19,29 @@
|
| #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> CreateAndShowWindow(aura::WindowDelegate* delegate) {
|
| + scoped_ptr<aura::Window> window(CreateTestWindow(delegate, gfx::Rect()));
|
| + window->Show();
|
| + return window.Pass();
|
| + }
|
|
|
| -typedef test::AthenaTestBase WindowManagerTest;
|
| + private:
|
| + DISALLOW_COPY_AND_ASSIGN(WindowManagerTest);
|
| +};
|
|
|
| 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(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndShowWindow(&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());
|
| @@ -82,9 +79,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()));
|
| + scoped_ptr<aura::Window> w1(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> w2(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> w3(CreateAndShowWindow(&delegate));
|
| wm::ActivateWindow(w3.get());
|
|
|
| WindowManager::GetInstance()->ToggleOverview();
|
| @@ -94,25 +91,39 @@ TEST_F(WindowManagerTest, OverviewToSplitViewMode) {
|
|
|
| // Go into split-view mode.
|
| WindowOverviewModeDelegate* overview_delegate = wm_api.wm();
|
| - overview_delegate->OnSplitViewMode(NULL, w2.get());
|
| + overview_delegate->OnSelectSplitViewWindow(w3.get(), NULL, w3.get());
|
| EXPECT_TRUE(w3->IsVisible());
|
| EXPECT_TRUE(w2->IsVisible());
|
| EXPECT_FALSE(w1->IsVisible());
|
| }
|
|
|
| +TEST_F(WindowManagerTest, NewWindowFromOverview) {
|
| + aura::test::TestWindowDelegate delegate;
|
| + scoped_ptr<aura::Window> w1(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> w2(CreateAndShowWindow(&delegate));
|
| +
|
| + WindowManager::GetInstance()->ToggleOverview();
|
| + EXPECT_TRUE(w1->IsVisible());
|
| + EXPECT_TRUE(w2->IsVisible());
|
| +
|
| + // Test that opening a new window exits overview mode. The new window could
|
| + // have been opened by JavaScript or by the home card.
|
| + scoped_ptr<aura::Window> w3(CreateAndShowWindow(&delegate));
|
| +
|
| + ASSERT_FALSE(WindowManager::GetInstance()->IsOverviewModeActive());
|
| + EXPECT_TRUE(w3->IsVisible());
|
| + EXPECT_TRUE(wm::IsActiveWindow(w3.get()));
|
| + EXPECT_FALSE(w1->IsVisible());
|
| + EXPECT_FALSE(w2->IsVisible());
|
| +}
|
| +
|
| 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(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndShowWindow(&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.
|
| @@ -133,19 +144,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(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndShowWindow(&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());
|
| @@ -167,17 +172,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(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndShowWindow(&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());
|
| @@ -220,20 +219,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(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> second(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> third(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> fourth(CreateAndShowWindow(&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.
|
| @@ -277,11 +268,9 @@ TEST_F(WindowManagerTest, TitleDragSwitchBetweenWindowsInSplitViewMode) {
|
|
|
| TEST_F(WindowManagerTest, NewWindowBounds) {
|
| aura::test::TestWindowDelegate delegate;
|
| - scoped_ptr<aura::Window> first(CreateWindow(&delegate));
|
| + scoped_ptr<aura::Window> first(CreateAndShowWindow(&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();
|
| @@ -290,9 +279,7 @@ 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(CreateAndShowWindow(&delegate));
|
| EXPECT_EQ(first->bounds().ToString(), second->bounds().ToString());
|
|
|
| // Get into split view.
|
| @@ -303,9 +290,7 @@ TEST_F(WindowManagerTest, NewWindowBounds) {
|
| 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(CreateAndShowWindow(&delegate));
|
| EXPECT_EQ(wm_api.GetSplitViewController()->left_window(), third.get());
|
| EXPECT_EQ(left_bounds.ToString(), third->bounds().ToString());
|
| }
|
| @@ -324,7 +309,7 @@ TEST_F(WindowManagerTest, SplitModeActivationByShortcut) {
|
| generator.ReleaseKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| EXPECT_FALSE(wm_api.GetSplitViewController()->IsSplitViewModeActive());
|
|
|
| - scoped_ptr<aura::Window> w2(CreateTestWindow(&delegate, gfx::Rect()));
|
| + scoped_ptr<aura::Window> w2(CreateAndShowWindow(&delegate));
|
| w2->Show();
|
|
|
| generator.PressKey(ui::VKEY_F6, ui::EF_CONTROL_DOWN);
|
| @@ -349,9 +334,9 @@ 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(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> w2(CreateAndShowWindow(&delegate));
|
| + scoped_ptr<aura::Window> w3(CreateAndShowWindow(&delegate));
|
|
|
| // Get into split-view mode, and then turn on overview mode.
|
| wm_api.GetSplitViewController()->ActivateSplitMode(NULL, NULL);
|
|
|