summaryrefslogtreecommitdiffstats
path: root/ui/aura_shell/shell_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'ui/aura_shell/shell_unittest.cc')
-rw-r--r--ui/aura_shell/shell_unittest.cc292
1 files changed, 0 insertions, 292 deletions
diff --git a/ui/aura_shell/shell_unittest.cc b/ui/aura_shell/shell_unittest.cc
deleted file mode 100644
index 6a8c0e2..0000000
--- a/ui/aura_shell/shell_unittest.cc
+++ /dev/null
@@ -1,292 +0,0 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "ash/test/aura_shell_test_base.h"
-#include "base/command_line.h"
-#include "base/utf_string_conversions.h"
-#include "ui/aura/test/aura_test_base.h"
-#include "ui/aura/root_window.h"
-#include "ui/aura/window.h"
-#include "ui/aura_shell/aura_shell_switches.h"
-#include "ui/aura_shell/shell.h"
-#include "ui/aura_shell/shell_window_ids.h"
-#include "ui/gfx/size.h"
-#include "ui/views/widget/widget.h"
-#include "ui/views/widget/widget_delegate.h"
-
-namespace aura_shell {
-
-namespace {
-
-views::Widget* CreateTestWindow(const views::Widget::InitParams& params) {
- views::Widget* widget = new views::Widget;
- widget->Init(params);
- return widget;
-}
-
-aura::Window* GetDefaultContainer() {
- return Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_DefaultContainer);
-}
-
-aura::Window* GetAlwaysOnTopContainer() {
- return Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_AlwaysOnTopContainer);
-}
-
-void TestCreateWindow(views::Widget::InitParams::Type type,
- bool always_on_top,
- aura::Window* expected_container) {
- views::Widget::InitParams widget_params(type);
- widget_params.keep_on_top = always_on_top;
-
- views::Widget* widget = CreateTestWindow(widget_params);
- widget->Show();
-
- EXPECT_EQ(expected_container, widget->GetNativeWindow()->parent()) <<
- "TestCreateWindow: type=" << type << ", always_on_top=" << always_on_top;
-
- widget->Close();
-}
-
-class ModalWindow : public views::WidgetDelegateView {
- public:
- ModalWindow() {}
- virtual ~ModalWindow() {}
-
- // Overridden from views::WidgetDelegate:
- virtual views::View* GetContentsView() OVERRIDE {
- return this;
- }
- virtual bool CanResize() const OVERRIDE {
- return true;
- }
- virtual string16 GetWindowTitle() const OVERRIDE {
- return ASCIIToUTF16("Modal Window");
- }
- virtual bool IsModal() const OVERRIDE {
- return true;
- }
-
- private:
- DISALLOW_COPY_AND_ASSIGN(ModalWindow);
-};
-
-// After base::AutoReset<> but via setter and getter.
-class AutoResetUseFullscreenHostWindow {
- public:
- AutoResetUseFullscreenHostWindow(bool new_value) {
- old_value_ = aura::RootWindow::use_fullscreen_host_window();
- aura::RootWindow::set_use_fullscreen_host_window(new_value);
- }
- ~AutoResetUseFullscreenHostWindow() {
- aura::RootWindow::set_use_fullscreen_host_window(old_value_);
- }
- private:
- bool old_value_;
-};
-
-} // namespace
-
-class ShellTest : public test::AuraShellTestBase {
- public:
- ShellTest() {}
- virtual ~ShellTest() {}
-
- private:
- DISALLOW_COPY_AND_ASSIGN(ShellTest);
-};
-
-TEST_F(ShellTest, CreateWindow) {
- // Normal window should be created in default container.
- TestCreateWindow(views::Widget::InitParams::TYPE_WINDOW,
- false, // always_on_top
- GetDefaultContainer());
- TestCreateWindow(views::Widget::InitParams::TYPE_POPUP,
- false, // always_on_top
- GetDefaultContainer());
-
- // Always-on-top window and popup are created in always-on-top container.
- TestCreateWindow(views::Widget::InitParams::TYPE_WINDOW,
- true, // always_on_top
- GetAlwaysOnTopContainer());
- TestCreateWindow(views::Widget::InitParams::TYPE_POPUP,
- true, // always_on_top
- GetAlwaysOnTopContainer());
-}
-
-TEST_F(ShellTest, ChangeAlwaysOnTop) {
- views::Widget::InitParams widget_params(
- views::Widget::InitParams::TYPE_WINDOW);
-
- // Creates a normal window
- views::Widget* widget = CreateTestWindow(widget_params);
- widget->Show();
-
- // It should be in default container.
- EXPECT_EQ(GetDefaultContainer(), widget->GetNativeWindow()->parent());
-
- // Flip always-on-top flag.
- widget->SetAlwaysOnTop(true);
- // And it should in always on top container now.
- EXPECT_EQ(GetAlwaysOnTopContainer(), widget->GetNativeWindow()->parent());
-
- // Flip always-on-top flag.
- widget->SetAlwaysOnTop(false);
- // It should go back to default container.
- EXPECT_EQ(GetDefaultContainer(), widget->GetNativeWindow()->parent());
-
- // Set the same always-on-top flag again.
- widget->SetAlwaysOnTop(false);
- // Should have no effect and we are still in the default container.
- EXPECT_EQ(GetDefaultContainer(), widget->GetNativeWindow()->parent());
-
- widget->Close();
-}
-
-TEST_F(ShellTest, CreateModalWindow) {
- views::Widget::InitParams widget_params(
- views::Widget::InitParams::TYPE_WINDOW);
-
- // Create a normal window.
- views::Widget* widget = CreateTestWindow(widget_params);
- widget->Show();
-
- // It should be in default container.
- EXPECT_EQ(GetDefaultContainer(), widget->GetNativeWindow()->parent());
-
- // Create a modal window.
- views::Widget* modal_widget = views::Widget::CreateWindowWithParent(
- new ModalWindow(), widget->GetNativeView());
- modal_widget->Show();
-
- // It should be in modal container.
- aura::Window* modal_container = Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_ModalContainer);
- EXPECT_EQ(modal_container, modal_widget->GetNativeWindow()->parent());
-
- modal_widget->Close();
- widget->Close();
-}
-
-TEST_F(ShellTest, CreateLockScreenModalWindow) {
- views::Widget::InitParams widget_params(
- views::Widget::InitParams::TYPE_WINDOW);
-
- // Create a normal window.
- views::Widget* widget = CreateTestWindow(widget_params);
- widget->Show();
-
- // It should be in default container.
- EXPECT_EQ(GetDefaultContainer(), widget->GetNativeWindow()->parent());
-
- // Create a LockScreen window.
- views::Widget* lock_widget = CreateTestWindow(widget_params);
- aura_shell::Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_LockScreenContainer)->
- AddChild(lock_widget->GetNativeView());
- lock_widget->Show();
-
- // It should be in LockScreen container.
- aura::Window* lock_screen = Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_LockScreenContainer);
- EXPECT_EQ(lock_screen, lock_widget->GetNativeWindow()->parent());
-
- // Create a modal window with a lock window as parent.
- views::Widget* lock_modal_widget = views::Widget::CreateWindowWithParent(
- new ModalWindow(), lock_widget->GetNativeView());
- lock_modal_widget->Show();
-
- // It should be in LockScreen modal container.
- aura::Window* lock_modal_container = Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_LockModalContainer);
- EXPECT_EQ(lock_modal_container,
- lock_modal_widget->GetNativeWindow()->parent());
-
- // Create a modal window with a normal window as parent.
- views::Widget* modal_widget = views::Widget::CreateWindowWithParent(
- new ModalWindow(), widget->GetNativeView());
- modal_widget->Show();
-
- // It should be in non-LockScreen modal container.
- aura::Window* modal_container = Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_ModalContainer);
- EXPECT_EQ(modal_container, modal_widget->GetNativeWindow()->parent());
-
- modal_widget->Close();
- lock_modal_widget->Close();
- lock_widget->Close();
- widget->Close();
-}
-
-TEST_F(ShellTest, IsScreenLocked) {
- views::Widget::InitParams widget_params(
- views::Widget::InitParams::TYPE_WINDOW);
-
- // A normal window does not lock the screen.
- views::Widget* widget = CreateTestWindow(widget_params);
- widget->Show();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
- widget->Hide();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
-
- // A modal window with a normal window as parent does not locks the screen.
- views::Widget* modal_widget = views::Widget::CreateWindowWithParent(
- new ModalWindow(), widget->GetNativeView());
- modal_widget->Show();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
- modal_widget->Close();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
- widget->Close();
-
- // A lock screen window locks the screen.
- views::Widget* lock_widget = CreateTestWindow(widget_params);
- aura_shell::Shell::GetInstance()->GetContainer(
- aura_shell::internal::kShellWindowId_LockScreenContainer)->
- AddChild(lock_widget->GetNativeView());
- lock_widget->Show();
- EXPECT_TRUE(Shell::GetInstance()->IsScreenLocked());
- lock_widget->Hide();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
-
- // A modal window with a lock window as parent does not lock the screen. The
- // screen is locked only when a lock windown is visible.
- views::Widget* lock_modal_widget = views::Widget::CreateWindowWithParent(
- new ModalWindow(), lock_widget->GetNativeView());
- lock_modal_widget->Show();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
- lock_widget->Show();
- EXPECT_TRUE(Shell::GetInstance()->IsScreenLocked());
- lock_modal_widget->Close();
- EXPECT_TRUE(Shell::GetInstance()->IsScreenLocked());
- lock_widget->Close();
- EXPECT_FALSE(Shell::GetInstance()->IsScreenLocked());
-}
-
-TEST_F(ShellTest, DefaultToCompactWindowMode) {
- // We only change default window mode with full-screen host windows.
- AutoResetUseFullscreenHostWindow use_fullscreen_host_window(true);
-
- // Wide screens use normal window mode.
- Shell* shell = Shell::GetInstance();
- gfx::Size monitor_size(1440, 900);
- CommandLine command_line(CommandLine::NO_PROGRAM);
- EXPECT_FALSE(shell->DefaultToCompactWindowMode(monitor_size, &command_line));
-
- // Alex-sized screens need compact mode.
- monitor_size.SetSize(1280, 800);
- EXPECT_TRUE(shell->DefaultToCompactWindowMode(monitor_size, &command_line));
-
- // ZGB-sized screens need compact mode.
- monitor_size.SetSize(1366, 768);
- EXPECT_TRUE(shell->DefaultToCompactWindowMode(monitor_size, &command_line));
-
- // Even for a small screen, the user can force normal mode.
- monitor_size.SetSize(800, 600);
- command_line.AppendSwitchASCII(aura_shell::switches::kAuraWindowMode,
- aura_shell::switches::kAuraWindowModeNormal);
- EXPECT_FALSE(shell->DefaultToCompactWindowMode(monitor_size, &command_line));
-}
-
-} // namespace aura_shell