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

Side by Side Diff: ash/system/chromeos/screen_security/screen_tray_item_unittest.cc

Issue 16472006: Add unit tests for screen capture and share notification UI. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years, 6 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
« no previous file with comments | « ash/system/chromeos/screen_security/screen_tray_item.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "ash/system/chromeos/screen_security/screen_capture_tray_item.h"
6 #include "ash/system/chromeos/screen_security/screen_share_tray_item.h"
7 #include "ash/system/chromeos/screen_security/screen_tray_item.h"
8
James Cook 2013/06/07 14:16:37 Either put the primary test class header include o
Tim Song 2013/06/07 18:14:35 Done.
9 #include "ash/test/ash_test_base.h"
10 #include "base/callback.h"
11 #include "base/strings/utf_string_conversions.h"
12 #include "ui/base/events/event.h"
13 #include "ui/gfx/point.h"
14 #include "ui/views/view.h"
15
16 namespace ash {
17 namespace internal {
18
19 const char kTestScreenCaptureAppName[] = "Ash Test";
20 const char kTestScreenShareHelperName[] = "Ash Test";
James Cook 2013/06/07 14:16:37 nit: Generally we use different strings, integers,
Tim Song 2013/06/07 18:14:35 Done. I just realized that it would be a good idea
21
22 SystemTray* GetSystemTray() {
23 return Shell::GetInstance()->GetPrimarySystemTray();
24 }
25
26 SystemTrayNotifier* GetSystemTrayNotifier() {
27 return Shell::GetInstance()->system_tray_notifier();
28 }
29
30 void ClickViewCenter(views::View* view) {
31 gfx::Point click_location = gfx::Point(view->width()/2, view->height()/2);
James Cook 2013/06/07 14:16:37 Spaces around / Also, click_location should be cl
Tim Song 2013/06/07 18:14:35 Done.
32 view->OnMousePressed(ui::MouseEvent(ui::ET_MOUSE_PRESSED,
33 click_location,
34 click_location,
35 ui::EF_NONE));
36 }
37
38 class ScreenTrayItemTest : public ash::test::AshTestBase {
39 public:
40 explicit ScreenTrayItemTest()
James Cook 2013/06/07 14:16:37 no explicit
Tim Song 2013/06/07 18:14:35 Done. I should really keep an eye out when copy pa
41 : tray_item_(NULL), stop_callback_hit_count_(0) {}
42 virtual ~ScreenTrayItemTest() {}
43
44 ScreenTrayItem* tray_item() { return tray_item_; }
45 uint stop_callback_hit_count() { return stop_callback_hit_count_; }
James Cook 2013/06/07 14:16:37 int would be fine here. Also, const here (but not
Tim Song 2013/06/07 18:14:35 Done.
46
47 void StartSession() {
48 tray_item_->Start(
49 base::Bind(&ScreenTrayItemTest::StopCallback, base::Unretained(this)));
50 }
51
52 void StopSession() {
53 tray_item_->Stop();
54 }
55
56 void StopCallback() {
57 stop_callback_hit_count_++;
58 }
59
60 protected:
61 ScreenTrayItem* tray_item_;
James Cook 2013/06/07 14:16:37 Make this private and use a setter. We generally
Tim Song 2013/06/07 18:14:35 Done. I added the comments about memory management
62 uint stop_callback_hit_count_;
63
64 DISALLOW_COPY_AND_ASSIGN(ScreenTrayItemTest);
65 };
66
67 class ScreenCaptureTest : public ScreenTrayItemTest {
68 public:
69 explicit ScreenCaptureTest() {}
70 virtual ~ScreenCaptureTest() {}
71
72 virtual void SetUp() OVERRIDE {
73 test::AshTestBase::SetUp();
74 tray_item_ = new ScreenCaptureTrayItem(GetSystemTray());
75 }
76
77 DISALLOW_COPY_AND_ASSIGN(ScreenCaptureTest);
78 };
79
80 class ScreenShareTest : public ScreenTrayItemTest {
81 public:
82 explicit ScreenShareTest() {}
83 virtual ~ScreenShareTest() {}
84
85 virtual void SetUp() OVERRIDE {
86 test::AshTestBase::SetUp();
87 tray_item_ = new ScreenShareTrayItem(GetSystemTray());
88 }
89
90 DISALLOW_COPY_AND_ASSIGN(ScreenShareTest);
91 };
92
93
James Cook 2013/06/07 14:16:37 nit: one blank line
Tim Song 2013/06/07 18:14:35 Done.
94 void TestStartAndStop(ScreenTrayItemTest* test) {
95 ScreenTrayItem* tray_item = test->tray_item();
96
97 EXPECT_FALSE(tray_item->is_started());
98 EXPECT_EQ(test->stop_callback_hit_count(), 0u);
James Cook 2013/06/07 14:16:37 expected value goes first: EXPECT_EQ(0, stop_call
Tim Song 2013/06/07 18:14:35 Done.
99
100 test->StartSession();
101 EXPECT_TRUE(tray_item->is_started());
102
103 test->StopSession();
104 EXPECT_FALSE(tray_item->is_started());
105 EXPECT_EQ(test->stop_callback_hit_count(), 1u);
106 }
107
108 TEST_F(ScreenCaptureTest, StartAndStop) { TestStartAndStop(this); }
109 TEST_F(ScreenShareTest, StartAndStop) { TestStartAndStop(this); }
110
111 void TestNotificationStartAndStop(ScreenTrayItemTest* test,
James Cook 2013/06/07 14:16:37 Good: nice descriptive function name
Tim Song 2013/06/07 18:14:35 Thanks!
112 const base::Closure& start_func,
James Cook 2013/06/07 14:16:37 no abbrevations: start_function, stop_function
Tim Song 2013/06/07 18:14:35 Done.
113 const base::Closure& stop_func) {
114 ScreenTrayItem* tray_item = test->tray_item();
115 EXPECT_FALSE(tray_item->is_started());
116
117 start_func.Run();
118 EXPECT_TRUE(tray_item->is_started());
119
120 // The stop callback shouldn't be called because we stopped
121 // through the notification system.
122 stop_func.Run();
123 EXPECT_FALSE(tray_item->is_started());
124 EXPECT_EQ(test->stop_callback_hit_count(), 0u);
125 }
126
127 TEST_F(ScreenCaptureTest, NotificationStartAndStop) {
128 base::Closure start_func =
129 base::Bind(&SystemTrayNotifier::NotifyScreenCaptureStart,
130 base::Unretained(GetSystemTrayNotifier()),
131 base::Bind(&ScreenTrayItemTest::StopCallback,
132 base::Unretained(this)),
133 base::UTF8ToUTF16(kTestScreenCaptureAppName));
134
135 base::Closure stop_func =
136 base::Bind(&SystemTrayNotifier::NotifyScreenCaptureStop,
137 base::Unretained(GetSystemTrayNotifier()));
138
139 TestNotificationStartAndStop(this, start_func, stop_func);
140 }
141
142 TEST_F(ScreenShareTest, NotificationStartAndStop) {
143 base::Closure start_func =
144 base::Bind(&SystemTrayNotifier::NotifyScreenShareStart,
145 base::Unretained(GetSystemTrayNotifier()),
146 base::Bind(&ScreenTrayItemTest::StopCallback,
147 base::Unretained(this)),
148 base::UTF8ToUTF16(kTestScreenShareHelperName));
149
150 base::Closure stop_func =
151 base::Bind(&SystemTrayNotifier::NotifyScreenShareStop,
152 base::Unretained(GetSystemTrayNotifier()));
153
154 TestNotificationStartAndStop(this, start_func, stop_func);
155 }
156
157
158 void TestNotificationView(ScreenTrayItemTest* test) {
159 ScreenTrayItem* tray_item = test->tray_item();
160
161 test->StartSession();
162 EXPECT_TRUE(tray_item->notification_view()->visible());
163
164 // Clicking on the notification view should dismiss the view
165 ClickViewCenter(tray_item->notification_view());
166 EXPECT_FALSE(tray_item->notification_view());
167
168 test->StopSession();
169 }
170
171 TEST_F(ScreenCaptureTest, NotificationView) { TestNotificationView(this); }
172 TEST_F(ScreenShareTest, NotificationView) { TestNotificationView(this); }
173
174 } // namespace internal
175 } // namespace ash
OLDNEW
« no previous file with comments | « ash/system/chromeos/screen_security/screen_tray_item.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698