Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1908)

Unified Diff: athena/wm/split_view_controller_unittest.cc

Issue 550043002: Keep the split view activities topmost in z-order in Athena (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « athena/wm/split_view_controller.cc ('k') | athena/wm/window_manager_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: athena/wm/split_view_controller_unittest.cc
diff --git a/athena/wm/split_view_controller_unittest.cc b/athena/wm/split_view_controller_unittest.cc
index 6bde13b5f66817c2df9e98a98cda9e3c5507bfda..06cde2096dd7e19be9ccae2bd1caaadaf0d2876d 100644
--- a/athena/wm/split_view_controller_unittest.cc
+++ b/athena/wm/split_view_controller_unittest.cc
@@ -32,6 +32,20 @@ class SplitViewControllerTest : public test::AthenaTestBase {
test::AthenaTestBase::TearDown();
}
+ // Returns whether the split view windows are topmost.
+ bool SplitViewWindowsTopmost() const {
oshima 2014/09/12 20:19:49 AreSplitViewWindowsTopmost()
+ SplitViewController* controller = api_->GetSplitViewController();
+ DCHECK(controller->IsSplitViewModeActive());
+ aura::Window::Windows list =
+ api_->GetWindowListProvider()->GetWindowList();
+ aura::Window* topmost = *list.rbegin();
+ aura::Window* second_topmost = *(list.rbegin() + 1);
+ return (topmost == controller->left_window() ||
+ topmost == controller->right_window()) &&
+ (second_topmost == controller->left_window() ||
+ second_topmost == controller->right_window());
+ }
+
bool IsSplitViewAllowed() const {
return api_->GetSplitViewController()->CanScroll();
}
@@ -58,7 +72,6 @@ TEST_F(SplitViewControllerTest, SplitModeActivation) {
}
SplitViewController* controller = api()->GetSplitViewController();
- WindowListProvider* list_provider = api()->GetWindowListProvider();
ASSERT_FALSE(controller->IsSplitViewModeActive());
controller->ActivateSplitMode(NULL, NULL);
@@ -66,34 +79,41 @@ TEST_F(SplitViewControllerTest, SplitModeActivation) {
// The last two windows should be on the left and right, respectively.
EXPECT_EQ(windows[kNumWindows - 1], controller->left_window());
EXPECT_EQ(windows[kNumWindows - 2], controller->right_window());
+ EXPECT_TRUE(SplitViewWindowsTopmost());
// Select the window that is currently on the left for the right panel. The
// windows should switch.
controller->ActivateSplitMode(NULL, windows[kNumWindows - 1]);
EXPECT_EQ(windows[kNumWindows - 2], controller->left_window());
EXPECT_EQ(windows[kNumWindows - 1], controller->right_window());
+ EXPECT_TRUE(SplitViewWindowsTopmost());
controller->ActivateSplitMode(windows[kNumWindows - 1], NULL);
EXPECT_EQ(windows[kNumWindows - 1], controller->left_window());
EXPECT_EQ(windows[kNumWindows - 2], controller->right_window());
+ EXPECT_TRUE(SplitViewWindowsTopmost());
// Select one of the windows behind the stacks for the right panel. The window
// on the left should remain unchanged.
controller->ActivateSplitMode(NULL, windows[0]);
EXPECT_EQ(windows[kNumWindows - 1], controller->left_window());
EXPECT_EQ(windows[0], controller->right_window());
- EXPECT_EQ(windows[0], *list_provider->GetWindowList().rbegin());
+ EXPECT_TRUE(SplitViewWindowsTopmost());
controller->ActivateSplitMode(windows[1], NULL);
EXPECT_EQ(windows[1], controller->left_window());
EXPECT_EQ(windows[0], controller->right_window());
- EXPECT_EQ(windows[1], *list_provider->GetWindowList().rbegin());
+ EXPECT_TRUE(SplitViewWindowsTopmost());
controller->ActivateSplitMode(windows[4], windows[5]);
EXPECT_EQ(windows[4], controller->left_window());
EXPECT_EQ(windows[5], controller->right_window());
- EXPECT_EQ(windows[4], *list_provider->GetWindowList().rbegin());
- EXPECT_EQ(windows[5], *(list_provider->GetWindowList().rbegin() + 1));
+ EXPECT_TRUE(SplitViewWindowsTopmost());
+
+ controller->ActivateSplitMode(windows[0], NULL);
+ EXPECT_EQ(windows[0], controller->left_window());
+ EXPECT_EQ(windows[5], controller->right_window());
+ EXPECT_TRUE(SplitViewWindowsTopmost());
}
TEST_F(SplitViewControllerTest, LandscapeOnly) {
« no previous file with comments | « athena/wm/split_view_controller.cc ('k') | athena/wm/window_manager_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698