Chromium Code Reviews| Index: ash/launcher/launcher_unittest.cc |
| diff --git a/ash/launcher/launcher_unittest.cc b/ash/launcher/launcher_unittest.cc |
| index 688a29ac28bbf422e99a804922b62fa3156a9145..a572c7187e36716d58f463483c2e9ccf3c1b2fd3 100644 |
| --- a/ash/launcher/launcher_unittest.cc |
| +++ b/ash/launcher/launcher_unittest.cc |
| @@ -10,6 +10,7 @@ |
| #include "ash/shelf/shelf_widget.h" |
| #include "ash/shell.h" |
| #include "ash/test/ash_test_base.h" |
| +#include "ash/test/launcher_test_api.h" |
| #include "ash/test/launcher_view_test_api.h" |
| #include "ash/wm/window_util.h" |
| #include "ui/aura/root_window.h" |
| @@ -29,90 +30,119 @@ using ash::internal::LauncherButton; |
| namespace ash { |
| +class LauncherTest : public ash::test::AshTestBase { |
| + public: |
| + LauncherTest() {} |
| + virtual ~LauncherTest() {} |
| + |
| + virtual void SetUp() { |
| + test::AshTestBase::SetUp(); |
| + |
| + launcher_ = Launcher::ForPrimaryDisplay(); |
| + ASSERT_TRUE(launcher_); |
| + |
| + ash::test::LauncherTestAPI test(launcher_); |
| + launcher_view_ = test.launcher_view(); |
| + launcher_model_ = launcher_view_->model(); |
| + |
| + test_.reset(new ash::test::LauncherViewTestAPI(launcher_view_)); |
| + } |
| + |
| + virtual void TearDown() OVERRIDE { |
| + test::AshTestBase::TearDown(); |
| + } |
| + |
| + Launcher* launcher() { |
| + return launcher_; |
| + } |
| + |
| + LauncherView* launcher_view() { |
| + return launcher_view_; |
| + } |
| + |
| + LauncherModel* launcher_model() { |
| + return launcher_model_; |
| + } |
| + |
| + ash::test::LauncherViewTestAPI* test_api() { |
| + return test_.get(); |
| + } |
| + |
| + private: |
| + Launcher* launcher_; |
|
sky
2013/09/13 17:12:25
member initialize these to NULL.
simonhong_
2013/09/13 17:21:48
Done.
|
| + LauncherView* launcher_view_; |
| + LauncherModel* launcher_model_; |
| + scoped_ptr<ash::test::LauncherViewTestAPI> test_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(LauncherTest); |
| +}; |
| + |
| // Confirms that LauncherItem reflects the appropriated state. |
| TEST_F(LauncherTest, StatusReflection) { |
| - Launcher* launcher = Launcher::ForPrimaryDisplay(); |
| - ASSERT_TRUE(launcher); |
| - LauncherView* launcher_view = launcher->GetLauncherViewForTest(); |
| - test::LauncherViewTestAPI test(launcher_view); |
| - LauncherModel* model = launcher_view->model(); |
| - |
| - // Initially we have the app list and chrome icon. |
| - int button_count = test.GetButtonCount(); |
| + // Initially we have the app list. |
| + int button_count = test_api()->GetButtonCount(); |
| // Add running platform app. |
| LauncherItem item; |
| item.type = TYPE_PLATFORM_APP; |
| item.status = STATUS_RUNNING; |
| - int index = model->Add(item); |
| - ASSERT_EQ(++button_count, test.GetButtonCount()); |
| - LauncherButton* button = test.GetButton(index); |
| + int index = launcher_model()->Add(item); |
| + ASSERT_EQ(++button_count, test_api()->GetButtonCount()); |
| + LauncherButton* button = test_api()->GetButton(index); |
| EXPECT_EQ(LauncherButton::STATE_RUNNING, button->state()); |
| // Remove it. |
| - model->RemoveItemAt(index); |
| - ASSERT_EQ(--button_count, test.GetButtonCount()); |
| + launcher_model()->RemoveItemAt(index); |
| + ASSERT_EQ(--button_count, test_api()->GetButtonCount()); |
| } |
| // Confirm that using the menu will clear the hover attribute. To avoid another |
| // browser test we check this here. |
| TEST_F(LauncherTest, checkHoverAfterMenu) { |
| - Launcher* launcher = Launcher::ForPrimaryDisplay(); |
| - ASSERT_TRUE(launcher); |
| - LauncherView* launcher_view = launcher->GetLauncherViewForTest(); |
| - test::LauncherViewTestAPI test(launcher_view); |
| - LauncherModel* model = launcher_view->model(); |
| - |
| - // Initially we have the app list and chrome icon. |
| - int button_count = test.GetButtonCount(); |
| + // Initially we have the app list. |
| + int button_count = test_api()->GetButtonCount(); |
| // Add running platform app. |
| LauncherItem item; |
| item.type = TYPE_PLATFORM_APP; |
| item.status = STATUS_RUNNING; |
| - int index = model->Add(item); |
| - ASSERT_EQ(++button_count, test.GetButtonCount()); |
| - LauncherButton* button = test.GetButton(index); |
| + int index = launcher_model()->Add(item); |
| + ASSERT_EQ(++button_count, test_api()->GetButtonCount()); |
| + LauncherButton* button = test_api()->GetButton(index); |
| button->AddState(LauncherButton::STATE_HOVERED); |
| button->ShowContextMenu(gfx::Point(), ui::MENU_SOURCE_MOUSE); |
| EXPECT_FALSE(button->state() & LauncherButton::STATE_HOVERED); |
| // Remove it. |
| - model->RemoveItemAt(index); |
| + launcher_model()->RemoveItemAt(index); |
| } |
| TEST_F(LauncherTest, ShowOverflowBubble) { |
| - Launcher* launcher = Launcher::ForPrimaryDisplay(); |
| - ASSERT_TRUE(launcher); |
| - |
| - LauncherView* launcher_view = launcher->GetLauncherViewForTest(); |
| - test::LauncherViewTestAPI test(launcher_view); |
| - |
| - LauncherModel* model = launcher_view->model(); |
| - LauncherID first_item_id = model->next_id(); |
| + LauncherID first_item_id = launcher_model()->next_id(); |
| // Add platform app button until overflow. |
| int items_added = 0; |
| - while (!test.IsOverflowButtonVisible()) { |
| + while (!test_api()->IsOverflowButtonVisible()) { |
| LauncherItem item; |
| item.type = TYPE_PLATFORM_APP; |
| item.status = STATUS_RUNNING; |
| - model->Add(item); |
| + launcher_model()->Add(item); |
| ++items_added; |
| ASSERT_LT(items_added, 10000); |
| } |
| // Shows overflow bubble. |
| - test.ShowOverflowBubble(); |
| - EXPECT_TRUE(launcher->IsShowingOverflowBubble()); |
| + test_api()->ShowOverflowBubble(); |
| + EXPECT_TRUE(launcher()->IsShowingOverflowBubble()); |
| // Removes the first item in main launcher view. |
| - model->RemoveItemAt(model->ItemIndexByID(first_item_id)); |
| + launcher_model()->RemoveItemAt( |
| + launcher_model()->ItemIndexByID(first_item_id)); |
| // Waits for all transitions to finish and there should be no crash. |
| - test.RunMessageLoopUntilAnimationsDone(); |
| - EXPECT_FALSE(launcher->IsShowingOverflowBubble()); |
| + test_api()->RunMessageLoopUntilAnimationsDone(); |
| + EXPECT_FALSE(launcher()->IsShowingOverflowBubble()); |
| } |
| } // namespace ash |