OLD | NEW |
| (Empty) |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "components/mus/test_change_tracker.h" | |
6 | |
7 #include "base/strings/string_util.h" | |
8 #include "base/strings/stringprintf.h" | |
9 #include "components/mus/public/cpp/util.h" | |
10 #include "mojo/common/common_type_converters.h" | |
11 | |
12 using mojo::Array; | |
13 using mojo::ViewDataPtr; | |
14 using mojo::String; | |
15 | |
16 namespace mus { | |
17 | |
18 std::string ViewIdToString(Id id) { | |
19 return (id == 0) ? "null" | |
20 : base::StringPrintf("%d,%d", HiWord(id), LoWord(id)); | |
21 } | |
22 | |
23 namespace { | |
24 | |
25 std::string RectToString(const mojo::Rect& rect) { | |
26 return base::StringPrintf("%d,%d %dx%d", rect.x, rect.y, rect.width, | |
27 rect.height); | |
28 } | |
29 | |
30 std::string DirectionToString(mojo::OrderDirection direction) { | |
31 return direction == mojo::ORDER_DIRECTION_ABOVE ? "above" : "below"; | |
32 } | |
33 | |
34 std::string ChangeToDescription1(const Change& change) { | |
35 switch (change.type) { | |
36 case CHANGE_TYPE_EMBED: | |
37 return "OnEmbed"; | |
38 | |
39 case CHANGE_TYPE_EMBEDDED_APP_DISCONNECTED: | |
40 return base::StringPrintf("OnEmbeddedAppDisconnected view=%s", | |
41 ViewIdToString(change.view_id).c_str()); | |
42 | |
43 case CHANGE_TYPE_UNEMBED: | |
44 return "OnUnembed"; | |
45 | |
46 case CHANGE_TYPE_NODE_BOUNDS_CHANGED: | |
47 return base::StringPrintf( | |
48 "BoundsChanged view=%s old_bounds=%s new_bounds=%s", | |
49 ViewIdToString(change.view_id).c_str(), | |
50 RectToString(change.bounds).c_str(), | |
51 RectToString(change.bounds2).c_str()); | |
52 | |
53 case CHANGE_TYPE_NODE_VIEWPORT_METRICS_CHANGED: | |
54 // TODO(sky): Not implemented. | |
55 return "ViewportMetricsChanged"; | |
56 | |
57 case CHANGE_TYPE_NODE_HIERARCHY_CHANGED: | |
58 return base::StringPrintf( | |
59 "HierarchyChanged view=%s new_parent=%s old_parent=%s", | |
60 ViewIdToString(change.view_id).c_str(), | |
61 ViewIdToString(change.view_id2).c_str(), | |
62 ViewIdToString(change.view_id3).c_str()); | |
63 | |
64 case CHANGE_TYPE_NODE_REORDERED: | |
65 return base::StringPrintf("Reordered view=%s relative=%s direction=%s", | |
66 ViewIdToString(change.view_id).c_str(), | |
67 ViewIdToString(change.view_id2).c_str(), | |
68 DirectionToString(change.direction).c_str()); | |
69 | |
70 case CHANGE_TYPE_NODE_DELETED: | |
71 return base::StringPrintf("ViewDeleted view=%s", | |
72 ViewIdToString(change.view_id).c_str()); | |
73 | |
74 case CHANGE_TYPE_NODE_VISIBILITY_CHANGED: | |
75 return base::StringPrintf("VisibilityChanged view=%s visible=%s", | |
76 ViewIdToString(change.view_id).c_str(), | |
77 change.bool_value ? "true" : "false"); | |
78 | |
79 case CHANGE_TYPE_NODE_DRAWN_STATE_CHANGED: | |
80 return base::StringPrintf("DrawnStateChanged view=%s drawn=%s", | |
81 ViewIdToString(change.view_id).c_str(), | |
82 change.bool_value ? "true" : "false"); | |
83 | |
84 case CHANGE_TYPE_INPUT_EVENT: | |
85 return base::StringPrintf("InputEvent view=%s event_action=%d", | |
86 ViewIdToString(change.view_id).c_str(), | |
87 change.event_action); | |
88 | |
89 case CHANGE_TYPE_PROPERTY_CHANGED: | |
90 return base::StringPrintf("PropertyChanged view=%s key=%s value=%s", | |
91 ViewIdToString(change.view_id).c_str(), | |
92 change.property_key.c_str(), | |
93 change.property_value.c_str()); | |
94 | |
95 case CHANGE_TYPE_DELEGATE_EMBED: | |
96 return base::StringPrintf("DelegateEmbed url=%s", | |
97 change.embed_url.data()); | |
98 | |
99 case CHANGE_TYPE_FOCUSED: | |
100 return base::StringPrintf("Focused id=%s", | |
101 ViewIdToString(change.view_id).c_str()); | |
102 } | |
103 return std::string(); | |
104 } | |
105 | |
106 } // namespace | |
107 | |
108 std::vector<std::string> ChangesToDescription1( | |
109 const std::vector<Change>& changes) { | |
110 std::vector<std::string> strings(changes.size()); | |
111 for (size_t i = 0; i < changes.size(); ++i) | |
112 strings[i] = ChangeToDescription1(changes[i]); | |
113 return strings; | |
114 } | |
115 | |
116 std::string SingleChangeToDescription(const std::vector<Change>& changes) { | |
117 std::string result; | |
118 for (auto& change : changes) { | |
119 if (!result.empty()) | |
120 result += "\n"; | |
121 result += ChangeToDescription1(change); | |
122 } | |
123 return result; | |
124 } | |
125 | |
126 std::string SingleViewDescription(const std::vector<TestView>& views) { | |
127 if (views.size() != 1u) | |
128 return "more than one changes and expected only one"; | |
129 return views[0].ToString(); | |
130 } | |
131 | |
132 std::string ChangeViewDescription(const std::vector<Change>& changes) { | |
133 if (changes.size() != 1) | |
134 return std::string(); | |
135 std::vector<std::string> view_strings(changes[0].views.size()); | |
136 for (size_t i = 0; i < changes[0].views.size(); ++i) | |
137 view_strings[i] = "[" + changes[0].views[i].ToString() + "]"; | |
138 return base::JoinString(view_strings, ","); | |
139 } | |
140 | |
141 TestView ViewDataToTestView(const ViewDataPtr& data) { | |
142 TestView view; | |
143 view.parent_id = data->parent_id; | |
144 view.view_id = data->view_id; | |
145 view.visible = data->visible; | |
146 view.drawn = data->drawn; | |
147 view.properties = | |
148 data->properties.To<std::map<std::string, std::vector<uint8_t>>>(); | |
149 return view; | |
150 } | |
151 | |
152 void ViewDatasToTestViews(const Array<ViewDataPtr>& data, | |
153 std::vector<TestView>* test_views) { | |
154 for (size_t i = 0; i < data.size(); ++i) | |
155 test_views->push_back(ViewDataToTestView(data[i])); | |
156 } | |
157 | |
158 Change::Change() | |
159 : type(CHANGE_TYPE_EMBED), | |
160 connection_id(0), | |
161 view_id(0), | |
162 view_id2(0), | |
163 view_id3(0), | |
164 event_action(0), | |
165 direction(mojo::ORDER_DIRECTION_ABOVE), | |
166 bool_value(false) {} | |
167 | |
168 Change::~Change() {} | |
169 | |
170 TestChangeTracker::TestChangeTracker() : delegate_(NULL) {} | |
171 | |
172 TestChangeTracker::~TestChangeTracker() {} | |
173 | |
174 void TestChangeTracker::OnEmbed(ConnectionSpecificId connection_id, | |
175 ViewDataPtr root) { | |
176 Change change; | |
177 change.type = CHANGE_TYPE_EMBED; | |
178 change.connection_id = connection_id; | |
179 change.views.push_back(ViewDataToTestView(root)); | |
180 AddChange(change); | |
181 } | |
182 | |
183 void TestChangeTracker::OnEmbeddedAppDisconnected(Id view_id) { | |
184 Change change; | |
185 change.type = CHANGE_TYPE_EMBEDDED_APP_DISCONNECTED; | |
186 change.view_id = view_id; | |
187 AddChange(change); | |
188 } | |
189 | |
190 void TestChangeTracker::OnViewBoundsChanged(Id view_id, | |
191 mojo::RectPtr old_bounds, | |
192 mojo::RectPtr new_bounds) { | |
193 Change change; | |
194 change.type = CHANGE_TYPE_NODE_BOUNDS_CHANGED; | |
195 change.view_id = view_id; | |
196 change.bounds.x = old_bounds->x; | |
197 change.bounds.y = old_bounds->y; | |
198 change.bounds.width = old_bounds->width; | |
199 change.bounds.height = old_bounds->height; | |
200 change.bounds2.x = new_bounds->x; | |
201 change.bounds2.y = new_bounds->y; | |
202 change.bounds2.width = new_bounds->width; | |
203 change.bounds2.height = new_bounds->height; | |
204 AddChange(change); | |
205 } | |
206 | |
207 void TestChangeTracker::OnUnembed() { | |
208 Change change; | |
209 change.type = CHANGE_TYPE_UNEMBED; | |
210 AddChange(change); | |
211 } | |
212 | |
213 void TestChangeTracker::OnViewViewportMetricsChanged( | |
214 mojo::ViewportMetricsPtr old_metrics, | |
215 mojo::ViewportMetricsPtr new_metrics) { | |
216 Change change; | |
217 change.type = CHANGE_TYPE_NODE_VIEWPORT_METRICS_CHANGED; | |
218 // NOT IMPLEMENTED | |
219 AddChange(change); | |
220 } | |
221 | |
222 void TestChangeTracker::OnViewHierarchyChanged(Id view_id, | |
223 Id new_parent_id, | |
224 Id old_parent_id, | |
225 Array<ViewDataPtr> views) { | |
226 Change change; | |
227 change.type = CHANGE_TYPE_NODE_HIERARCHY_CHANGED; | |
228 change.view_id = view_id; | |
229 change.view_id2 = new_parent_id; | |
230 change.view_id3 = old_parent_id; | |
231 ViewDatasToTestViews(views, &change.views); | |
232 AddChange(change); | |
233 } | |
234 | |
235 void TestChangeTracker::OnViewReordered(Id view_id, | |
236 Id relative_view_id, | |
237 mojo::OrderDirection direction) { | |
238 Change change; | |
239 change.type = CHANGE_TYPE_NODE_REORDERED; | |
240 change.view_id = view_id; | |
241 change.view_id2 = relative_view_id; | |
242 change.direction = direction; | |
243 AddChange(change); | |
244 } | |
245 | |
246 void TestChangeTracker::OnViewDeleted(Id view_id) { | |
247 Change change; | |
248 change.type = CHANGE_TYPE_NODE_DELETED; | |
249 change.view_id = view_id; | |
250 AddChange(change); | |
251 } | |
252 | |
253 void TestChangeTracker::OnViewVisibilityChanged(Id view_id, bool visible) { | |
254 Change change; | |
255 change.type = CHANGE_TYPE_NODE_VISIBILITY_CHANGED; | |
256 change.view_id = view_id; | |
257 change.bool_value = visible; | |
258 AddChange(change); | |
259 } | |
260 | |
261 void TestChangeTracker::OnViewDrawnStateChanged(Id view_id, bool drawn) { | |
262 Change change; | |
263 change.type = CHANGE_TYPE_NODE_DRAWN_STATE_CHANGED; | |
264 change.view_id = view_id; | |
265 change.bool_value = drawn; | |
266 AddChange(change); | |
267 } | |
268 | |
269 void TestChangeTracker::OnViewInputEvent(Id view_id, mojo::EventPtr event) { | |
270 Change change; | |
271 change.type = CHANGE_TYPE_INPUT_EVENT; | |
272 change.view_id = view_id; | |
273 change.event_action = event->action; | |
274 AddChange(change); | |
275 } | |
276 | |
277 void TestChangeTracker::OnViewSharedPropertyChanged(Id view_id, | |
278 String name, | |
279 Array<uint8_t> data) { | |
280 Change change; | |
281 change.type = CHANGE_TYPE_PROPERTY_CHANGED; | |
282 change.view_id = view_id; | |
283 change.property_key = name; | |
284 if (data.is_null()) | |
285 change.property_value = "NULL"; | |
286 else | |
287 change.property_value = data.To<std::string>(); | |
288 AddChange(change); | |
289 } | |
290 | |
291 void TestChangeTracker::OnViewFocused(Id view_id) { | |
292 Change change; | |
293 change.type = CHANGE_TYPE_FOCUSED; | |
294 change.view_id = view_id; | |
295 AddChange(change); | |
296 } | |
297 | |
298 void TestChangeTracker::DelegateEmbed(const String& url) { | |
299 Change change; | |
300 change.type = CHANGE_TYPE_DELEGATE_EMBED; | |
301 change.embed_url = url; | |
302 AddChange(change); | |
303 } | |
304 | |
305 void TestChangeTracker::AddChange(const Change& change) { | |
306 changes_.push_back(change); | |
307 if (delegate_) | |
308 delegate_->OnChangeAdded(); | |
309 } | |
310 | |
311 TestView::TestView() {} | |
312 | |
313 TestView::~TestView() {} | |
314 | |
315 std::string TestView::ToString() const { | |
316 return base::StringPrintf("view=%s parent=%s", | |
317 ViewIdToString(view_id).c_str(), | |
318 ViewIdToString(parent_id).c_str()); | |
319 } | |
320 | |
321 std::string TestView::ToString2() const { | |
322 return base::StringPrintf( | |
323 "view=%s parent=%s visible=%s drawn=%s", ViewIdToString(view_id).c_str(), | |
324 ViewIdToString(parent_id).c_str(), visible ? "true" : "false", | |
325 drawn ? "true" : "false"); | |
326 } | |
327 | |
328 } // namespace mus | |
OLD | NEW |