Index: chrome/browser/ui/window_sizer/window_sizer_ash_unittest.cc |
diff --git a/chrome/browser/ui/window_sizer/window_sizer_ash_unittest.cc b/chrome/browser/ui/window_sizer/window_sizer_ash_unittest.cc |
index 4cb09de078633a5d81b45e6d22d2022ad02ecd9c..ee07942c737b4e24c52e34ff07854b7f166ab419 100644 |
--- a/chrome/browser/ui/window_sizer/window_sizer_ash_unittest.cc |
+++ b/chrome/browser/ui/window_sizer/window_sizer_ash_unittest.cc |
@@ -2,86 +2,22 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "chrome/browser/ui/window_sizer/window_sizer.h" |
- |
-#include <vector> |
+#include "chrome/browser/ui/window_sizer/window_sizer_common_unittest.h" |
#include "ash/shell.h" |
-#include "ash/test/ash_test_base.h" |
#include "ash/test/test_shell_delegate.h" |
#include "ash/wm/window_resizer.h" |
#include "base/compiler_specific.h" |
-#include "base/logging.h" |
#include "chrome/browser/ui/browser.h" |
-#include "chrome/browser/ui/window_sizer/window_sizer_common_unittest.h" |
+#include "chrome/common/chrome_switches.h" |
#include "chrome/test/base/testing_profile.h" |
-#include "chrome/test/base/test_browser_window.h" |
-#include "content/public/browser/browser_thread.h" |
#include "content/public/test/render_view_test.h" |
-#include "content/public/test/test_browser_thread.h" |
#include "testing/gtest/include/gtest/gtest.h" |
#include "third_party/WebKit/Source/WebKit/chromium/public/WebKit.h" |
#include "ui/aura/env.h" |
#include "ui/aura/root_window.h" |
#include "ui/aura/test/test_windows.h" |
- |
-namespace { |
- |
-typedef ash::test::AshTestBase WindowSizerTest; |
- |
-// A special test class for use with browser creation - it will create a |
-// browser thread and deletes it after all other things have been destroyed. |
-class WindowSizerTestWithBrowser : public WindowSizerTest { |
- public: |
- WindowSizerTestWithBrowser(); |
- virtual ~WindowSizerTestWithBrowser(); |
- |
- private: |
- // Note: It is important to delete the thread after the browser instances got |
- // deleted. For this we transfer the thread here. |
- scoped_ptr<content::TestBrowserThread> ui_thread_; |
- |
- DISALLOW_COPY_AND_ASSIGN(WindowSizerTestWithBrowser); |
-}; |
- |
-WindowSizerTestWithBrowser::WindowSizerTestWithBrowser() { |
- // Set up a UI message thread. |
- MessageLoopForUI* ui_loop = message_loop(); |
- ui_thread_.reset( |
- new content::TestBrowserThread(content::BrowserThread::UI, ui_loop)); |
-} |
- |
-WindowSizerTestWithBrowser::~WindowSizerTestWithBrowser() { |
-} |
- |
-// A browser window proxy which is able to associate an aura native window with |
-// it. |
-class TestBrowserWindowAura : public TestBrowserWindow { |
- public: |
- explicit TestBrowserWindowAura(aura::Window* native_window); |
- virtual ~TestBrowserWindowAura(); |
- |
- virtual gfx::NativeWindow GetNativeWindow() OVERRIDE { |
- return native_window_; |
- } |
- |
- virtual gfx::Rect GetBounds() const { |
- return native_window_->bounds(); |
- } |
- |
- private: |
- gfx::NativeWindow native_window_; |
- |
- DISALLOW_COPY_AND_ASSIGN(TestBrowserWindowAura); |
-}; |
- |
-} // namespace |
- |
-TestBrowserWindowAura::TestBrowserWindowAura(aura::Window *native_window) |
- : native_window_(native_window) { |
-} |
- |
-TestBrowserWindowAura::~TestBrowserWindowAura() {} |
+#include "ui/aura/client/aura_constants.h" |
int AlignToGridRoundDown(int location, int grid_size) { |
if (grid_size <= 1 || location % grid_size == 0) |
@@ -763,3 +699,81 @@ TEST_F(WindowSizerTest, AdjustFitSize) { |
EXPECT_EQ("924,668 100x100", window_bounds.ToString()); |
} |
} |
+ |
+// Test that the show state is properly returned for non default cases. |
+TEST_F(WindowSizerTestWithBrowser, TestShowState) { |
+ // Creating a browser & window to play with. |
+ scoped_ptr<aura::Window> window( |
+ aura::test::CreateTestWindowWithId(0, NULL)); |
+ window->SetBounds(gfx::Rect(16, 32, 640, 320)); |
+ |
+ scoped_ptr<TestingProfile> profile(new TestingProfile()); |
+ |
+ scoped_ptr<BrowserWindow> browser_window( |
+ new TestBrowserWindowAura(window.get())); |
+ Browser::CreateParams window_params(Browser::TYPE_TABBED, profile.get()); |
+ window_params.window = browser_window.get(); |
+ scoped_ptr<Browser> browser(new Browser(window_params)); |
+ |
+ // Create also a popup browser since that behaves different. |
+ scoped_ptr<aura::Window> popup( |
+ aura::test::CreateTestWindowWithId(1, NULL)); |
+ popup->SetBounds(gfx::Rect(16, 32, 128, 256)); |
+ |
+ scoped_ptr<BrowserWindow> browser_popup( |
+ new TestBrowserWindowAura(popup.get())); |
+ Browser::CreateParams popup_params(Browser::TYPE_POPUP, profile.get()); |
+ popup_params.window = browser_window.get(); |
+ scoped_ptr<Browser> popup_browser(new Browser(popup_params)); |
+ |
+ // Tabbed windows should retrieve the saved window state - since there is a |
+ // top window. |
+ EXPECT_EQ(ui::SHOW_STATE_MAXIMIZED, |
+ GetWindowShowState(ui::SHOW_STATE_MAXIMIZED, |
+ ui::SHOW_STATE_NORMAL, |
+ BOTH, |
+ browser.get())); |
+ EXPECT_EQ(ui::SHOW_STATE_DEFAULT, |
+ GetWindowShowState(ui::SHOW_STATE_DEFAULT, |
+ ui::SHOW_STATE_NORMAL, |
+ BOTH, |
+ browser.get())); |
+ // Non tabbed windows should always follow the window saved visibility state. |
+ EXPECT_EQ(ui::SHOW_STATE_MAXIMIZED, |
+ GetWindowShowState(ui::SHOW_STATE_MAXIMIZED, |
+ ui::SHOW_STATE_NORMAL, |
+ BOTH, |
+ popup_browser.get())); |
+ // The non tabbed window will take the status of the last active of its kind. |
+ EXPECT_EQ(ui::SHOW_STATE_NORMAL, |
+ GetWindowShowState(ui::SHOW_STATE_DEFAULT, |
+ ui::SHOW_STATE_NORMAL, |
+ BOTH, |
+ popup_browser.get())); |
+ |
+ // Now create a top level window and check again for both. Only the tabbed |
+ // window should follow the top level window's state. |
+ // Creating a browser & window to play with. |
+ scoped_ptr<aura::Window> window2( |
+ aura::test::CreateTestWindowWithId(0, NULL)); |
+ window->SetBounds(gfx::Rect(16, 32, 640, 320)); |
+ |
+ scoped_ptr<BrowserWindow> browser_window2( |
+ new TestBrowserWindowAura(window2.get())); |
+ Browser::CreateParams window2_params(Browser::TYPE_TABBED, profile.get()); |
+ window2_params.window = browser_window2.get(); |
+ scoped_ptr<Browser> browser2(new Browser(window2_params)); |
+ |
+ // A tabbed window should now take the top level window state. |
+ EXPECT_EQ(ui::SHOW_STATE_DEFAULT, |
+ GetWindowShowState(ui::SHOW_STATE_MAXIMIZED, |
+ ui::SHOW_STATE_DEFAULT, |
+ BOTH, |
+ browser2.get())); |
+ // Non tabbed windows should always follow the window saved visibility state. |
+ EXPECT_EQ(ui::SHOW_STATE_MAXIMIZED, |
+ GetWindowShowState(ui::SHOW_STATE_MAXIMIZED, |
+ ui::SHOW_STATE_MINIMIZED, |
+ BOTH, |
+ popup_browser.get())); |
+} |