OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "components/mus/public/cpp/lib/window_tree_client_impl.h" | 5 #include "components/mus/public/cpp/window_tree_client.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 | 8 |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/macros.h" | 10 #include "base/macros.h" |
11 #include "components/mus/common/util.h" | 11 #include "components/mus/common/util.h" |
12 #include "components/mus/public/cpp/input_event_handler.h" | 12 #include "components/mus/public/cpp/input_event_handler.h" |
13 #include "components/mus/public/cpp/lib/window_private.h" | 13 #include "components/mus/public/cpp/lib/window_private.h" |
14 #include "components/mus/public/cpp/property_type_converters.h" | 14 #include "components/mus/public/cpp/property_type_converters.h" |
15 #include "components/mus/public/cpp/tests/test_window.h" | 15 #include "components/mus/public/cpp/tests/test_window.h" |
16 #include "components/mus/public/cpp/tests/test_window_tree.h" | 16 #include "components/mus/public/cpp/tests/test_window_tree.h" |
17 #include "components/mus/public/cpp/tests/window_tree_client_impl_private.h" | 17 #include "components/mus/public/cpp/tests/window_tree_client_private.h" |
18 #include "components/mus/public/cpp/window.h" | 18 #include "components/mus/public/cpp/window.h" |
19 #include "components/mus/public/cpp/window_observer.h" | 19 #include "components/mus/public/cpp/window_observer.h" |
20 #include "components/mus/public/cpp/window_property.h" | 20 #include "components/mus/public/cpp/window_property.h" |
21 #include "components/mus/public/cpp/window_tracker.h" | 21 #include "components/mus/public/cpp/window_tracker.h" |
22 #include "components/mus/public/cpp/window_tree_delegate.h" | 22 #include "components/mus/public/cpp/window_tree_client_delegate.h" |
23 #include "mojo/common/common_type_converters.h" | 23 #include "mojo/common/common_type_converters.h" |
24 #include "testing/gtest/include/gtest/gtest.h" | 24 #include "testing/gtest/include/gtest/gtest.h" |
25 #include "ui/events/event.h" | 25 #include "ui/events/event.h" |
26 #include "ui/events/event_utils.h" | 26 #include "ui/events/event_utils.h" |
27 #include "ui/events/mojo/input_events_type_converters.h" | 27 #include "ui/events/mojo/input_events_type_converters.h" |
28 #include "ui/gfx/geometry/mojo/geometry_type_converters.h" | 28 #include "ui/gfx/geometry/mojo/geometry_type_converters.h" |
29 #include "ui/gfx/geometry/rect.h" | 29 #include "ui/gfx/geometry/rect.h" |
30 | 30 |
31 namespace mus { | 31 namespace mus { |
32 | 32 |
33 namespace { | 33 namespace { |
34 | 34 |
35 void DoNothingWithEventResult(mojom::EventResult result) {} | 35 void DoNothingWithEventResult(mojom::EventResult result) {} |
36 | 36 |
37 Id server_id(mus::Window* window) { | 37 Id server_id(mus::Window* window) { |
38 return WindowPrivate(window).server_id(); | 38 return WindowPrivate(window).server_id(); |
39 } | 39 } |
40 | 40 |
41 } // namespace | 41 } // namespace |
42 | 42 |
43 mojo::Array<uint8_t> Int32ToPropertyTransportValue(int32_t value) { | 43 mojo::Array<uint8_t> Int32ToPropertyTransportValue(int32_t value) { |
44 const std::vector<uint8_t> bytes = | 44 const std::vector<uint8_t> bytes = |
45 mojo::ConvertTo<std::vector<uint8_t>>(value); | 45 mojo::ConvertTo<std::vector<uint8_t>>(value); |
46 mojo::Array<uint8_t> transport_value; | 46 mojo::Array<uint8_t> transport_value; |
47 transport_value.resize(bytes.size()); | 47 transport_value.resize(bytes.size()); |
48 memcpy(&transport_value.front(), &(bytes.front()), bytes.size()); | 48 memcpy(&transport_value.front(), &(bytes.front()), bytes.size()); |
49 return transport_value; | 49 return transport_value; |
50 } | 50 } |
51 | 51 |
52 class TestWindowTreeDelegate : public WindowTreeDelegate { | 52 class TestWindowTreeClientDelegate : public WindowTreeClientDelegate { |
53 public: | 53 public: |
54 TestWindowTreeDelegate() {} | 54 TestWindowTreeClientDelegate() {} |
55 ~TestWindowTreeDelegate() override {} | 55 ~TestWindowTreeClientDelegate() override {} |
56 | 56 |
57 ui::Event* last_event_observed() { return last_event_observed_.get(); } | 57 ui::Event* last_event_observed() { return last_event_observed_.get(); } |
58 | 58 |
59 void Reset() { last_event_observed_.reset(); } | 59 void Reset() { last_event_observed_.reset(); } |
60 | 60 |
61 // WindowTreeDelegate: | 61 // WindowTreeClientDelegate: |
62 void OnEmbed(Window* root) override {} | 62 void OnEmbed(Window* root) override {} |
63 void OnConnectionLost(WindowTreeConnection* connection) override {} | 63 void OnWindowTreeClientDestroyed(WindowTreeClient* client) override {} |
64 void OnEventObserved(const ui::Event& event, Window* target) override { | 64 void OnEventObserved(const ui::Event& event, Window* target) override { |
65 last_event_observed_ = ui::Event::Clone(event); | 65 last_event_observed_ = ui::Event::Clone(event); |
66 } | 66 } |
67 | 67 |
68 private: | 68 private: |
69 std::unique_ptr<ui::Event> last_event_observed_; | 69 std::unique_ptr<ui::Event> last_event_observed_; |
70 | 70 |
71 DISALLOW_COPY_AND_ASSIGN(TestWindowTreeDelegate); | 71 DISALLOW_COPY_AND_ASSIGN(TestWindowTreeClientDelegate); |
72 }; | 72 }; |
73 | 73 |
74 class WindowTreeSetup { | 74 class WindowTreeSetup { |
75 public: | 75 public: |
76 WindowTreeSetup() : tree_client_(&window_tree_delegate_, nullptr, nullptr) { | 76 WindowTreeSetup() : tree_client_(&window_tree_delegate_, nullptr, nullptr) { |
77 WindowTreeClientImplPrivate(&tree_client_).OnEmbed(&window_tree_); | 77 WindowTreeClientPrivate(&tree_client_).OnEmbed(&window_tree_); |
78 window_tree_.GetAndClearChangeId(nullptr); | 78 window_tree_.GetAndClearChangeId(nullptr); |
79 } | 79 } |
80 | 80 |
81 WindowTreeConnection* window_tree_connection() { | 81 WindowTreeClient* client() { |
82 return static_cast<WindowTreeConnection*>(&tree_client_); | 82 return &tree_client_; |
83 } | 83 } |
84 | 84 |
85 mojom::WindowTreeClient* window_tree_client() { | 85 mojom::WindowTreeClient* window_tree_client() { |
86 return static_cast<mojom::WindowTreeClient*>(&tree_client_); | 86 return static_cast<mojom::WindowTreeClient*>(&tree_client_); |
87 } | 87 } |
88 | 88 |
89 TestWindowTree* window_tree() { return &window_tree_; } | 89 TestWindowTree* window_tree() { return &window_tree_; } |
90 | 90 |
91 TestWindowTreeDelegate* window_tree_delegate() { | 91 TestWindowTreeClientDelegate* window_tree_delegate() { |
92 return &window_tree_delegate_; | 92 return &window_tree_delegate_; |
93 } | 93 } |
94 | 94 |
95 Window* GetFirstRoot() { | 95 Window* GetFirstRoot() { |
96 return window_tree_connection()->GetRoots().empty() | 96 return client()->GetRoots().empty() ? nullptr |
97 ? nullptr | 97 : *client()->GetRoots().begin(); |
98 : *window_tree_connection()->GetRoots().begin(); | |
99 } | 98 } |
100 | 99 |
101 uint32_t GetEventObserverId() { | 100 uint32_t GetEventObserverId() { |
102 return WindowTreeClientImplPrivate(&tree_client_).event_observer_id(); | 101 return WindowTreeClientPrivate(&tree_client_).event_observer_id(); |
103 } | 102 } |
104 | 103 |
105 private: | 104 private: |
106 TestWindowTree window_tree_; | 105 TestWindowTree window_tree_; |
107 TestWindowTreeDelegate window_tree_delegate_; | 106 TestWindowTreeClientDelegate window_tree_delegate_; |
108 WindowTreeClientImpl tree_client_; | 107 WindowTreeClient tree_client_; |
109 | 108 |
110 DISALLOW_COPY_AND_ASSIGN(WindowTreeSetup); | 109 DISALLOW_COPY_AND_ASSIGN(WindowTreeSetup); |
111 }; | 110 }; |
112 | 111 |
113 class TestInputEventHandler : public InputEventHandler { | 112 class TestInputEventHandler : public InputEventHandler { |
114 public: | 113 public: |
115 TestInputEventHandler() | 114 TestInputEventHandler() |
116 : received_event_(false), should_manually_ack_(false) {} | 115 : received_event_(false), should_manually_ack_(false) {} |
117 ~TestInputEventHandler() override {} | 116 ~TestInputEventHandler() override {} |
118 | 117 |
(...skipping 28 matching lines...) Expand all Loading... |
147 } | 146 } |
148 } | 147 } |
149 | 148 |
150 bool received_event_; | 149 bool received_event_; |
151 bool should_manually_ack_; | 150 bool should_manually_ack_; |
152 base::Callback<void(mojom::EventResult)> ack_callback_; | 151 base::Callback<void(mojom::EventResult)> ack_callback_; |
153 | 152 |
154 DISALLOW_COPY_AND_ASSIGN(TestInputEventHandler); | 153 DISALLOW_COPY_AND_ASSIGN(TestInputEventHandler); |
155 }; | 154 }; |
156 | 155 |
157 using WindowTreeClientImplTest = testing::Test; | 156 using WindowTreeClientTest = testing::Test; |
158 | 157 |
159 // Verifies bounds are reverted if the server replied that the change failed. | 158 // Verifies bounds are reverted if the server replied that the change failed. |
160 TEST_F(WindowTreeClientImplTest, SetBoundsFailed) { | 159 TEST_F(WindowTreeClientTest, SetBoundsFailed) { |
161 WindowTreeSetup setup; | 160 WindowTreeSetup setup; |
162 Window* root = setup.GetFirstRoot(); | 161 Window* root = setup.GetFirstRoot(); |
163 ASSERT_TRUE(root); | 162 ASSERT_TRUE(root); |
164 const gfx::Rect original_bounds(root->bounds()); | 163 const gfx::Rect original_bounds(root->bounds()); |
165 const gfx::Rect new_bounds(gfx::Rect(0, 0, 100, 100)); | 164 const gfx::Rect new_bounds(gfx::Rect(0, 0, 100, 100)); |
166 ASSERT_NE(new_bounds, root->bounds()); | 165 ASSERT_NE(new_bounds, root->bounds()); |
167 root->SetBounds(new_bounds); | 166 root->SetBounds(new_bounds); |
168 uint32_t change_id; | 167 uint32_t change_id; |
169 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 168 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
170 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 169 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
171 EXPECT_EQ(original_bounds, root->bounds()); | 170 EXPECT_EQ(original_bounds, root->bounds()); |
172 } | 171 } |
173 | 172 |
174 // Simulates a bounds change, and while the bounds change is in flight the | 173 // Simulates a bounds change, and while the bounds change is in flight the |
175 // server replies with a new bounds and the original bounds change fails. | 174 // server replies with a new bounds and the original bounds change fails. |
176 TEST_F(WindowTreeClientImplTest, SetBoundsFailedWithPendingChange) { | 175 TEST_F(WindowTreeClientTest, SetBoundsFailedWithPendingChange) { |
177 WindowTreeSetup setup; | 176 WindowTreeSetup setup; |
178 Window* root = setup.GetFirstRoot(); | 177 Window* root = setup.GetFirstRoot(); |
179 ASSERT_TRUE(root); | 178 ASSERT_TRUE(root); |
180 const gfx::Rect original_bounds(root->bounds()); | 179 const gfx::Rect original_bounds(root->bounds()); |
181 const gfx::Rect new_bounds(gfx::Rect(0, 0, 100, 100)); | 180 const gfx::Rect new_bounds(gfx::Rect(0, 0, 100, 100)); |
182 ASSERT_NE(new_bounds, root->bounds()); | 181 ASSERT_NE(new_bounds, root->bounds()); |
183 root->SetBounds(new_bounds); | 182 root->SetBounds(new_bounds); |
184 EXPECT_EQ(new_bounds, root->bounds()); | 183 EXPECT_EQ(new_bounds, root->bounds()); |
185 uint32_t change_id; | 184 uint32_t change_id; |
186 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 185 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
(...skipping 12 matching lines...) Expand all Loading... |
199 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 198 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
200 EXPECT_EQ(server_changed_bounds, root->bounds()); | 199 EXPECT_EQ(server_changed_bounds, root->bounds()); |
201 | 200 |
202 // Simulate server changing back to original bounds. Should take immediately. | 201 // Simulate server changing back to original bounds. Should take immediately. |
203 setup.window_tree_client()->OnWindowBoundsChanged( | 202 setup.window_tree_client()->OnWindowBoundsChanged( |
204 server_id(root), mojo::Rect::From(server_changed_bounds), | 203 server_id(root), mojo::Rect::From(server_changed_bounds), |
205 mojo::Rect::From(original_bounds)); | 204 mojo::Rect::From(original_bounds)); |
206 EXPECT_EQ(original_bounds, root->bounds()); | 205 EXPECT_EQ(original_bounds, root->bounds()); |
207 } | 206 } |
208 | 207 |
209 TEST_F(WindowTreeClientImplTest, TwoInFlightBoundsChangesBothCanceled) { | 208 TEST_F(WindowTreeClientTest, TwoInFlightBoundsChangesBothCanceled) { |
210 WindowTreeSetup setup; | 209 WindowTreeSetup setup; |
211 Window* root = setup.GetFirstRoot(); | 210 Window* root = setup.GetFirstRoot(); |
212 ASSERT_TRUE(root); | 211 ASSERT_TRUE(root); |
213 const gfx::Rect original_bounds(root->bounds()); | 212 const gfx::Rect original_bounds(root->bounds()); |
214 const gfx::Rect bounds1(gfx::Rect(0, 0, 100, 100)); | 213 const gfx::Rect bounds1(gfx::Rect(0, 0, 100, 100)); |
215 const gfx::Rect bounds2(gfx::Rect(0, 0, 100, 102)); | 214 const gfx::Rect bounds2(gfx::Rect(0, 0, 100, 102)); |
216 root->SetBounds(bounds1); | 215 root->SetBounds(bounds1); |
217 EXPECT_EQ(bounds1, root->bounds()); | 216 EXPECT_EQ(bounds1, root->bounds()); |
218 uint32_t change_id1; | 217 uint32_t change_id1; |
219 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); | 218 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); |
220 | 219 |
221 root->SetBounds(bounds2); | 220 root->SetBounds(bounds2); |
222 EXPECT_EQ(bounds2, root->bounds()); | 221 EXPECT_EQ(bounds2, root->bounds()); |
223 uint32_t change_id2; | 222 uint32_t change_id2; |
224 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id2)); | 223 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id2)); |
225 | 224 |
226 // Tell the client change 1 failed. As there is a still a change in flight | 225 // Tell the client change 1 failed. As there is a still a change in flight |
227 // nothing should happen. | 226 // nothing should happen. |
228 setup.window_tree_client()->OnChangeCompleted(change_id1, false); | 227 setup.window_tree_client()->OnChangeCompleted(change_id1, false); |
229 EXPECT_EQ(bounds2, root->bounds()); | 228 EXPECT_EQ(bounds2, root->bounds()); |
230 | 229 |
231 // And tell the client change 2 failed too. Should now fallback to original | 230 // And tell the client change 2 failed too. Should now fallback to original |
232 // bounds. | 231 // bounds. |
233 setup.window_tree_client()->OnChangeCompleted(change_id2, false); | 232 setup.window_tree_client()->OnChangeCompleted(change_id2, false); |
234 EXPECT_EQ(original_bounds, root->bounds()); | 233 EXPECT_EQ(original_bounds, root->bounds()); |
235 } | 234 } |
236 | 235 |
237 // Verifies properties are reverted if the server replied that the change | 236 // Verifies properties are reverted if the server replied that the change |
238 // failed. | 237 // failed. |
239 TEST_F(WindowTreeClientImplTest, SetPropertyFailed) { | 238 TEST_F(WindowTreeClientTest, SetPropertyFailed) { |
240 WindowTreeSetup setup; | 239 WindowTreeSetup setup; |
241 Window* root = setup.GetFirstRoot(); | 240 Window* root = setup.GetFirstRoot(); |
242 ASSERT_TRUE(root); | 241 ASSERT_TRUE(root); |
243 ASSERT_FALSE(root->HasSharedProperty("foo")); | 242 ASSERT_FALSE(root->HasSharedProperty("foo")); |
244 const int32_t new_value = 11; | 243 const int32_t new_value = 11; |
245 root->SetSharedProperty("foo", new_value); | 244 root->SetSharedProperty("foo", new_value); |
246 ASSERT_TRUE(root->HasSharedProperty("foo")); | 245 ASSERT_TRUE(root->HasSharedProperty("foo")); |
247 EXPECT_EQ(new_value, root->GetSharedProperty<int32_t>("foo")); | 246 EXPECT_EQ(new_value, root->GetSharedProperty<int32_t>("foo")); |
248 uint32_t change_id; | 247 uint32_t change_id; |
249 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 248 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
250 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 249 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
251 EXPECT_FALSE(root->HasSharedProperty("foo")); | 250 EXPECT_FALSE(root->HasSharedProperty("foo")); |
252 } | 251 } |
253 | 252 |
254 // Simulates a property change, and while the property change is in flight the | 253 // Simulates a property change, and while the property change is in flight the |
255 // server replies with a new property and the original property change fails. | 254 // server replies with a new property and the original property change fails. |
256 TEST_F(WindowTreeClientImplTest, SetPropertyFailedWithPendingChange) { | 255 TEST_F(WindowTreeClientTest, SetPropertyFailedWithPendingChange) { |
257 WindowTreeSetup setup; | 256 WindowTreeSetup setup; |
258 Window* root = setup.GetFirstRoot(); | 257 Window* root = setup.GetFirstRoot(); |
259 ASSERT_TRUE(root); | 258 ASSERT_TRUE(root); |
260 const int32_t value1 = 11; | 259 const int32_t value1 = 11; |
261 root->SetSharedProperty("foo", value1); | 260 root->SetSharedProperty("foo", value1); |
262 ASSERT_TRUE(root->HasSharedProperty("foo")); | 261 ASSERT_TRUE(root->HasSharedProperty("foo")); |
263 EXPECT_EQ(value1, root->GetSharedProperty<int32_t>("foo")); | 262 EXPECT_EQ(value1, root->GetSharedProperty<int32_t>("foo")); |
264 uint32_t change_id; | 263 uint32_t change_id; |
265 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 264 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
266 | 265 |
(...skipping 13 matching lines...) Expand all Loading... |
280 EXPECT_EQ(server_value, root->GetSharedProperty<int32_t>("foo")); | 279 EXPECT_EQ(server_value, root->GetSharedProperty<int32_t>("foo")); |
281 | 280 |
282 // Simulate server changing back to value1. Should take immediately. | 281 // Simulate server changing back to value1. Should take immediately. |
283 setup.window_tree_client()->OnWindowSharedPropertyChanged( | 282 setup.window_tree_client()->OnWindowSharedPropertyChanged( |
284 server_id(root), "foo", Int32ToPropertyTransportValue(value1)); | 283 server_id(root), "foo", Int32ToPropertyTransportValue(value1)); |
285 ASSERT_TRUE(root->HasSharedProperty("foo")); | 284 ASSERT_TRUE(root->HasSharedProperty("foo")); |
286 EXPECT_EQ(value1, root->GetSharedProperty<int32_t>("foo")); | 285 EXPECT_EQ(value1, root->GetSharedProperty<int32_t>("foo")); |
287 } | 286 } |
288 | 287 |
289 // Verifies visible is reverted if the server replied that the change failed. | 288 // Verifies visible is reverted if the server replied that the change failed. |
290 TEST_F(WindowTreeClientImplTest, SetVisibleFailed) { | 289 TEST_F(WindowTreeClientTest, SetVisibleFailed) { |
291 WindowTreeSetup setup; | 290 WindowTreeSetup setup; |
292 Window* root = setup.GetFirstRoot(); | 291 Window* root = setup.GetFirstRoot(); |
293 ASSERT_TRUE(root); | 292 ASSERT_TRUE(root); |
294 const bool original_visible = root->visible(); | 293 const bool original_visible = root->visible(); |
295 const bool new_visible = !original_visible; | 294 const bool new_visible = !original_visible; |
296 ASSERT_NE(new_visible, root->visible()); | 295 ASSERT_NE(new_visible, root->visible()); |
297 root->SetVisible(new_visible); | 296 root->SetVisible(new_visible); |
298 uint32_t change_id; | 297 uint32_t change_id; |
299 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 298 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
300 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 299 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
301 EXPECT_EQ(original_visible, root->visible()); | 300 EXPECT_EQ(original_visible, root->visible()); |
302 } | 301 } |
303 | 302 |
304 // Simulates a visible change, and while the visible change is in flight the | 303 // Simulates a visible change, and while the visible change is in flight the |
305 // server replies with a new visible and the original visible change fails. | 304 // server replies with a new visible and the original visible change fails. |
306 TEST_F(WindowTreeClientImplTest, SetVisibleFailedWithPendingChange) { | 305 TEST_F(WindowTreeClientTest, SetVisibleFailedWithPendingChange) { |
307 WindowTreeSetup setup; | 306 WindowTreeSetup setup; |
308 Window* root = setup.GetFirstRoot(); | 307 Window* root = setup.GetFirstRoot(); |
309 ASSERT_TRUE(root); | 308 ASSERT_TRUE(root); |
310 const bool original_visible = root->visible(); | 309 const bool original_visible = root->visible(); |
311 const bool new_visible = !original_visible; | 310 const bool new_visible = !original_visible; |
312 ASSERT_NE(new_visible, root->visible()); | 311 ASSERT_NE(new_visible, root->visible()); |
313 root->SetVisible(new_visible); | 312 root->SetVisible(new_visible); |
314 EXPECT_EQ(new_visible, root->visible()); | 313 EXPECT_EQ(new_visible, root->visible()); |
315 uint32_t change_id; | 314 uint32_t change_id; |
316 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 315 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
(...skipping 12 matching lines...) Expand all Loading... |
329 EXPECT_EQ(server_changed_visible, root->visible()); | 328 EXPECT_EQ(server_changed_visible, root->visible()); |
330 | 329 |
331 // Simulate server changing back to original visible. Should take immediately. | 330 // Simulate server changing back to original visible. Should take immediately. |
332 setup.window_tree_client()->OnWindowVisibilityChanged(server_id(root), | 331 setup.window_tree_client()->OnWindowVisibilityChanged(server_id(root), |
333 original_visible); | 332 original_visible); |
334 EXPECT_EQ(original_visible, root->visible()); | 333 EXPECT_EQ(original_visible, root->visible()); |
335 } | 334 } |
336 | 335 |
337 // Verifies that local opacity is not changed if the server replied that the | 336 // Verifies that local opacity is not changed if the server replied that the |
338 // change succeeded. | 337 // change succeeded. |
339 TEST_F(WindowTreeClientImplTest, SetOpacitySucceeds) { | 338 TEST_F(WindowTreeClientTest, SetOpacitySucceeds) { |
340 WindowTreeSetup setup; | 339 WindowTreeSetup setup; |
341 Window* root = setup.GetFirstRoot(); | 340 Window* root = setup.GetFirstRoot(); |
342 ASSERT_TRUE(root); | 341 ASSERT_TRUE(root); |
343 const float original_opacity = root->opacity(); | 342 const float original_opacity = root->opacity(); |
344 const float new_opacity = 0.5f; | 343 const float new_opacity = 0.5f; |
345 ASSERT_NE(new_opacity, original_opacity); | 344 ASSERT_NE(new_opacity, original_opacity); |
346 ASSERT_NE(new_opacity, root->opacity()); | 345 ASSERT_NE(new_opacity, root->opacity()); |
347 root->SetOpacity(new_opacity); | 346 root->SetOpacity(new_opacity); |
348 uint32_t change_id; | 347 uint32_t change_id; |
349 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 348 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
350 setup.window_tree_client()->OnChangeCompleted(change_id, true); | 349 setup.window_tree_client()->OnChangeCompleted(change_id, true); |
351 EXPECT_EQ(new_opacity, root->opacity()); | 350 EXPECT_EQ(new_opacity, root->opacity()); |
352 } | 351 } |
353 | 352 |
354 // Verifies that opacity is reverted if the server replied that the change | 353 // Verifies that opacity is reverted if the server replied that the change |
355 // failed. | 354 // failed. |
356 TEST_F(WindowTreeClientImplTest, SetOpacityFailed) { | 355 TEST_F(WindowTreeClientTest, SetOpacityFailed) { |
357 WindowTreeSetup setup; | 356 WindowTreeSetup setup; |
358 Window* root = setup.GetFirstRoot(); | 357 Window* root = setup.GetFirstRoot(); |
359 ASSERT_TRUE(root); | 358 ASSERT_TRUE(root); |
360 const float original_opacity = root->opacity(); | 359 const float original_opacity = root->opacity(); |
361 const float new_opacity = 0.5f; | 360 const float new_opacity = 0.5f; |
362 ASSERT_NE(new_opacity, root->opacity()); | 361 ASSERT_NE(new_opacity, root->opacity()); |
363 root->SetOpacity(new_opacity); | 362 root->SetOpacity(new_opacity); |
364 uint32_t change_id; | 363 uint32_t change_id; |
365 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 364 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
366 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 365 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
367 EXPECT_EQ(original_opacity, root->opacity()); | 366 EXPECT_EQ(original_opacity, root->opacity()); |
368 } | 367 } |
369 | 368 |
370 // Simulates the server changing the opacitry while there is an opacity change | 369 // Simulates the server changing the opacitry while there is an opacity change |
371 // in flight, causing the requested change to fail. | 370 // in flight, causing the requested change to fail. |
372 TEST_F(WindowTreeClientImplTest, SetOpacityFailedWithPendingChange) { | 371 TEST_F(WindowTreeClientTest, SetOpacityFailedWithPendingChange) { |
373 WindowTreeSetup setup; | 372 WindowTreeSetup setup; |
374 Window* root = setup.GetFirstRoot(); | 373 Window* root = setup.GetFirstRoot(); |
375 ASSERT_TRUE(root); | 374 ASSERT_TRUE(root); |
376 const float original_opacity = root->opacity(); | 375 const float original_opacity = root->opacity(); |
377 const float new_opacity = 0.5f; | 376 const float new_opacity = 0.5f; |
378 ASSERT_NE(new_opacity, root->opacity()); | 377 ASSERT_NE(new_opacity, root->opacity()); |
379 root->SetOpacity(new_opacity); | 378 root->SetOpacity(new_opacity); |
380 EXPECT_EQ(new_opacity, root->opacity()); | 379 EXPECT_EQ(new_opacity, root->opacity()); |
381 uint32_t change_id; | 380 uint32_t change_id; |
382 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 381 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
(...skipping 12 matching lines...) Expand all Loading... |
395 EXPECT_EQ(server_changed_opacity, root->opacity()); | 394 EXPECT_EQ(server_changed_opacity, root->opacity()); |
396 | 395 |
397 // Simulate server changing back to original opacity. Should take immediately. | 396 // Simulate server changing back to original opacity. Should take immediately. |
398 setup.window_tree_client()->OnWindowOpacityChanged( | 397 setup.window_tree_client()->OnWindowOpacityChanged( |
399 server_id(root), server_changed_opacity, original_opacity); | 398 server_id(root), server_changed_opacity, original_opacity); |
400 EXPECT_EQ(original_opacity, root->opacity()); | 399 EXPECT_EQ(original_opacity, root->opacity()); |
401 } | 400 } |
402 | 401 |
403 // Tests that when there are multiple changes in flight, that failing changes | 402 // Tests that when there are multiple changes in flight, that failing changes |
404 // update the revert state of subsequent changes. | 403 // update the revert state of subsequent changes. |
405 TEST_F(WindowTreeClientImplTest, SetOpacityFailedWithMultiplePendingChange) { | 404 TEST_F(WindowTreeClientTest, SetOpacityFailedWithMultiplePendingChange) { |
406 WindowTreeSetup setup; | 405 WindowTreeSetup setup; |
407 Window* root = setup.GetFirstRoot(); | 406 Window* root = setup.GetFirstRoot(); |
408 ASSERT_TRUE(root); | 407 ASSERT_TRUE(root); |
409 const float original_opacity = root->opacity(); | 408 const float original_opacity = root->opacity(); |
410 const float new_opacity = 0.5f; | 409 const float new_opacity = 0.5f; |
411 ASSERT_NE(new_opacity, root->opacity()); | 410 ASSERT_NE(new_opacity, root->opacity()); |
412 root->SetOpacity(new_opacity); | 411 root->SetOpacity(new_opacity); |
413 uint32_t change_id1; | 412 uint32_t change_id1; |
414 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); | 413 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); |
415 | 414 |
416 const float second_new_opacity = 0.75f; | 415 const float second_new_opacity = 0.75f; |
417 ASSERT_NE(second_new_opacity, root->opacity()); | 416 ASSERT_NE(second_new_opacity, root->opacity()); |
418 root->SetOpacity(second_new_opacity); | 417 root->SetOpacity(second_new_opacity); |
419 uint32_t change_id2; | 418 uint32_t change_id2; |
420 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id2)); | 419 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id2)); |
421 | 420 |
422 // Canceling the first one, while there is another in flight, should not | 421 // Canceling the first one, while there is another in flight, should not |
423 // change the local opacity. | 422 // change the local opacity. |
424 setup.window_tree_client()->OnChangeCompleted(change_id1, false); | 423 setup.window_tree_client()->OnChangeCompleted(change_id1, false); |
425 EXPECT_EQ(second_new_opacity, root->opacity()); | 424 EXPECT_EQ(second_new_opacity, root->opacity()); |
426 | 425 |
427 // The previous cancelation should have updated the revert value of the in | 426 // The previous cancelation should have updated the revert value of the in |
428 // flight change. | 427 // flight change. |
429 setup.window_tree_client()->OnChangeCompleted(change_id2, false); | 428 setup.window_tree_client()->OnChangeCompleted(change_id2, false); |
430 EXPECT_EQ(original_opacity, root->opacity()); | 429 EXPECT_EQ(original_opacity, root->opacity()); |
431 } | 430 } |
432 | 431 |
433 // Verifies |is_modal| is reverted if the server replied that the change failed. | 432 // Verifies |is_modal| is reverted if the server replied that the change failed. |
434 TEST_F(WindowTreeClientImplTest, SetModalFailed) { | 433 TEST_F(WindowTreeClientTest, SetModalFailed) { |
435 WindowTreeSetup setup; | 434 WindowTreeSetup setup; |
436 Window* root = setup.GetFirstRoot(); | 435 Window* root = setup.GetFirstRoot(); |
437 ASSERT_TRUE(root); | 436 ASSERT_TRUE(root); |
438 EXPECT_FALSE(root->is_modal()); | 437 EXPECT_FALSE(root->is_modal()); |
439 root->SetModal(); | 438 root->SetModal(); |
440 uint32_t change_id; | 439 uint32_t change_id; |
441 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 440 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
442 EXPECT_TRUE(root->is_modal()); | 441 EXPECT_TRUE(root->is_modal()); |
443 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 442 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
444 EXPECT_FALSE(root->is_modal()); | 443 EXPECT_FALSE(root->is_modal()); |
445 } | 444 } |
446 | 445 |
447 TEST_F(WindowTreeClientImplTest, InputEventBasic) { | 446 TEST_F(WindowTreeClientTest, InputEventBasic) { |
448 WindowTreeSetup setup; | 447 WindowTreeSetup setup; |
449 Window* root = setup.GetFirstRoot(); | 448 Window* root = setup.GetFirstRoot(); |
450 ASSERT_TRUE(root); | 449 ASSERT_TRUE(root); |
451 | 450 |
452 TestInputEventHandler event_handler; | 451 TestInputEventHandler event_handler; |
453 root->set_input_event_handler(&event_handler); | 452 root->set_input_event_handler(&event_handler); |
454 | 453 |
455 std::unique_ptr<ui::Event> ui_event( | 454 std::unique_ptr<ui::Event> ui_event( |
456 new ui::MouseEvent(ui::ET_MOUSE_MOVED, gfx::Point(), gfx::Point(), | 455 new ui::MouseEvent(ui::ET_MOUSE_MOVED, gfx::Point(), gfx::Point(), |
457 ui::EventTimeForNow(), ui::EF_NONE, 0)); | 456 ui::EventTimeForNow(), ui::EF_NONE, 0)); |
458 setup.window_tree_client()->OnWindowInputEvent( | 457 setup.window_tree_client()->OnWindowInputEvent( |
459 1, server_id(root), mojom::Event::From(*ui_event.get()), 0); | 458 1, server_id(root), mojom::Event::From(*ui_event.get()), 0); |
460 EXPECT_TRUE(event_handler.received_event()); | 459 EXPECT_TRUE(event_handler.received_event()); |
461 EXPECT_TRUE(setup.window_tree()->WasEventAcked(1)); | 460 EXPECT_TRUE(setup.window_tree()->WasEventAcked(1)); |
462 event_handler.Reset(); | 461 event_handler.Reset(); |
463 | 462 |
464 event_handler.set_should_manually_ack(); | 463 event_handler.set_should_manually_ack(); |
465 setup.window_tree_client()->OnWindowInputEvent( | 464 setup.window_tree_client()->OnWindowInputEvent( |
466 33, server_id(root), mojom::Event::From(*ui_event.get()), 0); | 465 33, server_id(root), mojom::Event::From(*ui_event.get()), 0); |
467 EXPECT_TRUE(event_handler.received_event()); | 466 EXPECT_TRUE(event_handler.received_event()); |
468 EXPECT_FALSE(setup.window_tree()->WasEventAcked(33)); | 467 EXPECT_FALSE(setup.window_tree()->WasEventAcked(33)); |
469 | 468 |
470 event_handler.AckEvent(); | 469 event_handler.AckEvent(); |
471 EXPECT_TRUE(setup.window_tree()->WasEventAcked(33)); | 470 EXPECT_TRUE(setup.window_tree()->WasEventAcked(33)); |
472 } | 471 } |
473 | 472 |
474 // Tests event observers triggered by events that did not hit a target in this | 473 // Tests event observers triggered by events that did not hit a target in this |
475 // window tree. | 474 // window tree. |
476 TEST_F(WindowTreeClientImplTest, OnEventObserved) { | 475 TEST_F(WindowTreeClientTest, OnEventObserved) { |
477 WindowTreeSetup setup; | 476 WindowTreeSetup setup; |
478 Window* root = setup.GetFirstRoot(); | 477 Window* root = setup.GetFirstRoot(); |
479 ASSERT_TRUE(root); | 478 ASSERT_TRUE(root); |
480 | 479 |
481 // Set up an event observer. | 480 // Set up an event observer. |
482 mojom::EventMatcherPtr matcher = mojom::EventMatcher::New(); | 481 mojom::EventMatcherPtr matcher = mojom::EventMatcher::New(); |
483 matcher->type_matcher = mojom::EventTypeMatcher::New(); | 482 matcher->type_matcher = mojom::EventTypeMatcher::New(); |
484 matcher->type_matcher->type = mojom::EventType::POINTER_DOWN; | 483 matcher->type_matcher->type = mojom::EventType::POINTER_DOWN; |
485 setup.window_tree_connection()->SetEventObserver(std::move(matcher)); | 484 setup.client()->SetEventObserver(std::move(matcher)); |
486 | 485 |
487 // Simulate the server sending an observed event. | 486 // Simulate the server sending an observed event. |
488 uint32_t event_observer_id = setup.GetEventObserverId(); | 487 uint32_t event_observer_id = setup.GetEventObserverId(); |
489 std::unique_ptr<ui::Event> ui_event( | 488 std::unique_ptr<ui::Event> ui_event( |
490 new ui::MouseEvent(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), | 489 new ui::MouseEvent(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), |
491 ui::EventTimeForNow(), ui::EF_CONTROL_DOWN, 0)); | 490 ui::EventTimeForNow(), ui::EF_CONTROL_DOWN, 0)); |
492 setup.window_tree_client()->OnEventObserved( | 491 setup.window_tree_client()->OnEventObserved( |
493 mojom::Event::From(*ui_event.get()), event_observer_id); | 492 mojom::Event::From(*ui_event.get()), event_observer_id); |
494 | 493 |
495 // Delegate sensed the event. | 494 // Delegate sensed the event. |
496 ui::Event* last_event = setup.window_tree_delegate()->last_event_observed(); | 495 ui::Event* last_event = setup.window_tree_delegate()->last_event_observed(); |
497 EXPECT_EQ(ui::ET_MOUSE_PRESSED, last_event->type()); | 496 EXPECT_EQ(ui::ET_MOUSE_PRESSED, last_event->type()); |
498 EXPECT_EQ(ui::EF_CONTROL_DOWN, last_event->flags()); | 497 EXPECT_EQ(ui::EF_CONTROL_DOWN, last_event->flags()); |
499 setup.window_tree_delegate()->Reset(); | 498 setup.window_tree_delegate()->Reset(); |
500 | 499 |
501 // Clear the event observer. | 500 // Clear the event observer. |
502 setup.window_tree_connection()->SetEventObserver(nullptr); | 501 setup.client()->SetEventObserver(nullptr); |
503 | 502 |
504 // Simulate another event from the server. | 503 // Simulate another event from the server. |
505 setup.window_tree_client()->OnEventObserved( | 504 setup.window_tree_client()->OnEventObserved( |
506 mojom::Event::From(*ui_event.get()), event_observer_id); | 505 mojom::Event::From(*ui_event.get()), event_observer_id); |
507 | 506 |
508 // No event was sensed. | 507 // No event was sensed. |
509 EXPECT_FALSE(setup.window_tree_delegate()->last_event_observed()); | 508 EXPECT_FALSE(setup.window_tree_delegate()->last_event_observed()); |
510 } | 509 } |
511 | 510 |
512 // Tests event observers triggered by events that hit this window tree. | 511 // Tests event observers triggered by events that hit this window tree. |
513 TEST_F(WindowTreeClientImplTest, OnWindowInputEventWithEventObserver) { | 512 TEST_F(WindowTreeClientTest, OnWindowInputEventWithEventObserver) { |
514 WindowTreeSetup setup; | 513 WindowTreeSetup setup; |
515 Window* root = setup.GetFirstRoot(); | 514 Window* root = setup.GetFirstRoot(); |
516 ASSERT_TRUE(root); | 515 ASSERT_TRUE(root); |
517 | 516 |
518 // Set up an event observer. | 517 // Set up an event observer. |
519 mojom::EventMatcherPtr matcher = mojom::EventMatcher::New(); | 518 mojom::EventMatcherPtr matcher = mojom::EventMatcher::New(); |
520 matcher->type_matcher = mojom::EventTypeMatcher::New(); | 519 matcher->type_matcher = mojom::EventTypeMatcher::New(); |
521 matcher->type_matcher->type = mojom::EventType::POINTER_DOWN; | 520 matcher->type_matcher->type = mojom::EventType::POINTER_DOWN; |
522 setup.window_tree_connection()->SetEventObserver(std::move(matcher)); | 521 setup.client()->SetEventObserver(std::move(matcher)); |
523 | 522 |
524 // Simulate the server dispatching an event that also matched the observer. | 523 // Simulate the server dispatching an event that also matched the observer. |
525 uint32_t event_observer_id = setup.GetEventObserverId(); | 524 uint32_t event_observer_id = setup.GetEventObserverId(); |
526 std::unique_ptr<ui::Event> ui_event( | 525 std::unique_ptr<ui::Event> ui_event( |
527 new ui::MouseEvent(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), | 526 new ui::MouseEvent(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), |
528 ui::EventTimeForNow(), ui::EF_CONTROL_DOWN, 0)); | 527 ui::EventTimeForNow(), ui::EF_CONTROL_DOWN, 0)); |
529 setup.window_tree_client()->OnWindowInputEvent( | 528 setup.window_tree_client()->OnWindowInputEvent( |
530 1, server_id(root), mojom::Event::From(*ui_event.get()), | 529 1, server_id(root), mojom::Event::From(*ui_event.get()), |
531 event_observer_id); | 530 event_observer_id); |
532 | 531 |
533 // Delegate sensed the event. | 532 // Delegate sensed the event. |
534 ui::Event* last_event = setup.window_tree_delegate()->last_event_observed(); | 533 ui::Event* last_event = setup.window_tree_delegate()->last_event_observed(); |
535 EXPECT_EQ(ui::ET_MOUSE_PRESSED, last_event->type()); | 534 EXPECT_EQ(ui::ET_MOUSE_PRESSED, last_event->type()); |
536 EXPECT_EQ(ui::EF_CONTROL_DOWN, last_event->flags()); | 535 EXPECT_EQ(ui::EF_CONTROL_DOWN, last_event->flags()); |
537 } | 536 } |
538 | 537 |
539 // Tests that replacing an event observer with a new one results in only new | 538 // Tests that replacing an event observer with a new one results in only new |
540 // events being observed. | 539 // events being observed. |
541 TEST_F(WindowTreeClientImplTest, EventObserverReplaced) { | 540 TEST_F(WindowTreeClientTest, EventObserverReplaced) { |
542 WindowTreeSetup setup; | 541 WindowTreeSetup setup; |
543 Window* root = setup.GetFirstRoot(); | 542 Window* root = setup.GetFirstRoot(); |
544 ASSERT_TRUE(root); | 543 ASSERT_TRUE(root); |
545 | 544 |
546 // Set up an event observer. | 545 // Set up an event observer. |
547 mojom::EventMatcherPtr matcher1 = mojom::EventMatcher::New(); | 546 mojom::EventMatcherPtr matcher1 = mojom::EventMatcher::New(); |
548 matcher1->type_matcher = mojom::EventTypeMatcher::New(); | 547 matcher1->type_matcher = mojom::EventTypeMatcher::New(); |
549 matcher1->type_matcher->type = mojom::EventType::POINTER_DOWN; | 548 matcher1->type_matcher->type = mojom::EventType::POINTER_DOWN; |
550 setup.window_tree_connection()->SetEventObserver(std::move(matcher1)); | 549 setup.client()->SetEventObserver(std::move(matcher1)); |
551 uint32_t event_observer_id1 = setup.GetEventObserverId(); | 550 uint32_t event_observer_id1 = setup.GetEventObserverId(); |
552 | 551 |
553 // Replace it with a second observer. | 552 // Replace it with a second observer. |
554 mojom::EventMatcherPtr matcher2 = mojom::EventMatcher::New(); | 553 mojom::EventMatcherPtr matcher2 = mojom::EventMatcher::New(); |
555 matcher2->type_matcher = mojom::EventTypeMatcher::New(); | 554 matcher2->type_matcher = mojom::EventTypeMatcher::New(); |
556 matcher2->type_matcher->type = mojom::EventType::POINTER_UP; | 555 matcher2->type_matcher->type = mojom::EventType::POINTER_UP; |
557 setup.window_tree_connection()->SetEventObserver(std::move(matcher2)); | 556 setup.client()->SetEventObserver(std::move(matcher2)); |
558 uint32_t event_observer_id2 = setup.GetEventObserverId(); | 557 uint32_t event_observer_id2 = setup.GetEventObserverId(); |
559 | 558 |
560 // Simulate the server sending an observed event that matched the old observer | 559 // Simulate the server sending an observed event that matched the old observer |
561 // (e.g. that was in-flight when the observer was replaced). | 560 // (e.g. that was in-flight when the observer was replaced). |
562 std::unique_ptr<ui::Event> pressed_event( | 561 std::unique_ptr<ui::Event> pressed_event( |
563 new ui::MouseEvent(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), | 562 new ui::MouseEvent(ui::ET_MOUSE_PRESSED, gfx::Point(), gfx::Point(), |
564 ui::EventTimeForNow(), ui::EF_NONE, 0)); | 563 ui::EventTimeForNow(), ui::EF_NONE, 0)); |
565 setup.window_tree_client()->OnEventObserved( | 564 setup.window_tree_client()->OnEventObserved( |
566 mojom::Event::From(*pressed_event.get()), event_observer_id1); | 565 mojom::Event::From(*pressed_event.get()), event_observer_id1); |
567 | 566 |
568 // The event was not sensed, because it does not match the current observer. | 567 // The event was not sensed, because it does not match the current observer. |
569 EXPECT_FALSE(setup.window_tree_delegate()->last_event_observed()); | 568 EXPECT_FALSE(setup.window_tree_delegate()->last_event_observed()); |
570 | 569 |
571 // Simulate another event that matches the new observer. | 570 // Simulate another event that matches the new observer. |
572 std::unique_ptr<ui::Event> released_event( | 571 std::unique_ptr<ui::Event> released_event( |
573 new ui::MouseEvent(ui::ET_MOUSE_RELEASED, gfx::Point(), gfx::Point(), | 572 new ui::MouseEvent(ui::ET_MOUSE_RELEASED, gfx::Point(), gfx::Point(), |
574 ui::EventTimeForNow(), ui::EF_CONTROL_DOWN, 0)); | 573 ui::EventTimeForNow(), ui::EF_CONTROL_DOWN, 0)); |
575 setup.window_tree_client()->OnEventObserved( | 574 setup.window_tree_client()->OnEventObserved( |
576 mojom::Event::From(*released_event.get()), event_observer_id2); | 575 mojom::Event::From(*released_event.get()), event_observer_id2); |
577 | 576 |
578 // The delegate sensed the event. | 577 // The delegate sensed the event. |
579 ui::Event* last_event = setup.window_tree_delegate()->last_event_observed(); | 578 ui::Event* last_event = setup.window_tree_delegate()->last_event_observed(); |
580 EXPECT_EQ(ui::ET_MOUSE_RELEASED, last_event->type()); | 579 EXPECT_EQ(ui::ET_MOUSE_RELEASED, last_event->type()); |
581 EXPECT_EQ(ui::EF_CONTROL_DOWN, last_event->flags()); | 580 EXPECT_EQ(ui::EF_CONTROL_DOWN, last_event->flags()); |
582 } | 581 } |
583 | 582 |
584 // Verifies focus is reverted if the server replied that the change failed. | 583 // Verifies focus is reverted if the server replied that the change failed. |
585 TEST_F(WindowTreeClientImplTest, SetFocusFailed) { | 584 TEST_F(WindowTreeClientTest, SetFocusFailed) { |
586 WindowTreeSetup setup; | 585 WindowTreeSetup setup; |
587 Window* root = setup.GetFirstRoot(); | 586 Window* root = setup.GetFirstRoot(); |
588 ASSERT_TRUE(root); | 587 ASSERT_TRUE(root); |
589 root->SetVisible(true); | 588 root->SetVisible(true); |
590 Window* child = setup.window_tree_connection()->NewWindow(); | 589 Window* child = setup.client()->NewWindow(); |
591 child->SetVisible(true); | 590 child->SetVisible(true); |
592 root->AddChild(child); | 591 root->AddChild(child); |
593 Window* original_focus = setup.window_tree_connection()->GetFocusedWindow(); | 592 Window* original_focus = setup.client()->GetFocusedWindow(); |
594 Window* new_focus = child; | 593 Window* new_focus = child; |
595 ASSERT_NE(new_focus, original_focus); | 594 ASSERT_NE(new_focus, original_focus); |
596 new_focus->SetFocus(); | 595 new_focus->SetFocus(); |
597 ASSERT_TRUE(new_focus->HasFocus()); | 596 ASSERT_TRUE(new_focus->HasFocus()); |
598 uint32_t change_id; | 597 uint32_t change_id; |
599 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 598 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
600 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 599 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
601 EXPECT_EQ(original_focus, setup.window_tree_connection()->GetFocusedWindow()); | 600 EXPECT_EQ(original_focus, setup.client()->GetFocusedWindow()); |
602 } | 601 } |
603 | 602 |
604 // Simulates a focus change, and while the focus change is in flight the server | 603 // Simulates a focus change, and while the focus change is in flight the server |
605 // replies with a new focus and the original focus change fails. | 604 // replies with a new focus and the original focus change fails. |
606 TEST_F(WindowTreeClientImplTest, SetFocusFailedWithPendingChange) { | 605 TEST_F(WindowTreeClientTest, SetFocusFailedWithPendingChange) { |
607 WindowTreeSetup setup; | 606 WindowTreeSetup setup; |
608 Window* root = setup.GetFirstRoot(); | 607 Window* root = setup.GetFirstRoot(); |
609 ASSERT_TRUE(root); | 608 ASSERT_TRUE(root); |
610 root->SetVisible(true); | 609 root->SetVisible(true); |
611 Window* child1 = setup.window_tree_connection()->NewWindow(); | 610 Window* child1 = setup.client()->NewWindow(); |
612 child1->SetVisible(true); | 611 child1->SetVisible(true); |
613 root->AddChild(child1); | 612 root->AddChild(child1); |
614 Window* child2 = setup.window_tree_connection()->NewWindow(); | 613 Window* child2 = setup.client()->NewWindow(); |
615 child2->SetVisible(true); | 614 child2->SetVisible(true); |
616 root->AddChild(child2); | 615 root->AddChild(child2); |
617 Window* original_focus = setup.window_tree_connection()->GetFocusedWindow(); | 616 Window* original_focus = setup.client()->GetFocusedWindow(); |
618 Window* new_focus = child1; | 617 Window* new_focus = child1; |
619 ASSERT_NE(new_focus, original_focus); | 618 ASSERT_NE(new_focus, original_focus); |
620 new_focus->SetFocus(); | 619 new_focus->SetFocus(); |
621 ASSERT_TRUE(new_focus->HasFocus()); | 620 ASSERT_TRUE(new_focus->HasFocus()); |
622 uint32_t change_id; | 621 uint32_t change_id; |
623 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 622 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
624 | 623 |
625 // Simulate the server responding with a focus change. | 624 // Simulate the server responding with a focus change. |
626 setup.window_tree_client()->OnWindowFocused(server_id(child2)); | 625 setup.window_tree_client()->OnWindowFocused(server_id(child2)); |
627 | 626 |
628 // This shouldn't trigger focus changing yet. | 627 // This shouldn't trigger focus changing yet. |
629 EXPECT_TRUE(child1->HasFocus()); | 628 EXPECT_TRUE(child1->HasFocus()); |
630 | 629 |
631 // Tell the client the change failed, which should trigger failing to the | 630 // Tell the client the change failed, which should trigger failing to the |
632 // most recent focus from server. | 631 // most recent focus from server. |
633 setup.window_tree_client()->OnChangeCompleted(change_id, false); | 632 setup.window_tree_client()->OnChangeCompleted(change_id, false); |
634 EXPECT_FALSE(child1->HasFocus()); | 633 EXPECT_FALSE(child1->HasFocus()); |
635 EXPECT_TRUE(child2->HasFocus()); | 634 EXPECT_TRUE(child2->HasFocus()); |
636 EXPECT_EQ(child2, setup.window_tree_connection()->GetFocusedWindow()); | 635 EXPECT_EQ(child2, setup.client()->GetFocusedWindow()); |
637 | 636 |
638 // Simulate server changing focus to child1. Should take immediately. | 637 // Simulate server changing focus to child1. Should take immediately. |
639 setup.window_tree_client()->OnWindowFocused(server_id(child1)); | 638 setup.window_tree_client()->OnWindowFocused(server_id(child1)); |
640 EXPECT_TRUE(child1->HasFocus()); | 639 EXPECT_TRUE(child1->HasFocus()); |
641 } | 640 } |
642 | 641 |
643 TEST_F(WindowTreeClientImplTest, FocusOnRemovedWindowWithInFlightFocusChange) { | 642 TEST_F(WindowTreeClientTest, FocusOnRemovedWindowWithInFlightFocusChange) { |
644 WindowTreeSetup setup; | 643 WindowTreeSetup setup; |
645 Window* root = setup.GetFirstRoot(); | 644 Window* root = setup.GetFirstRoot(); |
646 ASSERT_TRUE(root); | 645 ASSERT_TRUE(root); |
647 root->SetVisible(true); | 646 root->SetVisible(true); |
648 Window* child1 = setup.window_tree_connection()->NewWindow(); | 647 Window* child1 = setup.client()->NewWindow(); |
649 child1->SetVisible(true); | 648 child1->SetVisible(true); |
650 root->AddChild(child1); | 649 root->AddChild(child1); |
651 Window* child2 = setup.window_tree_connection()->NewWindow(); | 650 Window* child2 = setup.client()->NewWindow(); |
652 child2->SetVisible(true); | 651 child2->SetVisible(true); |
653 root->AddChild(child2); | 652 root->AddChild(child2); |
654 | 653 |
655 child1->SetFocus(); | 654 child1->SetFocus(); |
656 uint32_t change_id; | 655 uint32_t change_id; |
657 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 656 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
658 | 657 |
659 // Destroy child1, which should set focus to null. | 658 // Destroy child1, which should set focus to null. |
660 child1->Destroy(); | 659 child1->Destroy(); |
661 EXPECT_EQ(nullptr, setup.window_tree_connection()->GetFocusedWindow()); | 660 EXPECT_EQ(nullptr, setup.client()->GetFocusedWindow()); |
662 | 661 |
663 // Server changes focus to 2. | 662 // Server changes focus to 2. |
664 setup.window_tree_client()->OnWindowFocused(server_id(child2)); | 663 setup.window_tree_client()->OnWindowFocused(server_id(child2)); |
665 // Shouldn't take immediately. | 664 // Shouldn't take immediately. |
666 EXPECT_FALSE(child2->HasFocus()); | 665 EXPECT_FALSE(child2->HasFocus()); |
667 | 666 |
668 // Ack the change, focus should still be null. | 667 // Ack the change, focus should still be null. |
669 setup.window_tree_client()->OnChangeCompleted(change_id, true); | 668 setup.window_tree_client()->OnChangeCompleted(change_id, true); |
670 EXPECT_EQ(nullptr, setup.window_tree_connection()->GetFocusedWindow()); | 669 EXPECT_EQ(nullptr, setup.client()->GetFocusedWindow()); |
671 | 670 |
672 // Change to 2 again, this time it should take. | 671 // Change to 2 again, this time it should take. |
673 setup.window_tree_client()->OnWindowFocused(server_id(child2)); | 672 setup.window_tree_client()->OnWindowFocused(server_id(child2)); |
674 EXPECT_TRUE(child2->HasFocus()); | 673 EXPECT_TRUE(child2->HasFocus()); |
675 } | 674 } |
676 | 675 |
677 class ToggleVisibilityFromDestroyedObserver : public WindowObserver { | 676 class ToggleVisibilityFromDestroyedObserver : public WindowObserver { |
678 public: | 677 public: |
679 explicit ToggleVisibilityFromDestroyedObserver(Window* window) | 678 explicit ToggleVisibilityFromDestroyedObserver(Window* window) |
680 : window_(window) { | 679 : window_(window) { |
681 window_->AddObserver(this); | 680 window_->AddObserver(this); |
682 } | 681 } |
683 | 682 |
684 ToggleVisibilityFromDestroyedObserver() { EXPECT_FALSE(window_); } | 683 ToggleVisibilityFromDestroyedObserver() { EXPECT_FALSE(window_); } |
685 | 684 |
686 // WindowObserver: | 685 // WindowObserver: |
687 void OnWindowDestroyed(Window* window) override { | 686 void OnWindowDestroyed(Window* window) override { |
688 window_->SetVisible(!window->visible()); | 687 window_->SetVisible(!window->visible()); |
689 window_->RemoveObserver(this); | 688 window_->RemoveObserver(this); |
690 window_ = nullptr; | 689 window_ = nullptr; |
691 } | 690 } |
692 | 691 |
693 private: | 692 private: |
694 Window* window_; | 693 Window* window_; |
695 | 694 |
696 DISALLOW_COPY_AND_ASSIGN(ToggleVisibilityFromDestroyedObserver); | 695 DISALLOW_COPY_AND_ASSIGN(ToggleVisibilityFromDestroyedObserver); |
697 }; | 696 }; |
698 | 697 |
699 TEST_F(WindowTreeClientImplTest, ToggleVisibilityFromWindowDestroyed) { | 698 TEST_F(WindowTreeClientTest, ToggleVisibilityFromWindowDestroyed) { |
700 WindowTreeSetup setup; | 699 WindowTreeSetup setup; |
701 Window* root = setup.GetFirstRoot(); | 700 Window* root = setup.GetFirstRoot(); |
702 ASSERT_TRUE(root); | 701 ASSERT_TRUE(root); |
703 Window* child1 = setup.window_tree_connection()->NewWindow(); | 702 Window* child1 = setup.client()->NewWindow(); |
704 root->AddChild(child1); | 703 root->AddChild(child1); |
705 ToggleVisibilityFromDestroyedObserver toggler(child1); | 704 ToggleVisibilityFromDestroyedObserver toggler(child1); |
706 // Destroying the window triggers | 705 // Destroying the window triggers |
707 // ToggleVisibilityFromDestroyedObserver::OnWindowDestroyed(), which toggles | 706 // ToggleVisibilityFromDestroyedObserver::OnWindowDestroyed(), which toggles |
708 // the visibility of the window. Ack the change, which should not crash or | 707 // the visibility of the window. Ack the change, which should not crash or |
709 // trigger DCHECKs. | 708 // trigger DCHECKs. |
710 child1->Destroy(); | 709 child1->Destroy(); |
711 uint32_t change_id; | 710 uint32_t change_id; |
712 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 711 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
713 setup.window_tree_client()->OnChangeCompleted(change_id, true); | 712 setup.window_tree_client()->OnChangeCompleted(change_id, true); |
714 } | 713 } |
715 | 714 |
716 TEST_F(WindowTreeClientImplTest, NewTopLevelWindow) { | 715 TEST_F(WindowTreeClientTest, NewTopLevelWindow) { |
717 WindowTreeSetup setup; | 716 WindowTreeSetup setup; |
718 Window* root1 = setup.GetFirstRoot(); | 717 Window* root1 = setup.GetFirstRoot(); |
719 ASSERT_TRUE(root1); | 718 ASSERT_TRUE(root1); |
720 Window* root2 = setup.window_tree_connection()->NewTopLevelWindow(nullptr); | 719 Window* root2 = setup.client()->NewTopLevelWindow(nullptr); |
721 ASSERT_TRUE(root2); | 720 ASSERT_TRUE(root2); |
722 EXPECT_TRUE(WindowPrivate(root2).parent_drawn()); | 721 EXPECT_TRUE(WindowPrivate(root2).parent_drawn()); |
723 ASSERT_NE(root2, root1); | 722 ASSERT_NE(root2, root1); |
724 EXPECT_NE(server_id(root2), server_id(root1)); | 723 EXPECT_NE(server_id(root2), server_id(root1)); |
725 EXPECT_EQ(2u, setup.window_tree_connection()->GetRoots().size()); | 724 EXPECT_EQ(2u, setup.client()->GetRoots().size()); |
726 EXPECT_TRUE(setup.window_tree_connection()->GetRoots().count(root1) > 0u); | 725 EXPECT_TRUE(setup.client()->GetRoots().count(root1) > 0u); |
727 EXPECT_TRUE(setup.window_tree_connection()->GetRoots().count(root2) > 0u); | 726 EXPECT_TRUE(setup.client()->GetRoots().count(root2) > 0u); |
728 | 727 |
729 // Ack the request to the windowtree to create the new window. | 728 // Ack the request to the windowtree to create the new window. |
730 uint32_t change_id; | 729 uint32_t change_id; |
731 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 730 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
732 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); | 731 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); |
733 | 732 |
734 mojom::WindowDataPtr data = mojom::WindowData::New(); | 733 mojom::WindowDataPtr data = mojom::WindowData::New(); |
735 data->window_id = server_id(root2); | 734 data->window_id = server_id(root2); |
736 data->display_id = 1; | 735 data->display_id = 1; |
737 setup.window_tree_client()->OnTopLevelCreated(change_id, std::move(data), | 736 setup.window_tree_client()->OnTopLevelCreated(change_id, std::move(data), |
738 false); | 737 false); |
739 | 738 |
740 EXPECT_FALSE(WindowPrivate(root2).parent_drawn()); | 739 EXPECT_FALSE(WindowPrivate(root2).parent_drawn()); |
741 | 740 |
742 // Should not be able to add a top level as a child of another window. | 741 // Should not be able to add a top level as a child of another window. |
743 root1->AddChild(root2); | 742 root1->AddChild(root2); |
744 ASSERT_EQ(nullptr, root2->parent()); | 743 ASSERT_EQ(nullptr, root2->parent()); |
745 | 744 |
746 // Destroy the first root, shouldn't initiate tear down. | 745 // Destroy the first root, shouldn't initiate tear down. |
747 root1->Destroy(); | 746 root1->Destroy(); |
748 root1 = nullptr; | 747 root1 = nullptr; |
749 EXPECT_EQ(1u, setup.window_tree_connection()->GetRoots().size()); | 748 EXPECT_EQ(1u, setup.client()->GetRoots().size()); |
750 EXPECT_TRUE(setup.window_tree_connection()->GetRoots().count(root2) > 0u); | 749 EXPECT_TRUE(setup.client()->GetRoots().count(root2) > 0u); |
751 } | 750 } |
752 | 751 |
753 TEST_F(WindowTreeClientImplTest, NewTopLevelWindowGetsPropertiesFromData) { | 752 TEST_F(WindowTreeClientTest, NewTopLevelWindowGetsPropertiesFromData) { |
754 WindowTreeSetup setup; | 753 WindowTreeSetup setup; |
755 Window* root1 = setup.GetFirstRoot(); | 754 Window* root1 = setup.GetFirstRoot(); |
756 ASSERT_TRUE(root1); | 755 ASSERT_TRUE(root1); |
757 Window* root2 = setup.window_tree_connection()->NewTopLevelWindow(nullptr); | 756 Window* root2 = setup.client()->NewTopLevelWindow(nullptr); |
758 ASSERT_TRUE(root2); | 757 ASSERT_TRUE(root2); |
759 | 758 |
760 EXPECT_FALSE(root2->IsDrawn()); | 759 EXPECT_FALSE(root2->IsDrawn()); |
761 EXPECT_FALSE(root2->visible()); | 760 EXPECT_FALSE(root2->visible()); |
762 | 761 |
763 // Ack the request to the windowtree to create the new window. | 762 // Ack the request to the windowtree to create the new window. |
764 uint32_t change_id; | 763 uint32_t change_id; |
765 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 764 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
766 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); | 765 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); |
767 | 766 |
768 mojom::WindowDataPtr data = mojom::WindowData::New(); | 767 mojom::WindowDataPtr data = mojom::WindowData::New(); |
769 data->window_id = server_id(root2); | 768 data->window_id = server_id(root2); |
770 data->display_id = 1; | 769 data->display_id = 1; |
771 data->bounds = mojo::Rect::From(gfx::Rect(1, 2, 3, 4)); | 770 data->bounds = mojo::Rect::From(gfx::Rect(1, 2, 3, 4)); |
772 data->visible = true; | 771 data->visible = true; |
773 setup.window_tree_client()->OnTopLevelCreated(change_id, std::move(data), | 772 setup.window_tree_client()->OnTopLevelCreated(change_id, std::move(data), |
774 true); | 773 true); |
775 | 774 |
776 // Make sure all the properties took. | 775 // Make sure all the properties took. |
777 EXPECT_TRUE(root2->IsDrawn()); | 776 EXPECT_TRUE(root2->IsDrawn()); |
778 EXPECT_TRUE(root2->visible()); | 777 EXPECT_TRUE(root2->visible()); |
779 EXPECT_EQ(1, root2->display_id()); | 778 EXPECT_EQ(1, root2->display_id()); |
780 EXPECT_EQ(gfx::Rect(1, 2, 3, 4), root2->bounds()); | 779 EXPECT_EQ(gfx::Rect(1, 2, 3, 4), root2->bounds()); |
781 } | 780 } |
782 | 781 |
783 TEST_F(WindowTreeClientImplTest, NewTopLevelWindowGetsAllChangesInFlight) { | 782 TEST_F(WindowTreeClientTest, NewTopLevelWindowGetsAllChangesInFlight) { |
784 WindowTreeSetup setup; | 783 WindowTreeSetup setup; |
785 Window* root1 = setup.GetFirstRoot(); | 784 Window* root1 = setup.GetFirstRoot(); |
786 ASSERT_TRUE(root1); | 785 ASSERT_TRUE(root1); |
787 Window* root2 = setup.window_tree_connection()->NewTopLevelWindow(nullptr); | 786 Window* root2 = setup.client()->NewTopLevelWindow(nullptr); |
788 ASSERT_TRUE(root2); | 787 ASSERT_TRUE(root2); |
789 | 788 |
790 EXPECT_FALSE(root2->IsDrawn()); | 789 EXPECT_FALSE(root2->IsDrawn()); |
791 EXPECT_FALSE(root2->visible()); | 790 EXPECT_FALSE(root2->visible()); |
792 | 791 |
793 // Get the id of the in flight change for creating the new window. | 792 // Get the id of the in flight change for creating the new window. |
794 uint32_t new_window_in_flight_change_id; | 793 uint32_t new_window_in_flight_change_id; |
795 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId( | 794 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId( |
796 &new_window_in_flight_change_id)); | 795 &new_window_in_flight_change_id)); |
797 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); | 796 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
859 false); | 858 false); |
860 EXPECT_EQ(2u, root2->shared_properties().size()); | 859 EXPECT_EQ(2u, root2->shared_properties().size()); |
861 ASSERT_TRUE(root2->HasSharedProperty("yy")); | 860 ASSERT_TRUE(root2->HasSharedProperty("yy")); |
862 EXPECT_EQ("server_yy", root2->GetSharedProperty<std::string>("yy")); | 861 EXPECT_EQ("server_yy", root2->GetSharedProperty<std::string>("yy")); |
863 ASSERT_TRUE(root2->HasSharedProperty("xx")); | 862 ASSERT_TRUE(root2->HasSharedProperty("xx")); |
864 EXPECT_EQ("server_xx", root2->GetSharedProperty<std::string>("xx")); | 863 EXPECT_EQ("server_xx", root2->GetSharedProperty<std::string>("xx")); |
865 } | 864 } |
866 | 865 |
867 // Tests that if the client has multiple unowned windows, and one of them is a | 866 // Tests that if the client has multiple unowned windows, and one of them is a |
868 // transient child to another, the teardown can happen cleanly. | 867 // transient child to another, the teardown can happen cleanly. |
869 TEST_F(WindowTreeClientImplTest, MultipleUnOwnedWindowsDuringDestruction) { | 868 TEST_F(WindowTreeClientTest, MultipleUnOwnedWindowsDuringDestruction) { |
870 std::unique_ptr<WindowTreeSetup> setup(new WindowTreeSetup()); | 869 std::unique_ptr<WindowTreeSetup> setup(new WindowTreeSetup()); |
871 Window* root1 = setup->GetFirstRoot(); | 870 Window* root1 = setup->GetFirstRoot(); |
872 ASSERT_TRUE(root1); | 871 ASSERT_TRUE(root1); |
873 Window* root2 = setup->window_tree_connection()->NewTopLevelWindow(nullptr); | 872 Window* root2 = setup->client()->NewTopLevelWindow(nullptr); |
874 ASSERT_TRUE(root2); | 873 ASSERT_TRUE(root2); |
875 root1->AddTransientWindow(root2); | 874 root1->AddTransientWindow(root2); |
876 | 875 |
877 WindowTracker tracker; | 876 WindowTracker tracker; |
878 tracker.Add(root1); | 877 tracker.Add(root1); |
879 tracker.Add(root2); | 878 tracker.Add(root2); |
880 setup.reset(); | 879 setup.reset(); |
881 EXPECT_TRUE(tracker.windows().empty()); | 880 EXPECT_TRUE(tracker.windows().empty()); |
882 } | 881 } |
883 | 882 |
884 TEST_F(WindowTreeClientImplTest, TopLevelWindowDestroyedBeforeCreateComplete) { | 883 TEST_F(WindowTreeClientTest, TopLevelWindowDestroyedBeforeCreateComplete) { |
885 WindowTreeSetup setup; | 884 WindowTreeSetup setup; |
886 Window* root1 = setup.GetFirstRoot(); | 885 Window* root1 = setup.GetFirstRoot(); |
887 ASSERT_TRUE(root1); | 886 ASSERT_TRUE(root1); |
888 Window* root2 = setup.window_tree_connection()->NewTopLevelWindow(nullptr); | 887 Window* root2 = setup.client()->NewTopLevelWindow(nullptr); |
889 ASSERT_TRUE(root2); | 888 ASSERT_TRUE(root2); |
890 ASSERT_EQ(2u, setup.window_tree_connection()->GetRoots().size()); | 889 ASSERT_EQ(2u, setup.client()->GetRoots().size()); |
891 | 890 |
892 // Get the id of the in flight change for creating the new window. | 891 // Get the id of the in flight change for creating the new window. |
893 uint32_t change_id; | 892 uint32_t change_id; |
894 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); | 893 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id)); |
895 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); | 894 EXPECT_EQ(setup.window_tree()->window_id(), server_id(root2)); |
896 | 895 |
897 mojom::WindowDataPtr data = mojom::WindowData::New(); | 896 mojom::WindowDataPtr data = mojom::WindowData::New(); |
898 data->window_id = server_id(root2); | 897 data->window_id = server_id(root2); |
899 data->display_id = 1; | 898 data->display_id = 1; |
900 | 899 |
901 // Destroy the window before the server has a chance to ack the window | 900 // Destroy the window before the server has a chance to ack the window |
902 // creation. | 901 // creation. |
903 root2->Destroy(); | 902 root2->Destroy(); |
904 EXPECT_EQ(1u, setup.window_tree_connection()->GetRoots().size()); | 903 EXPECT_EQ(1u, setup.client()->GetRoots().size()); |
905 | 904 |
906 setup.window_tree_client()->OnTopLevelCreated(change_id, std::move(data), | 905 setup.window_tree_client()->OnTopLevelCreated(change_id, std::move(data), |
907 true); | 906 true); |
908 EXPECT_EQ(1u, setup.window_tree_connection()->GetRoots().size()); | 907 EXPECT_EQ(1u, setup.client()->GetRoots().size()); |
909 } | 908 } |
910 | 909 |
911 // Tests both SetCapture and ReleaseCapture, to ensure that Window is properly | 910 // Tests both SetCapture and ReleaseCapture, to ensure that Window is properly |
912 // updated on failures. | 911 // updated on failures. |
913 TEST_F(WindowTreeClientImplTest, ExplicitCapture) { | 912 TEST_F(WindowTreeClientTest, ExplicitCapture) { |
914 WindowTreeSetup setup; | 913 WindowTreeSetup setup; |
915 Window* root = setup.GetFirstRoot(); | 914 Window* root = setup.GetFirstRoot(); |
916 ASSERT_TRUE(root); | 915 ASSERT_TRUE(root); |
917 | 916 |
918 root->SetCapture(); | 917 root->SetCapture(); |
919 EXPECT_TRUE(root->HasCapture()); | 918 EXPECT_TRUE(root->HasCapture()); |
920 uint32_t change_id1; | 919 uint32_t change_id1; |
921 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); | 920 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); |
922 setup.window_tree_client()->OnChangeCompleted(change_id1, false); | 921 setup.window_tree_client()->OnChangeCompleted(change_id1, false); |
923 EXPECT_FALSE(root->HasCapture()); | 922 EXPECT_FALSE(root->HasCapture()); |
(...skipping 13 matching lines...) Expand all Loading... |
937 EXPECT_TRUE(root->HasCapture()); | 936 EXPECT_TRUE(root->HasCapture()); |
938 | 937 |
939 root->ReleaseCapture(); | 938 root->ReleaseCapture(); |
940 uint32_t change_id4; | 939 uint32_t change_id4; |
941 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id4)); | 940 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id4)); |
942 setup.window_tree_client()->OnChangeCompleted(change_id4, true); | 941 setup.window_tree_client()->OnChangeCompleted(change_id4, true); |
943 EXPECT_FALSE(root->HasCapture()); | 942 EXPECT_FALSE(root->HasCapture()); |
944 } | 943 } |
945 | 944 |
946 // Tests that when capture is lost, that the window tree updates properly. | 945 // Tests that when capture is lost, that the window tree updates properly. |
947 TEST_F(WindowTreeClientImplTest, LostCapture) { | 946 TEST_F(WindowTreeClientTest, LostCapture) { |
948 WindowTreeSetup setup; | 947 WindowTreeSetup setup; |
949 Window* root = setup.GetFirstRoot(); | 948 Window* root = setup.GetFirstRoot(); |
950 ASSERT_TRUE(root); | 949 ASSERT_TRUE(root); |
951 | 950 |
952 root->SetCapture(); | 951 root->SetCapture(); |
953 EXPECT_TRUE(root->HasCapture()); | 952 EXPECT_TRUE(root->HasCapture()); |
954 uint32_t change_id1; | 953 uint32_t change_id1; |
955 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); | 954 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); |
956 setup.window_tree_client()->OnChangeCompleted(change_id1, true); | 955 setup.window_tree_client()->OnChangeCompleted(change_id1, true); |
957 EXPECT_TRUE(root->HasCapture()); | 956 EXPECT_TRUE(root->HasCapture()); |
958 | 957 |
959 // The second SetCapture should be ignored. | 958 // The second SetCapture should be ignored. |
960 root->SetCapture(); | 959 root->SetCapture(); |
961 uint32_t change_id2; | 960 uint32_t change_id2; |
962 ASSERT_FALSE(setup.window_tree()->GetAndClearChangeId(&change_id2)); | 961 ASSERT_FALSE(setup.window_tree()->GetAndClearChangeId(&change_id2)); |
963 | 962 |
964 setup.window_tree_client()->OnLostCapture(server_id(root)); | 963 setup.window_tree_client()->OnLostCapture(server_id(root)); |
965 EXPECT_FALSE(root->HasCapture()); | 964 EXPECT_FALSE(root->HasCapture()); |
966 } | 965 } |
967 | 966 |
968 // Tests that when capture is lost, while there is a release capture request | 967 // Tests that when capture is lost, while there is a release capture request |
969 // inflight, that the revert value of that request is updated correctly. | 968 // inflight, that the revert value of that request is updated correctly. |
970 TEST_F(WindowTreeClientImplTest, LostCaptureDifferentInFlightChange) { | 969 TEST_F(WindowTreeClientTest, LostCaptureDifferentInFlightChange) { |
971 WindowTreeSetup setup; | 970 WindowTreeSetup setup; |
972 Window* root = setup.GetFirstRoot(); | 971 Window* root = setup.GetFirstRoot(); |
973 ASSERT_TRUE(root); | 972 ASSERT_TRUE(root); |
974 | 973 |
975 root->SetCapture(); | 974 root->SetCapture(); |
976 EXPECT_TRUE(root->HasCapture()); | 975 EXPECT_TRUE(root->HasCapture()); |
977 uint32_t change_id1; | 976 uint32_t change_id1; |
978 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); | 977 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); |
979 setup.window_tree_client()->OnChangeCompleted(change_id1, true); | 978 setup.window_tree_client()->OnChangeCompleted(change_id1, true); |
980 EXPECT_TRUE(root->HasCapture()); | 979 EXPECT_TRUE(root->HasCapture()); |
981 | 980 |
982 // The ReleaseCapture should be updated to the revert of the SetCapture. | 981 // The ReleaseCapture should be updated to the revert of the SetCapture. |
983 root->ReleaseCapture(); | 982 root->ReleaseCapture(); |
984 uint32_t change_id2; | 983 uint32_t change_id2; |
985 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id2)); | 984 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id2)); |
986 | 985 |
987 setup.window_tree_client()->OnLostCapture(server_id(root)); | 986 setup.window_tree_client()->OnLostCapture(server_id(root)); |
988 EXPECT_FALSE(root->HasCapture()); | 987 EXPECT_FALSE(root->HasCapture()); |
989 | 988 |
990 setup.window_tree_client()->OnChangeCompleted(change_id2, false); | 989 setup.window_tree_client()->OnChangeCompleted(change_id2, false); |
991 EXPECT_FALSE(root->HasCapture()); | 990 EXPECT_FALSE(root->HasCapture()); |
992 } | 991 } |
993 | 992 |
994 // Tests that while two windows can inflight capture requests, that the | 993 // Tests that while two windows can inflight capture requests, that the |
995 // WindowTreeClient only identifies one as having the current capture. | 994 // WindowTreeClient only identifies one as having the current capture. |
996 TEST_F(WindowTreeClientImplTest, TwoWindowsRequestCapture) { | 995 TEST_F(WindowTreeClientTest, TwoWindowsRequestCapture) { |
997 WindowTreeSetup setup; | 996 WindowTreeSetup setup; |
998 Window* root = setup.GetFirstRoot(); | 997 Window* root = setup.GetFirstRoot(); |
999 Window* child = setup.window_tree_connection()->NewWindow(); | 998 Window* child = setup.client()->NewWindow(); |
1000 child->SetVisible(true); | 999 child->SetVisible(true); |
1001 root->AddChild(child); | 1000 root->AddChild(child); |
1002 | 1001 |
1003 root->SetCapture(); | 1002 root->SetCapture(); |
1004 EXPECT_TRUE(root->HasCapture()); | 1003 EXPECT_TRUE(root->HasCapture()); |
1005 uint32_t change_id1; | 1004 uint32_t change_id1; |
1006 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); | 1005 ASSERT_TRUE(setup.window_tree()->GetAndClearChangeId(&change_id1)); |
1007 | 1006 |
1008 child->SetCapture(); | 1007 child->SetCapture(); |
1009 EXPECT_TRUE(child->HasCapture()); | 1008 EXPECT_TRUE(child->HasCapture()); |
(...skipping 10 matching lines...) Expand all Loading... |
1020 EXPECT_FALSE(child->HasCapture()); | 1019 EXPECT_FALSE(child->HasCapture()); |
1021 EXPECT_TRUE(root->HasCapture()); | 1020 EXPECT_TRUE(root->HasCapture()); |
1022 | 1021 |
1023 setup.window_tree_client()->OnLostCapture(server_id(root)); | 1022 setup.window_tree_client()->OnLostCapture(server_id(root)); |
1024 EXPECT_FALSE(root->HasCapture()); | 1023 EXPECT_FALSE(root->HasCapture()); |
1025 } | 1024 } |
1026 | 1025 |
1027 TEST_F(WindowTreeClientImplTest, WindowDestroyedWhileTransientChildHasCapture) { | 1026 TEST_F(WindowTreeClientImplTest, WindowDestroyedWhileTransientChildHasCapture) { |
1028 WindowTreeSetup setup; | 1027 WindowTreeSetup setup; |
1029 Window* root = setup.GetFirstRoot(); | 1028 Window* root = setup.GetFirstRoot(); |
1030 Window* transient_parent = setup.window_tree_connection()->NewWindow(); | 1029 Window* transient_parent = setup.window_tree_client()->NewWindow(); |
1031 Window* transient_child = setup.window_tree_connection()->NewWindow(); | 1030 Window* transient_child = setup.window_tree_client()->NewWindow(); |
1032 transient_parent->SetVisible(true); | 1031 transient_parent->SetVisible(true); |
1033 transient_child->SetVisible(true); | 1032 transient_child->SetVisible(true); |
1034 root->AddChild(transient_parent); | 1033 root->AddChild(transient_parent); |
1035 root->AddChild(transient_child); | 1034 root->AddChild(transient_child); |
1036 | 1035 |
1037 transient_parent->AddTransientWindow(transient_child); | 1036 transient_parent->AddTransientWindow(transient_child); |
1038 | 1037 |
1039 WindowTracker tracker; | 1038 WindowTracker tracker; |
1040 tracker.Add(transient_parent); | 1039 tracker.Add(transient_parent); |
1041 tracker.Add(transient_child); | 1040 tracker.Add(transient_child); |
1042 // Request a capture on the transient child, then destroy the transient | 1041 // Request a capture on the transient child, then destroy the transient |
1043 // parent. That will destroy both windows, and should reset the capture window | 1042 // parent. That will destroy both windows, and should reset the capture window |
1044 // correctly. | 1043 // correctly. |
1045 transient_child->SetCapture(); | 1044 transient_child->SetCapture(); |
1046 transient_parent->Destroy(); | 1045 transient_parent->Destroy(); |
1047 EXPECT_TRUE(tracker.windows().empty()); | 1046 EXPECT_TRUE(tracker.windows().empty()); |
1048 | 1047 |
1049 // Create a new Window, and attempt to place capture on that. | 1048 // Create a new Window, and attempt to place capture on that. |
1050 Window* child = setup.window_tree_connection()->NewWindow(); | 1049 Window* child = setup.window_tree_client()->NewWindow(); |
1051 child->SetVisible(true); | 1050 child->SetVisible(true); |
1052 root->AddChild(child); | 1051 root->AddChild(child); |
1053 child->SetCapture(); | 1052 child->SetCapture(); |
1054 EXPECT_TRUE(child->HasCapture()); | 1053 EXPECT_TRUE(child->HasCapture()); |
1055 } | 1054 } |
1056 | 1055 |
1057 } // namespace mus | 1056 } // namespace mus |
OLD | NEW |