OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ash/common/system/chromeos/screen_security/screen_tray_item.h" | 5 #include "ash/common/system/chromeos/screen_security/screen_tray_item.h" |
6 #include "ash/common/system/tray/system_tray.h" | 6 #include "ash/common/system/tray/system_tray.h" |
7 #include "ash/common/wm/overview/window_selector_controller.h" | 7 #include "ash/common/wm/overview/window_selector_controller.h" |
8 #include "ash/common/wm_shell.h" | 8 #include "ash/common/wm_shell.h" |
9 #include "ash/test/ash_test_base.h" | 9 #include "ash/test/ash_test_base.h" |
| 10 #include "base/run_loop.h" |
| 11 #include "base/threading/thread_task_runner_handle.h" |
10 #include "chrome/browser/ui/ash/multi_user/user_switch_util.h" | 12 #include "chrome/browser/ui/ash/multi_user/user_switch_util.h" |
| 13 #include "chrome/browser/ui/simple_message_box.h" |
11 #include "ui/aura/window.h" | 14 #include "ui/aura/window.h" |
12 | 15 |
13 namespace ash { | 16 namespace ash { |
14 | 17 |
15 class TrySwitchingUserTest : public ash::test::AshTestBase { | 18 class TrySwitchingUserTest : public ash::test::AshTestBase { |
16 public: | 19 public: |
17 // The action type to perform / check for upon user switching. | 20 // The action type to perform / check for upon user switching. |
18 enum ActionType { | 21 enum ActionType { |
19 NO_DIALOG, // No dialog should be shown. | 22 NO_DIALOG, // No dialog should be shown. |
20 ACCEPT_DIALOG, // A dialog should be shown and we should accept it. | 23 ACCEPT_DIALOG, // A dialog should be shown and we should accept it. |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
61 // Simulates a screen share session stop. | 64 // Simulates a screen share session stop. |
62 void StopShareSession() { share_item_->Stop(); } | 65 void StopShareSession() { share_item_->Stop(); } |
63 | 66 |
64 // The callback which gets called when the screen share gets stopped. | 67 // The callback which gets called when the screen share gets stopped. |
65 void StopShareCallback() { stop_share_callback_hit_count_++; } | 68 void StopShareCallback() { stop_share_callback_hit_count_++; } |
66 | 69 |
67 // Issuing a switch user call which might or might not create a dialog. | 70 // Issuing a switch user call which might or might not create a dialog. |
68 // The passed |action| type parameter defines the outcome (which will be | 71 // The passed |action| type parameter defines the outcome (which will be |
69 // checked) and the action the user will choose. | 72 // checked) and the action the user will choose. |
70 void SwitchUser(ActionType action) { | 73 void SwitchUser(ActionType action) { |
| 74 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 75 FROM_HERE, base::Bind(&CloseMessageBox, action)); |
71 TrySwitchingActiveUser(base::Bind(&TrySwitchingUserTest::SwitchCallback, | 76 TrySwitchingActiveUser(base::Bind(&TrySwitchingUserTest::SwitchCallback, |
72 base::Unretained(this))); | 77 base::Unretained(this))); |
73 switch (action) { | 78 base::RunLoop().RunUntilIdle(); |
74 case NO_DIALOG: | |
75 EXPECT_TRUE(!TestAndTerminateDesktopCastingWarningForTest(true)); | |
76 return; | |
77 case ACCEPT_DIALOG: | |
78 EXPECT_TRUE(TestAndTerminateDesktopCastingWarningForTest(true)); | |
79 return; | |
80 case DECLINE_DIALOG: | |
81 EXPECT_TRUE(TestAndTerminateDesktopCastingWarningForTest(false)); | |
82 return; | |
83 } | |
84 } | 79 } |
85 | 80 |
86 // Called when the user will get actually switched. | 81 // Called when the user will get actually switched. |
87 void SwitchCallback() { switch_callback_hit_count_++; } | 82 void SwitchCallback() { switch_callback_hit_count_++; } |
88 | 83 |
89 // Methods needed to test with overview mode. | 84 // Methods needed to test with overview mode. |
90 const WindowSelectorController* window_selector_controller() const { | 85 const WindowSelectorController* window_selector_controller() const { |
91 return WmShell::Get()->window_selector_controller(); | 86 return WmShell::Get()->window_selector_controller(); |
92 } | 87 } |
93 WindowSelectorController* window_selector_controller() { | 88 WindowSelectorController* window_selector_controller() { |
94 return const_cast<WindowSelectorController*>( | 89 return const_cast<WindowSelectorController*>( |
95 const_cast<const TrySwitchingUserTest*>(this) | 90 const_cast<const TrySwitchingUserTest*>(this) |
96 ->window_selector_controller()); | 91 ->window_selector_controller()); |
97 } | 92 } |
98 void ToggleOverview() { window_selector_controller()->ToggleOverview(); } | 93 void ToggleOverview() { window_selector_controller()->ToggleOverview(); } |
99 bool IsSelecting() const { | 94 bool IsSelecting() const { |
100 return window_selector_controller()->IsSelecting(); | 95 return window_selector_controller()->IsSelecting(); |
101 } | 96 } |
102 | 97 |
103 // Various counter accessors. | 98 // Various counter accessors. |
104 int stop_capture_callback_hit_count() const { | 99 int stop_capture_callback_hit_count() const { |
105 return stop_capture_callback_hit_count_; | 100 return stop_capture_callback_hit_count_; |
106 } | 101 } |
107 int stop_share_callback_hit_count() const { | 102 int stop_share_callback_hit_count() const { |
108 return stop_share_callback_hit_count_; | 103 return stop_share_callback_hit_count_; |
109 } | 104 } |
110 int switch_callback_hit_count() const { return switch_callback_hit_count_; } | 105 int switch_callback_hit_count() const { return switch_callback_hit_count_; } |
111 | 106 |
112 private: | 107 private: |
| 108 static void CloseMessageBox(ActionType action) { |
| 109 switch (action) { |
| 110 case NO_DIALOG: |
| 111 EXPECT_FALSE(chrome::CloseMessageBoxForTest(true)); |
| 112 return; |
| 113 case ACCEPT_DIALOG: |
| 114 EXPECT_TRUE(chrome::CloseMessageBoxForTest(true)); |
| 115 return; |
| 116 case DECLINE_DIALOG: |
| 117 EXPECT_TRUE(chrome::CloseMessageBoxForTest(false)); |
| 118 return; |
| 119 } |
| 120 } |
| 121 |
113 // The two items from the SystemTray for the screen capture / share | 122 // The two items from the SystemTray for the screen capture / share |
114 // functionality. | 123 // functionality. |
115 ScreenTrayItem* capture_item_; | 124 ScreenTrayItem* capture_item_; |
116 ScreenTrayItem* share_item_; | 125 ScreenTrayItem* share_item_; |
117 | 126 |
118 // Various counters to query for. | 127 // Various counters to query for. |
119 int stop_capture_callback_hit_count_; | 128 int stop_capture_callback_hit_count_; |
120 int stop_share_callback_hit_count_; | 129 int stop_share_callback_hit_count_; |
121 int switch_callback_hit_count_; | 130 int switch_callback_hit_count_; |
122 | 131 |
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
234 gfx::Rect bounds(0, 0, 100, 100); | 243 gfx::Rect bounds(0, 0, 100, 100); |
235 std::unique_ptr<aura::Window> w(CreateTestWindowInShellWithBounds(bounds)); | 244 std::unique_ptr<aura::Window> w(CreateTestWindowInShellWithBounds(bounds)); |
236 ToggleOverview(); | 245 ToggleOverview(); |
237 ASSERT_TRUE(IsSelecting()); | 246 ASSERT_TRUE(IsSelecting()); |
238 SwitchUser(TrySwitchingUserTest::NO_DIALOG); | 247 SwitchUser(TrySwitchingUserTest::NO_DIALOG); |
239 ASSERT_FALSE(IsSelecting()); | 248 ASSERT_FALSE(IsSelecting()); |
240 EXPECT_EQ(1, switch_callback_hit_count()); | 249 EXPECT_EQ(1, switch_callback_hit_count()); |
241 } | 250 } |
242 | 251 |
243 } // namespace ash | 252 } // namespace ash |
OLD | NEW |