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

Side by Side Diff: ash/common/system/tray/system_tray_unittest.cc

Issue 2162153002: Added Ash.SystemMenu.DefaultView.VisibleItems histogram. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Removed the COUNT value from the SystemMenuDefaultViewRows enum. Created 4 years, 5 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/tray/system_tray.h" 5 #include "ash/common/system/tray/system_tray.h"
6 6
7 #include <string>
7 #include <vector> 8 #include <vector>
8 9
9 #include "ash/common/accessibility_delegate.h" 10 #include "ash/common/accessibility_delegate.h"
10 #include "ash/common/shelf/wm_shelf.h" 11 #include "ash/common/shelf/wm_shelf.h"
11 #include "ash/common/shell_window_ids.h" 12 #include "ash/common/shell_window_ids.h"
12 #include "ash/common/system/status_area_widget.h" 13 #include "ash/common/system/status_area_widget.h"
13 #include "ash/common/system/tray/system_tray_bubble.h" 14 #include "ash/common/system/tray/system_tray_bubble.h"
14 #include "ash/common/system/tray/system_tray_item.h" 15 #include "ash/common/system/tray/system_tray_item.h"
15 #include "ash/common/system/tray/tray_constants.h" 16 #include "ash/common/system/tray/tray_constants.h"
16 #include "ash/common/system/tray/tray_popup_item_container.h" 17 #include "ash/common/system/tray/tray_popup_item_container.h"
17 #include "ash/common/system/web_notification/web_notification_tray.h" 18 #include "ash/common/system/web_notification/web_notification_tray.h"
18 #include "ash/common/wm_root_window_controller.h" 19 #include "ash/common/wm_root_window_controller.h"
19 #include "ash/common/wm_shell.h" 20 #include "ash/common/wm_shell.h"
20 #include "ash/common/wm_window.h" 21 #include "ash/common/wm_window.h"
21 #include "ash/test/ash_test_base.h" 22 #include "ash/test/ash_test_base.h"
22 #include "ash/test/status_area_widget_test_helper.h" 23 #include "ash/test/status_area_widget_test_helper.h"
24 #include "ash/test/test_system_tray_item.h"
23 #include "base/run_loop.h" 25 #include "base/run_loop.h"
24 #include "base/strings/utf_string_conversions.h" 26 #include "base/test/histogram_tester.h"
25 #include "ui/base/ui_base_types.h" 27 #include "ui/base/ui_base_types.h"
26 #include "ui/compositor/scoped_animation_duration_scale_mode.h" 28 #include "ui/compositor/scoped_animation_duration_scale_mode.h"
27 #include "ui/events/test/event_generator.h" 29 #include "ui/events/test/event_generator.h"
28 #include "ui/gfx/geometry/point.h" 30 #include "ui/gfx/geometry/point.h"
29 #include "ui/gfx/geometry/rect.h" 31 #include "ui/gfx/geometry/rect.h"
30 #include "ui/views/controls/label.h"
31 #include "ui/views/layout/fill_layout.h"
32 #include "ui/views/view.h" 32 #include "ui/views/view.h"
33 #include "ui/views/widget/widget.h" 33 #include "ui/views/widget/widget.h"
34 #include "ui/views/widget/widget_delegate.h" 34 #include "ui/views/widget/widget_delegate.h"
35 35
36 #if defined(OS_WIN) 36 #if defined(OS_WIN)
37 #include "base/win/windows_version.h" 37 #include "base/win/windows_version.h"
38 #endif 38 #endif
39 39
40 namespace ash { 40 namespace ash {
41 namespace test { 41 namespace test {
42 42
43 namespace { 43 namespace {
44 44
45 // Trivial item implementation that tracks its views for testing. 45 const char kVisibleRowsHistogramName[] =
46 class TestItem : public SystemTrayItem { 46 "Ash.SystemMenu.DefaultView.VisibleRows";
47 public:
48 TestItem()
49 : SystemTrayItem(AshTestBase::GetPrimarySystemTray()),
50 tray_view_(nullptr),
51 default_view_(nullptr),
52 detailed_view_(nullptr),
53 notification_view_(nullptr) {}
54
55 views::View* CreateTrayView(LoginStatus status) override {
56 tray_view_ = new views::View;
57 // Add a label so it has non-zero width.
58 tray_view_->SetLayoutManager(new views::FillLayout);
59 tray_view_->AddChildView(new views::Label(base::UTF8ToUTF16("Tray")));
60 return tray_view_;
61 }
62
63 views::View* CreateDefaultView(LoginStatus status) override {
64 default_view_ = new views::View;
65 default_view_->SetLayoutManager(new views::FillLayout);
66 default_view_->AddChildView(new views::Label(base::UTF8ToUTF16("Default")));
67 return default_view_;
68 }
69
70 views::View* CreateDetailedView(LoginStatus status) override {
71 detailed_view_ = new views::View;
72 detailed_view_->SetLayoutManager(new views::FillLayout);
73 detailed_view_->AddChildView(
74 new views::Label(base::UTF8ToUTF16("Detailed")));
75 return detailed_view_;
76 }
77
78 views::View* CreateNotificationView(LoginStatus status) override {
79 notification_view_ = new views::View;
80 return notification_view_;
81 }
82
83 void DestroyTrayView() override { tray_view_ = NULL; }
84
85 void DestroyDefaultView() override { default_view_ = NULL; }
86
87 void DestroyDetailedView() override { detailed_view_ = NULL; }
88
89 void DestroyNotificationView() override { notification_view_ = NULL; }
90
91 void UpdateAfterLoginStatusChange(LoginStatus status) override {}
92
93 views::View* tray_view() const { return tray_view_; }
94 views::View* default_view() const { return default_view_; }
95 views::View* detailed_view() const { return detailed_view_; }
96 views::View* notification_view() const { return notification_view_; }
97
98 private:
99 views::View* tray_view_;
100 views::View* default_view_;
101 views::View* detailed_view_;
102 views::View* notification_view_;
103 };
104
105 // Trivial item implementation that returns NULL from tray/default/detailed
106 // view creation methods.
107 class TestNoViewItem : public SystemTrayItem {
108 public:
109 TestNoViewItem() : SystemTrayItem(AshTestBase::GetPrimarySystemTray()) {}
110
111 views::View* CreateTrayView(LoginStatus status) override { return nullptr; }
112
113 views::View* CreateDefaultView(LoginStatus status) override {
114 return nullptr;
115 }
116
117 views::View* CreateDetailedView(LoginStatus status) override {
118 return nullptr;
119 }
120
121 views::View* CreateNotificationView(LoginStatus status) override {
122 return nullptr;
123 }
124
125 void DestroyTrayView() override {}
126 void DestroyDefaultView() override {}
127 void DestroyDetailedView() override {}
128 void DestroyNotificationView() override {}
129 void UpdateAfterLoginStatusChange(LoginStatus status) override {}
130 };
131 47
132 class ModalWidgetDelegate : public views::WidgetDelegateView { 48 class ModalWidgetDelegate : public views::WidgetDelegateView {
133 public: 49 public:
134 ModalWidgetDelegate() {} 50 ModalWidgetDelegate() {}
135 ~ModalWidgetDelegate() override {} 51 ~ModalWidgetDelegate() override {}
136 52
137 views::View* GetContentsView() override { return this; } 53 views::View* GetContentsView() override { return this; }
138 ui::ModalType GetModalType() const override { return ui::MODAL_TYPE_SYSTEM; } 54 ui::ModalType GetModalType() const override { return ui::MODAL_TYPE_SYSTEM; }
139 55
140 private: 56 private:
141 DISALLOW_COPY_AND_ASSIGN(ModalWidgetDelegate); 57 DISALLOW_COPY_AND_ASSIGN(ModalWidgetDelegate);
142 }; 58 };
143 59
144 } // namespace 60 } // namespace
145 61
146 typedef AshTestBase SystemTrayTest; 62 typedef AshTestBase SystemTrayTest;
147 63
64 // Verifies only the visible default views are recorded in the
65 // "Ash.SystemMenu.DefaultView.VisibleItems" histogram.
66 TEST_F(SystemTrayTest, OnlyVisibleItemsRecorded) {
67 SystemTray* tray = GetPrimarySystemTray();
68 ASSERT_TRUE(tray->GetWidget());
69
70 TestSystemTrayItem* test_item = new TestSystemTrayItem();
71 tray->AddTrayItem(test_item);
72
73 base::HistogramTester histogram_tester;
74
75 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
76 RunAllPendingInMessageLoop();
77 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
78 SystemTrayItem::UMA_TEST, 1);
79
80 ASSERT_TRUE(tray->CloseSystemBubble());
81 RunAllPendingInMessageLoop();
82
83 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
84 RunAllPendingInMessageLoop();
85 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
86 SystemTrayItem::UMA_TEST, 2);
87
88 ASSERT_TRUE(tray->CloseSystemBubble());
89 RunAllPendingInMessageLoop();
90
91 test_item->set_views_are_visible(false);
92
93 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
94 RunAllPendingInMessageLoop();
95 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
96 SystemTrayItem::UMA_TEST, 2);
97
98 ASSERT_TRUE(tray->CloseSystemBubble());
99 RunAllPendingInMessageLoop();
100 }
101
102 // Verifies a visible UMA_NOT_RECORDED default view is not recorded in the
103 // "Ash.SystemMenu.DefaultView.VisibleItems" histogram.
104 TEST_F(SystemTrayTest, NotRecordedtemsAreNotRecorded) {
105 SystemTray* tray = GetPrimarySystemTray();
106 ASSERT_TRUE(tray->GetWidget());
107
108 TestSystemTrayItem* test_item =
109 new TestSystemTrayItem(SystemTrayItem::UMA_NOT_RECORDED);
110 tray->AddTrayItem(test_item);
111
112 base::HistogramTester histogram_tester;
113
114 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
115 RunAllPendingInMessageLoop();
116 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
117 SystemTrayItem::UMA_NOT_RECORDED, 0);
118
119 ASSERT_TRUE(tray->CloseSystemBubble());
120 RunAllPendingInMessageLoop();
121 }
122
123 // Verifies null default views are not recorded in the
124 // "Ash.SystemMenu.DefaultView.VisibleItems" histogram.
125 TEST_F(SystemTrayTest, NullDefaultViewIsNotRecorded) {
126 SystemTray* tray = GetPrimarySystemTray();
127 ASSERT_TRUE(tray->GetWidget());
128
129 TestSystemTrayItem* test_item = new TestSystemTrayItem();
130 test_item->set_has_views(false);
131 tray->AddTrayItem(test_item);
132
133 base::HistogramTester histogram_tester;
134
135 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
136 RunAllPendingInMessageLoop();
137 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
138 SystemTrayItem::UMA_TEST, 0);
139
140 ASSERT_TRUE(tray->CloseSystemBubble());
141 RunAllPendingInMessageLoop();
142 }
143
144 // Verifies visible detailed views are not recorded in the
145 // "Ash.SystemMenu.DefaultView.VisibleItems" histogram.
146 TEST_F(SystemTrayTest, VisibleDetailedViewsIsNotRecorded) {
147 SystemTray* tray = GetPrimarySystemTray();
148 ASSERT_TRUE(tray->GetWidget());
149
150 TestSystemTrayItem* test_item = new TestSystemTrayItem();
151 tray->AddTrayItem(test_item);
152
153 base::HistogramTester histogram_tester;
154
155 tray->ShowDetailedView(test_item, 0, false, BUBBLE_CREATE_NEW);
156 RunAllPendingInMessageLoop();
157
158 histogram_tester.ExpectTotalCount(kVisibleRowsHistogramName, 0);
159
160 ASSERT_TRUE(tray->CloseSystemBubble());
161 RunAllPendingInMessageLoop();
162 }
163
164 // Verifies visible default views are not recorded for menu re-shows in the
165 // "Ash.SystemMenu.DefaultView.VisibleItems" histogram.
166 TEST_F(SystemTrayTest, VisibleDefaultViewIsNotRecordedOnReshow) {
167 SystemTray* tray = GetPrimarySystemTray();
168 ASSERT_TRUE(tray->GetWidget());
169
170 TestSystemTrayItem* test_item = new TestSystemTrayItem();
171 tray->AddTrayItem(test_item);
172
173 base::HistogramTester histogram_tester;
174
175 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
176 RunAllPendingInMessageLoop();
177 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
178 SystemTrayItem::UMA_TEST, 1);
179
180 tray->ShowDetailedView(test_item, 0, false, BUBBLE_USE_EXISTING);
181 RunAllPendingInMessageLoop();
182 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
183 SystemTrayItem::UMA_TEST, 1);
184
185 tray->ShowDefaultView(BUBBLE_USE_EXISTING);
186 RunAllPendingInMessageLoop();
187 histogram_tester.ExpectBucketCount(kVisibleRowsHistogramName,
188 SystemTrayItem::UMA_TEST, 1);
189
190 ASSERT_TRUE(tray->CloseSystemBubble());
191 RunAllPendingInMessageLoop();
192 }
193
148 TEST_F(SystemTrayTest, SystemTrayDefaultView) { 194 TEST_F(SystemTrayTest, SystemTrayDefaultView) {
149 SystemTray* tray = GetPrimarySystemTray(); 195 SystemTray* tray = GetPrimarySystemTray();
150 ASSERT_TRUE(tray->GetWidget()); 196 ASSERT_TRUE(tray->GetWidget());
151 197
152 tray->ShowDefaultView(BUBBLE_CREATE_NEW); 198 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
153 199
154 // Ensure that closing the bubble destroys it. 200 // Ensure that closing the bubble destroys it.
155 ASSERT_TRUE(tray->CloseSystemBubble()); 201 ASSERT_TRUE(tray->CloseSystemBubble());
156 RunAllPendingInMessageLoop(); 202 RunAllPendingInMessageLoop();
157 ASSERT_FALSE(tray->CloseSystemBubble()); 203 ASSERT_FALSE(tray->CloseSystemBubble());
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
194 ASSERT_FALSE(tray->draw_background_as_active()); 240 ASSERT_FALSE(tray->draw_background_as_active());
195 RunAllPendingInMessageLoop(); 241 RunAllPendingInMessageLoop();
196 // The bubble should already be closed by now. 242 // The bubble should already be closed by now.
197 ASSERT_FALSE(tray->CloseSystemBubble()); 243 ASSERT_FALSE(tray->CloseSystemBubble());
198 } 244 }
199 245
200 TEST_F(SystemTrayTest, SystemTrayTestItems) { 246 TEST_F(SystemTrayTest, SystemTrayTestItems) {
201 SystemTray* tray = GetPrimarySystemTray(); 247 SystemTray* tray = GetPrimarySystemTray();
202 ASSERT_TRUE(tray->GetWidget()); 248 ASSERT_TRUE(tray->GetWidget());
203 249
204 TestItem* test_item = new TestItem; 250 TestSystemTrayItem* test_item = new TestSystemTrayItem();
205 TestItem* detailed_item = new TestItem; 251 TestSystemTrayItem* detailed_item = new TestSystemTrayItem();
206 tray->AddTrayItem(test_item); 252 tray->AddTrayItem(test_item);
207 tray->AddTrayItem(detailed_item); 253 tray->AddTrayItem(detailed_item);
208 254
209 // Check items have been added 255 // Check items have been added
210 const std::vector<SystemTrayItem*>& items = tray->GetTrayItems(); 256 const std::vector<SystemTrayItem*>& items = tray->GetTrayItems();
211 ASSERT_TRUE(std::find(items.begin(), items.end(), test_item) != items.end()); 257 ASSERT_TRUE(std::find(items.begin(), items.end(), test_item) != items.end());
212 ASSERT_TRUE(std::find(items.begin(), items.end(), detailed_item) != 258 ASSERT_TRUE(std::find(items.begin(), items.end(), detailed_item) !=
213 items.end()); 259 items.end());
214 260
215 // Ensure the tray views are created. 261 // Ensure the tray views are created.
(...skipping 16 matching lines...) Expand all
232 RunAllPendingInMessageLoop(); 278 RunAllPendingInMessageLoop();
233 ASSERT_TRUE(test_item->default_view() != NULL); 279 ASSERT_TRUE(test_item->default_view() != NULL);
234 ASSERT_TRUE(detailed_item->detailed_view() == NULL); 280 ASSERT_TRUE(detailed_item->detailed_view() == NULL);
235 } 281 }
236 282
237 TEST_F(SystemTrayTest, SystemTrayNoViewItems) { 283 TEST_F(SystemTrayTest, SystemTrayNoViewItems) {
238 SystemTray* tray = GetPrimarySystemTray(); 284 SystemTray* tray = GetPrimarySystemTray();
239 ASSERT_TRUE(tray->GetWidget()); 285 ASSERT_TRUE(tray->GetWidget());
240 286
241 // Verify that no crashes occur on items lacking some views. 287 // Verify that no crashes occur on items lacking some views.
242 TestNoViewItem* no_view_item = new TestNoViewItem; 288 TestSystemTrayItem* no_view_item = new TestSystemTrayItem();
289 no_view_item->set_has_views(false);
243 tray->AddTrayItem(no_view_item); 290 tray->AddTrayItem(no_view_item);
244 tray->ShowDefaultView(BUBBLE_CREATE_NEW); 291 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
245 tray->ShowDetailedView(no_view_item, 0, false, BUBBLE_USE_EXISTING); 292 tray->ShowDetailedView(no_view_item, 0, false, BUBBLE_USE_EXISTING);
246 RunAllPendingInMessageLoop(); 293 RunAllPendingInMessageLoop();
247 } 294 }
248 295
249 TEST_F(SystemTrayTest, TrayWidgetAutoResizes) { 296 TEST_F(SystemTrayTest, TrayWidgetAutoResizes) {
250 SystemTray* tray = GetPrimarySystemTray(); 297 SystemTray* tray = GetPrimarySystemTray();
251 ASSERT_TRUE(tray->GetWidget()); 298 ASSERT_TRUE(tray->GetWidget());
252 299
253 // Add an initial tray item so that the tray gets laid out correctly. 300 // Add an initial tray item so that the tray gets laid out correctly.
254 TestItem* initial_item = new TestItem; 301 TestSystemTrayItem* initial_item = new TestSystemTrayItem();
255 tray->AddTrayItem(initial_item); 302 tray->AddTrayItem(initial_item);
256 303
257 gfx::Size initial_size = tray->GetWidget()->GetWindowBoundsInScreen().size(); 304 gfx::Size initial_size = tray->GetWidget()->GetWindowBoundsInScreen().size();
258 305
259 TestItem* new_item = new TestItem; 306 TestSystemTrayItem* new_item = new TestSystemTrayItem();
260 tray->AddTrayItem(new_item); 307 tray->AddTrayItem(new_item);
261 308
262 gfx::Size new_size = tray->GetWidget()->GetWindowBoundsInScreen().size(); 309 gfx::Size new_size = tray->GetWidget()->GetWindowBoundsInScreen().size();
263 310
264 // Adding the new item should change the size of the tray. 311 // Adding the new item should change the size of the tray.
265 EXPECT_NE(initial_size.ToString(), new_size.ToString()); 312 EXPECT_NE(initial_size.ToString(), new_size.ToString());
266 313
267 // Hiding the tray view of the new item should also change the size of the 314 // Hiding the tray view of the new item should also change the size of the
268 // tray. 315 // tray.
269 new_item->tray_view()->SetVisible(false); 316 new_item->tray_view()->SetVisible(false);
270 EXPECT_EQ(initial_size.ToString(), 317 EXPECT_EQ(initial_size.ToString(),
271 tray->GetWidget()->GetWindowBoundsInScreen().size().ToString()); 318 tray->GetWidget()->GetWindowBoundsInScreen().size().ToString());
272 319
273 new_item->tray_view()->SetVisible(true); 320 new_item->tray_view()->SetVisible(true);
274 EXPECT_EQ(new_size.ToString(), 321 EXPECT_EQ(new_size.ToString(),
275 tray->GetWidget()->GetWindowBoundsInScreen().size().ToString()); 322 tray->GetWidget()->GetWindowBoundsInScreen().size().ToString());
276 } 323 }
277 324
278 TEST_F(SystemTrayTest, SystemTrayNotifications) { 325 TEST_F(SystemTrayTest, SystemTrayNotifications) {
279 SystemTray* tray = GetPrimarySystemTray(); 326 SystemTray* tray = GetPrimarySystemTray();
280 ASSERT_TRUE(tray->GetWidget()); 327 ASSERT_TRUE(tray->GetWidget());
281 328
282 TestItem* test_item = new TestItem; 329 TestSystemTrayItem* test_item = new TestSystemTrayItem();
283 TestItem* detailed_item = new TestItem; 330 TestSystemTrayItem* detailed_item = new TestSystemTrayItem();
284 tray->AddTrayItem(test_item); 331 tray->AddTrayItem(test_item);
285 tray->AddTrayItem(detailed_item); 332 tray->AddTrayItem(detailed_item);
286 333
287 // Ensure the tray views are created. 334 // Ensure the tray views are created.
288 ASSERT_TRUE(test_item->tray_view() != NULL); 335 ASSERT_TRUE(test_item->tray_view() != NULL);
289 ASSERT_TRUE(detailed_item->tray_view() != NULL); 336 ASSERT_TRUE(detailed_item->tray_view() != NULL);
290 337
291 // Ensure a notification view is created. 338 // Ensure a notification view is created.
292 tray->ShowNotificationView(test_item); 339 tray->ShowNotificationView(test_item);
293 ASSERT_TRUE(test_item->notification_view() != NULL); 340 ASSERT_TRUE(test_item->notification_view() != NULL);
(...skipping 13 matching lines...) Expand all
307 ASSERT_TRUE(tray->CloseSystemBubble()); 354 ASSERT_TRUE(tray->CloseSystemBubble());
308 RunAllPendingInMessageLoop(); 355 RunAllPendingInMessageLoop();
309 ASSERT_TRUE(detailed_item->detailed_view() == NULL); 356 ASSERT_TRUE(detailed_item->detailed_view() == NULL);
310 ASSERT_TRUE(test_item->notification_view() != NULL); 357 ASSERT_TRUE(test_item->notification_view() != NULL);
311 } 358 }
312 359
313 TEST_F(SystemTrayTest, BubbleCreationTypesTest) { 360 TEST_F(SystemTrayTest, BubbleCreationTypesTest) {
314 SystemTray* tray = GetPrimarySystemTray(); 361 SystemTray* tray = GetPrimarySystemTray();
315 ASSERT_TRUE(tray->GetWidget()); 362 ASSERT_TRUE(tray->GetWidget());
316 363
317 TestItem* test_item = new TestItem; 364 TestSystemTrayItem* test_item = new TestSystemTrayItem();
318 tray->AddTrayItem(test_item); 365 tray->AddTrayItem(test_item);
319 366
320 // Ensure the tray views are created. 367 // Ensure the tray views are created.
321 ASSERT_TRUE(test_item->tray_view() != NULL); 368 ASSERT_TRUE(test_item->tray_view() != NULL);
322 369
323 // Show the default view, ensure the notification view is destroyed. 370 // Show the default view, ensure the notification view is destroyed.
324 tray->ShowDefaultView(BUBBLE_CREATE_NEW); 371 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
325 RunAllPendingInMessageLoop(); 372 RunAllPendingInMessageLoop();
326 373
327 views::Widget* widget = test_item->default_view()->GetWidget(); 374 views::Widget* widget = test_item->default_view()->GetWidget();
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
377 shelf->SetAlignment(SHELF_ALIGNMENT_LEFT); 424 shelf->SetAlignment(SHELF_ALIGNMENT_LEFT);
378 window_bounds = widget->GetWindowBoundsInScreen(); 425 window_bounds = widget->GetWindowBoundsInScreen();
379 tray_bounds = tray->GetBoundsInScreen(); 426 tray_bounds = tray->GetBoundsInScreen();
380 EXPECT_TRUE(window_bounds.Contains(tray_bounds)); 427 EXPECT_TRUE(window_bounds.Contains(tray_bounds));
381 } 428 }
382 429
383 TEST_F(SystemTrayTest, PersistentBubble) { 430 TEST_F(SystemTrayTest, PersistentBubble) {
384 SystemTray* tray = GetPrimarySystemTray(); 431 SystemTray* tray = GetPrimarySystemTray();
385 ASSERT_TRUE(tray->GetWidget()); 432 ASSERT_TRUE(tray->GetWidget());
386 433
387 TestItem* test_item = new TestItem; 434 TestSystemTrayItem* test_item = new TestSystemTrayItem();
388 tray->AddTrayItem(test_item); 435 tray->AddTrayItem(test_item);
389 436
390 std::unique_ptr<views::Widget> widget(CreateTestWidget( 437 std::unique_ptr<views::Widget> widget(CreateTestWidget(
391 nullptr, kShellWindowId_DefaultContainer, gfx::Rect(0, 0, 100, 100))); 438 nullptr, kShellWindowId_DefaultContainer, gfx::Rect(0, 0, 100, 100)));
392 439
393 // Tests for usual default view while activating a window. 440 // Tests for usual default view while activating a window.
394 tray->ShowDefaultView(BUBBLE_CREATE_NEW); 441 tray->ShowDefaultView(BUBBLE_CREATE_NEW);
395 ASSERT_TRUE(tray->HasSystemBubble()); 442 ASSERT_TRUE(tray->HasSystemBubble());
396 widget->Activate(); 443 widget->Activate();
397 base::RunLoop().RunUntilIdle(); 444 base::RunLoop().RunUntilIdle();
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after
546 // Hide the default view, ensure the tray bubble height is back to zero. 593 // Hide the default view, ensure the tray bubble height is back to zero.
547 ASSERT_TRUE(tray->CloseSystemBubble()); 594 ASSERT_TRUE(tray->CloseSystemBubble());
548 RunAllPendingInMessageLoop(); 595 RunAllPendingInMessageLoop();
549 596
550 EXPECT_EQ(0, notification_tray->tray_bubble_height_for_test()); 597 EXPECT_EQ(0, notification_tray->tray_bubble_height_for_test());
551 } 598 }
552 #endif // OS_CHROMEOS 599 #endif // OS_CHROMEOS
553 600
554 } // namespace test 601 } // namespace test
555 } // namespace ash 602 } // namespace ash
OLDNEW
« no previous file with comments | « ash/common/system/tray/system_tray_item.cc ('k') | ash/common/system/tray/tray_details_view_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698