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

Side by Side Diff: ui/views/mus/window_manager_connection_unittest.cc

Issue 2180683003: NOSUBMIT: PointerWatcher observes all pointer events, with moves optional (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: 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
« no previous file with comments | « ui/views/mus/window_manager_connection.cc ('k') | ui/views/pointer_watcher.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "ui/views/mus/window_manager_connection.h" 5 #include "ui/views/mus/window_manager_connection.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "base/message_loop/message_loop.h" 9 #include "base/message_loop/message_loop.h"
10 #include "testing/gtest/include/gtest/gtest.h" 10 #include "testing/gtest/include/gtest/gtest.h"
11 #include "ui/events/event.h" 11 #include "ui/events/event.h"
12 #include "ui/views/pointer_watcher.h" 12 #include "ui/views/pointer_watcher.h"
13 #include "ui/views/test/scoped_views_test_helper.h" 13 #include "ui/views/test/scoped_views_test_helper.h"
14 #include "ui/views/touch_event_watcher.h"
15 14
16 namespace views { 15 namespace views {
17 namespace { 16 namespace {
18 17
19 class TestPointerWatcher : public PointerWatcher { 18 class TestPointerWatcher : public PointerWatcher {
20 public: 19 public:
21 TestPointerWatcher() {} 20 TestPointerWatcher() {}
22 ~TestPointerWatcher() override {} 21 ~TestPointerWatcher() override {}
23 22
24 bool mouse_pressed() const { return mouse_pressed_; } 23 bool mouse_pressed() const { return mouse_pressed_; }
25 bool touch_pressed() const { return touch_pressed_; } 24 bool touch_pressed() const { return touch_pressed_; }
26 25
27 void Reset() { 26 void Reset() {
28 mouse_pressed_ = false; 27 mouse_pressed_ = false;
29 touch_pressed_ = false; 28 touch_pressed_ = false;
30 } 29 }
31 30
32 // PointerWatcher: 31 // PointerWatcher:
33 void OnMousePressed(const ui::MouseEvent& event, 32 void OnPointerEventObserved(const ui::LocatedEvent& event,
34 const gfx::Point& location_in_screen, 33 const gfx::Point& location_in_screen,
35 Widget* target) override { 34 Widget* target) override {
36 mouse_pressed_ = true; 35 if (event.type() == ui::ET_TOUCH_PRESSED)
37 } 36 touch_pressed_ = true;
38 void OnTouchPressed(const ui::TouchEvent& event, 37 else if (event.type() == ui::ET_MOUSE_PRESSED)
39 const gfx::Point& location_in_screen, 38 mouse_pressed_ = true;
40 Widget* target) override {
41 touch_pressed_ = true;
42 } 39 }
43 40
44 private: 41 private:
45 bool mouse_pressed_ = false; 42 bool mouse_pressed_ = false;
46 bool touch_pressed_ = false; 43 bool touch_pressed_ = false;
47 44
48 DISALLOW_COPY_AND_ASSIGN(TestPointerWatcher); 45 DISALLOW_COPY_AND_ASSIGN(TestPointerWatcher);
49 }; 46 };
50 47
51 } // namespace 48 } // namespace
52 49
53 namespace {
54
55 class TestTouchEventWatcher : public TouchEventWatcher {
56 public:
57 TestTouchEventWatcher() {}
58 ~TestTouchEventWatcher() override {}
59
60 bool touch_observed() const { return touch_observed_; }
61
62 void Reset() { touch_observed_ = false; }
63
64 // TouchEventWatcher:
65 void OnTouchEventObserved(const ui::LocatedEvent& event,
66 Widget* target) override {
67 touch_observed_ = true;
68 }
69
70 private:
71 bool touch_observed_ = false;
72
73 DISALLOW_COPY_AND_ASSIGN(TestTouchEventWatcher);
74 };
75
76 } // namespace
77
78 class WindowManagerConnectionTest : public testing::Test { 50 class WindowManagerConnectionTest : public testing::Test {
79 public: 51 public:
80 WindowManagerConnectionTest() {} 52 WindowManagerConnectionTest() {}
81 ~WindowManagerConnectionTest() override {} 53 ~WindowManagerConnectionTest() override {}
82 54
83 void OnEventObserved(const ui::Event& event) { 55 void OnEventObserved(const ui::Event& event) {
84 WindowManagerConnection::Get()->OnEventObserved(event, nullptr); 56 WindowManagerConnection::Get()->OnEventObserved(event, nullptr);
85 } 57 }
86 58
87 private: 59 private:
88 DISALLOW_COPY_AND_ASSIGN(WindowManagerConnectionTest); 60 DISALLOW_COPY_AND_ASSIGN(WindowManagerConnectionTest);
89 }; 61 };
90 62
91 TEST_F(WindowManagerConnectionTest, PointerWatcher) { 63 TEST_F(WindowManagerConnectionTest, PointerWatcher) {
92 base::MessageLoop message_loop(base::MessageLoop::TYPE_UI); 64 base::MessageLoop message_loop(base::MessageLoop::TYPE_UI);
93 ScopedViewsTestHelper helper; 65 ScopedViewsTestHelper helper;
94 WindowManagerConnection* connection = WindowManagerConnection::Get(); 66 WindowManagerConnection* connection = WindowManagerConnection::Get();
95 ASSERT_TRUE(connection); 67 ASSERT_TRUE(connection);
96 ui::MouseEvent mouse_pressed(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), 68 ui::MouseEvent mouse_pressed(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(),
97 base::TimeTicks(), ui::EF_NONE, 0); 69 base::TimeTicks(), ui::EF_NONE, 0);
98 ui::TouchEvent touch_pressed(ui::ET_TOUCH_PRESSED, gfx::Point(), 1, 70 ui::TouchEvent touch_pressed(ui::ET_TOUCH_PRESSED, gfx::Point(), 1,
99 base::TimeTicks()); 71 base::TimeTicks());
100 ui::KeyEvent key_pressed(ui::ET_KEY_PRESSED, ui::VKEY_A, 0); 72 ui::KeyEvent key_pressed(ui::ET_KEY_PRESSED, ui::VKEY_A, 0);
101 73
102 // PointerWatchers receive mouse events. 74 // PointerWatchers receive mouse events.
103 TestPointerWatcher watcher1; 75 TestPointerWatcher watcher1;
104 connection->AddPointerWatcher(&watcher1); 76 connection->AddPointerWatcher(&watcher1, false);
105 OnEventObserved(mouse_pressed); 77 OnEventObserved(mouse_pressed);
106 EXPECT_TRUE(watcher1.mouse_pressed()); 78 EXPECT_TRUE(watcher1.mouse_pressed());
107 watcher1.Reset(); 79 watcher1.Reset();
108 80
109 // PointerWatchers receive touch events. 81 // PointerWatchers receive touch events.
110 OnEventObserved(touch_pressed); 82 OnEventObserved(touch_pressed);
111 EXPECT_TRUE(watcher1.touch_pressed()); 83 EXPECT_TRUE(watcher1.touch_pressed());
112 watcher1.Reset(); 84 watcher1.Reset();
113 85
114 // PointerWatchers do not trigger for key events. 86 // PointerWatchers do not trigger for key events.
115 OnEventObserved(key_pressed); 87 OnEventObserved(key_pressed);
116 EXPECT_FALSE(watcher1.mouse_pressed()); 88 EXPECT_FALSE(watcher1.mouse_pressed());
117 EXPECT_FALSE(watcher1.touch_pressed()); 89 EXPECT_FALSE(watcher1.touch_pressed());
118 watcher1.Reset(); 90 watcher1.Reset();
119 91
120 // Two PointerWatchers can both receive a single observed event. 92 // Two PointerWatchers can both receive a single observed event.
121 TestPointerWatcher watcher2; 93 TestPointerWatcher watcher2;
122 connection->AddPointerWatcher(&watcher2); 94 connection->AddPointerWatcher(&watcher2, false);
123 OnEventObserved(mouse_pressed); 95 OnEventObserved(mouse_pressed);
124 EXPECT_TRUE(watcher1.mouse_pressed()); 96 EXPECT_TRUE(watcher1.mouse_pressed());
125 EXPECT_TRUE(watcher2.mouse_pressed()); 97 EXPECT_TRUE(watcher2.mouse_pressed());
126 watcher1.Reset(); 98 watcher1.Reset();
127 watcher2.Reset(); 99 watcher2.Reset();
128 100
129 // Removing the first PointerWatcher stops sending events to it. 101 // Removing the first PointerWatcher stops sending events to it.
130 connection->RemovePointerWatcher(&watcher1); 102 connection->RemovePointerWatcher(&watcher1);
131 OnEventObserved(mouse_pressed); 103 OnEventObserved(mouse_pressed);
132 EXPECT_FALSE(watcher1.mouse_pressed()); 104 EXPECT_FALSE(watcher1.mouse_pressed());
133 EXPECT_TRUE(watcher2.mouse_pressed()); 105 EXPECT_TRUE(watcher2.mouse_pressed());
134 watcher1.Reset(); 106 watcher1.Reset();
135 watcher2.Reset(); 107 watcher2.Reset();
136 108
137 // Removing the last PointerWatcher stops sending events to it. 109 // Removing the last PointerWatcher stops sending events to it.
138 connection->RemovePointerWatcher(&watcher2); 110 connection->RemovePointerWatcher(&watcher2);
139 OnEventObserved(mouse_pressed); 111 OnEventObserved(mouse_pressed);
140 EXPECT_FALSE(watcher1.mouse_pressed()); 112 EXPECT_FALSE(watcher1.mouse_pressed());
141 EXPECT_FALSE(watcher1.touch_pressed()); 113 EXPECT_FALSE(watcher1.touch_pressed());
142 } 114 }
143 115
144 TEST_F(WindowManagerConnectionTest, TouchEventWatcher) {
145 base::MessageLoop message_loop(base::MessageLoop::TYPE_UI);
146 ScopedViewsTestHelper helper;
147 WindowManagerConnection* connection = WindowManagerConnection::Get();
148 ASSERT_TRUE(connection);
149
150 const ui::EventType kMouseType[] = {
151 ui::ET_MOUSE_PRESSED, ui::ET_MOUSE_DRAGGED, ui::ET_MOUSE_MOVED,
152 ui::ET_MOUSE_ENTERED, ui::ET_MOUSE_EXITED, ui::ET_MOUSE_RELEASED};
153 const ui::EventType kTouchType[] = {ui::ET_TOUCH_PRESSED, ui::ET_TOUCH_MOVED,
154 ui::ET_TOUCH_RELEASED,
155 ui::ET_TOUCH_CANCELLED};
156
157 TestTouchEventWatcher watcher1;
158 connection->AddTouchEventWatcher(&watcher1);
159
160 // TouchEventWatchers do not trigger for mouse events.
161 for (size_t i = 0; i < arraysize(kMouseType); i++) {
162 ui::MouseEvent mouse_event(kMouseType[i], gfx::Point(), gfx::Point(),
163 base::TimeTicks(), 0, 0);
164 ui::PointerEvent mouse_pointer_event(mouse_event);
165 EXPECT_TRUE(mouse_pointer_event.IsMousePointerEvent());
166 OnEventObserved(mouse_pointer_event);
167 EXPECT_FALSE(watcher1.touch_observed());
168 watcher1.Reset();
169 }
170
171 // TouchEventWatchers receive both TouchEvent and TouchPointerEvent.
172 for (size_t i = 0; i < arraysize(kTouchType); i++) {
173 ui::TouchEvent touch_event(kTouchType[i], gfx::Point(), 0,
174 base::TimeTicks());
175 EXPECT_TRUE(touch_event.IsTouchEvent());
176 OnEventObserved(touch_event);
177 EXPECT_TRUE(watcher1.touch_observed());
178 watcher1.Reset();
179
180 ui::PointerEvent touch_pointer_event(touch_event);
181 EXPECT_TRUE(touch_pointer_event.IsTouchPointerEvent());
182 OnEventObserved(touch_pointer_event);
183 EXPECT_TRUE(watcher1.touch_observed());
184 watcher1.Reset();
185 }
186
187 // Two TouchEventWatchers can both receive a single observed event.
188 TestTouchEventWatcher watcher2;
189 connection->AddTouchEventWatcher(&watcher2);
190 ui::TouchEvent touch_event(ui::ET_TOUCH_PRESSED, gfx::Point(), 0,
191 base::TimeTicks());
192 ui::PointerEvent touch_pointer_event(touch_event);
193 OnEventObserved(touch_pointer_event);
194 EXPECT_TRUE(watcher1.touch_observed());
195 EXPECT_TRUE(watcher2.touch_observed());
196 watcher1.Reset();
197 watcher2.Reset();
198
199 // Removing the first TouchEventWatcher stops sending events to it.
200 connection->RemoveTouchEventWatcher(&watcher1);
201 OnEventObserved(touch_pointer_event);
202 EXPECT_FALSE(watcher1.touch_observed());
203 EXPECT_TRUE(watcher2.touch_observed());
204 watcher1.Reset();
205 watcher2.Reset();
206
207 // Removing the last TouchEventWatcher stops sending events to it.
208 connection->RemoveTouchEventWatcher(&watcher2);
209 OnEventObserved(touch_pointer_event);
210 EXPECT_FALSE(watcher1.touch_observed());
211 EXPECT_FALSE(watcher2.touch_observed());
212 }
213
214 } // namespace views 116 } // namespace views
OLDNEW
« no previous file with comments | « ui/views/mus/window_manager_connection.cc ('k') | ui/views/pointer_watcher.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698