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

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

Issue 1957653003: mash: Don't close system tray bubble for clicks in menus/notifications (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 7 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 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 14
15 namespace views { 15 namespace views {
16 namespace { 16 namespace {
17 17
18 class TestPointerWatcher : public PointerWatcher { 18 class TestPointerWatcher : public PointerWatcher {
19 public: 19 public:
20 TestPointerWatcher() {} 20 TestPointerWatcher() {}
21 ~TestPointerWatcher() override {} 21 ~TestPointerWatcher() override {}
22 22
23 ui::Event* last_event() { return last_event_.get(); } 23 bool mouse_pressed() const { return mouse_pressed_; }
24 bool touch_pressed() const { return touch_pressed_; }
24 25
25 void Reset() { last_event_.reset(); } 26 void Reset() {
27 mouse_pressed_ = false;
28 touch_pressed_ = false;
29 }
26 30
27 // PointerWatcher: 31 // PointerWatcher:
28 void OnMousePressed(const ui::MouseEvent& event, 32 void OnMousePressed(const gfx::Point& location_in_screen,
29 const gfx::Point& location_in_screen) override { 33 Widget* target) override {
30 last_event_ = ui::Event::Clone(event); 34 mouse_pressed_ = true;
31 } 35 }
32 void OnTouchPressed(const ui::TouchEvent& event, 36 void OnTouchPressed(const gfx::Point& location_in_screen,
33 const gfx::Point& location_in_screen) override { 37 Widget* target) override {
34 last_event_ = ui::Event::Clone(event); 38 touch_pressed_ = true;
35 } 39 }
36 40
37 private: 41 private:
38 std::unique_ptr<ui::Event> last_event_; 42 bool mouse_pressed_ = false;
43 bool touch_pressed_ = false;
39 44
40 DISALLOW_COPY_AND_ASSIGN(TestPointerWatcher); 45 DISALLOW_COPY_AND_ASSIGN(TestPointerWatcher);
41 }; 46 };
42 47
43 } // namespace 48 } // namespace
44 49
45 class WindowManagerConnectionTest : public testing::Test { 50 class WindowManagerConnectionTest : public testing::Test {
46 public: 51 public:
47 WindowManagerConnectionTest() {} 52 WindowManagerConnectionTest() {}
48 ~WindowManagerConnectionTest() override {} 53 ~WindowManagerConnectionTest() override {}
49 54
50 void OnEventObserved(const ui::Event& event) { 55 void OnEventObserved(const ui::Event& event) {
51 WindowManagerConnection::Get()->OnEventObserved(event); 56 WindowManagerConnection::Get()->OnEventObserved(event, nullptr);
52 } 57 }
53 58
54 private: 59 private:
55 DISALLOW_COPY_AND_ASSIGN(WindowManagerConnectionTest); 60 DISALLOW_COPY_AND_ASSIGN(WindowManagerConnectionTest);
56 }; 61 };
57 62
58 TEST_F(WindowManagerConnectionTest, PointerWatcher) { 63 TEST_F(WindowManagerConnectionTest, PointerWatcher) {
59 base::MessageLoop message_loop(base::MessageLoop::TYPE_UI); 64 base::MessageLoop message_loop(base::MessageLoop::TYPE_UI);
60 ScopedViewsTestHelper helper; 65 ScopedViewsTestHelper helper;
61 WindowManagerConnection* connection = WindowManagerConnection::Get(); 66 WindowManagerConnection* connection = WindowManagerConnection::Get();
62 ASSERT_TRUE(connection); 67 ASSERT_TRUE(connection);
63 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(),
64 base::TimeDelta(), ui::EF_NONE, 0); 69 base::TimeDelta(), ui::EF_NONE, 0);
65 ui::TouchEvent touch_pressed(ui::ET_TOUCH_PRESSED, gfx::Point(), 1, 70 ui::TouchEvent touch_pressed(ui::ET_TOUCH_PRESSED, gfx::Point(), 1,
66 base::TimeDelta()); 71 base::TimeDelta());
67 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);
68 73
69 // PointerWatchers receive mouse events. 74 // PointerWatchers receive mouse events.
70 TestPointerWatcher watcher1; 75 TestPointerWatcher watcher1;
71 connection->AddPointerWatcher(&watcher1); 76 connection->AddPointerWatcher(&watcher1);
72 OnEventObserved(mouse_pressed); 77 OnEventObserved(mouse_pressed);
73 EXPECT_EQ(ui::ET_MOUSE_PRESSED, watcher1.last_event()->type()); 78 EXPECT_TRUE(watcher1.mouse_pressed());
74 watcher1.Reset(); 79 watcher1.Reset();
75 80
76 // PointerWatchers receive touch events. 81 // PointerWatchers receive touch events.
77 OnEventObserved(touch_pressed); 82 OnEventObserved(touch_pressed);
78 EXPECT_EQ(ui::ET_TOUCH_PRESSED, watcher1.last_event()->type()); 83 EXPECT_TRUE(watcher1.touch_pressed());
79 watcher1.Reset(); 84 watcher1.Reset();
80 85
81 // PointerWatchers do not receive key events. 86 // PointerWatchers do not trigger for key events.
82 OnEventObserved(key_pressed); 87 OnEventObserved(key_pressed);
83 EXPECT_FALSE(watcher1.last_event()); 88 EXPECT_FALSE(watcher1.mouse_pressed());
89 EXPECT_FALSE(watcher1.touch_pressed());
84 watcher1.Reset(); 90 watcher1.Reset();
85 91
86 // Two PointerWatchers can both receive a single observed event. 92 // Two PointerWatchers can both receive a single observed event.
87 TestPointerWatcher watcher2; 93 TestPointerWatcher watcher2;
88 connection->AddPointerWatcher(&watcher2); 94 connection->AddPointerWatcher(&watcher2);
89 OnEventObserved(mouse_pressed); 95 OnEventObserved(mouse_pressed);
90 EXPECT_EQ(ui::ET_MOUSE_PRESSED, watcher1.last_event()->type()); 96 EXPECT_TRUE(watcher1.mouse_pressed());
91 EXPECT_EQ(ui::ET_MOUSE_PRESSED, watcher2.last_event()->type()); 97 EXPECT_TRUE(watcher2.mouse_pressed());
92 watcher1.Reset(); 98 watcher1.Reset();
93 watcher2.Reset(); 99 watcher2.Reset();
94 100
95 // Removing the first PointerWatcher stops sending events to it. 101 // Removing the first PointerWatcher stops sending events to it.
96 connection->RemovePointerWatcher(&watcher1); 102 connection->RemovePointerWatcher(&watcher1);
97 OnEventObserved(mouse_pressed); 103 OnEventObserved(mouse_pressed);
98 EXPECT_FALSE(watcher1.last_event()); 104 EXPECT_FALSE(watcher1.mouse_pressed());
99 EXPECT_EQ(ui::ET_MOUSE_PRESSED, watcher2.last_event()->type()); 105 EXPECT_TRUE(watcher2.mouse_pressed());
100 watcher1.Reset(); 106 watcher1.Reset();
101 watcher2.Reset(); 107 watcher2.Reset();
102 108
103 // Removing the last PointerWatcher stops sending events to it. 109 // Removing the last PointerWatcher stops sending events to it.
104 connection->RemovePointerWatcher(&watcher2); 110 connection->RemovePointerWatcher(&watcher2);
105 OnEventObserved(mouse_pressed); 111 OnEventObserved(mouse_pressed);
106 EXPECT_FALSE(watcher1.last_event()); 112 EXPECT_FALSE(watcher1.mouse_pressed());
107 EXPECT_FALSE(watcher2.last_event()); 113 EXPECT_FALSE(watcher1.touch_pressed());
108 } 114 }
109 115
110 } // namespace views 116 } // namespace views
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698