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

Side by Side Diff: dbus/message_unittest.cc

Issue 7492029: Implement classes used for manipulating D-Bus messages. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: improve ToString() Created 9 years, 4 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 | Annotate | Revision Log
« dbus/message.cc ('K') | « dbus/message.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2011 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 "base/logging.h"
6 #include "dbus/message.h"
7 #include "testing/gtest/include/gtest/gtest.h"
8
9 // Test that a byte can be properly written and read. We only have this
10 // test for byte, as repeating this for other basic types is too redundant.
11 TEST(MessageTest, AppendAndPopByte) {
12 dbus::Message message;
13 message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL));
14 dbus::MessageWriter writer(&message);
15 writer.AppendByte(123); // The input is 123.
16
17 dbus::MessageReader reader(&message);
18 ASSERT_TRUE(reader.HasMoreData()); // Should have data to read.
19 ASSERT_EQ(dbus::Message::BYTE, reader.GetDataType());
20
21 bool bool_value = false;
22 // Should fail as the type is not bool here.
23 ASSERT_FALSE(reader.PopBool(&bool_value));
24
25 uint8 byte_value = 0;
26 ASSERT_TRUE(reader.PopByte(&byte_value));
27 EXPECT_EQ(123, byte_value); // Should match with the input.
28 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
29
30 // Try to get another byte. Should fail.
31 ASSERT_FALSE(reader.PopByte(&byte_value));
32 }
33
34 // Check all basic types can be properly written and read.
35 TEST(MessageTest, AppendAndPopBasicDataTypes) {
36 dbus::Message message;
37 message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL));
38 dbus::MessageWriter writer(&message);
39
40 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
41 writer.AppendByte(0);
42 writer.AppendBool(true);
43 writer.AppendInt16(2);
44 writer.AppendUint16(3);
45 writer.AppendInt32(4);
46 writer.AppendUint32(5);
47 writer.AppendInt64(6);
48 writer.AppendUint64(7);
49 writer.AppendDouble(8.0);
50 writer.AppendString("string");
51 writer.AppendObjectPath("/object/path");
52
53 uint8 byte_value = 0;
54 bool bool_value = false;
55 int16 int16_value = 0;
56 uint16 uint16_value = 0;
57 int32 int32_value = 0;
58 uint32 uint32_value = 0;
59 int64 int64_value = 0;
60 uint64 uint64_value = 0;
61 double double_value = 0;
62 std::string string_value;
63 std::string object_path_value;
64
65 dbus::MessageReader reader(&message);
66 ASSERT_TRUE(reader.HasMoreData());
67 ASSERT_TRUE(reader.PopByte(&byte_value));
68 ASSERT_TRUE(reader.PopBool(&bool_value));
69 ASSERT_TRUE(reader.PopInt16(&int16_value));
70 ASSERT_TRUE(reader.PopUint16(&uint16_value));
71 ASSERT_TRUE(reader.PopInt32(&int32_value));
72 ASSERT_TRUE(reader.PopUint32(&uint32_value));
73 ASSERT_TRUE(reader.PopInt64(&int64_value));
74 ASSERT_TRUE(reader.PopUint64(&uint64_value));
75 ASSERT_TRUE(reader.PopDouble(&double_value));
76 ASSERT_TRUE(reader.PopString(&string_value));
77 ASSERT_TRUE(reader.PopObjectPath(&object_path_value));
78 ASSERT_FALSE(reader.HasMoreData());
79
80 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
81 EXPECT_EQ(0, byte_value);
82 EXPECT_EQ(true, bool_value);
83 EXPECT_EQ(2, int16_value);
84 EXPECT_EQ(3U, uint16_value);
85 EXPECT_EQ(4, int32_value);
86 EXPECT_EQ(5U, uint32_value);
87 EXPECT_EQ(6, int64_value);
88 EXPECT_EQ(7U, uint64_value);
89 EXPECT_DOUBLE_EQ(8.0, double_value);
90 EXPECT_EQ("string", string_value);
91 EXPECT_EQ("/object/path", object_path_value);
92 }
93
94 // Check all variant types can be properly written and read.
95 TEST(MessageTest, AppendAndPopVariantDataTypes) {
96 dbus::Message message;
97 message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL));
98 dbus::MessageWriter writer(&message);
99
100 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
101 writer.AppendVariantOfByte(0);
102 writer.AppendVariantOfBool(true);
103 writer.AppendVariantOfInt16(2);
104 writer.AppendVariantOfUint16(3);
105 writer.AppendVariantOfInt32(4);
106 writer.AppendVariantOfUint32(5);
107 writer.AppendVariantOfInt64(6);
108 writer.AppendVariantOfUint64(7);
109 writer.AppendVariantOfDouble(8.0);
110 writer.AppendVariantOfString("string");
111 writer.AppendVariantOfObjectPath("/object/path");
112
113 uint8 byte_value = 0;
114 bool bool_value = false;
115 int16 int16_value = 0;
116 uint16 uint16_value = 0;
117 int32 int32_value = 0;
118 uint32 uint32_value = 0;
119 int64 int64_value = 0;
120 uint64 uint64_value = 0;
121 double double_value = 0;
122 std::string string_value;
123 std::string object_path_value;
124
125 dbus::MessageReader reader(&message);
126 ASSERT_TRUE(reader.HasMoreData());
127 ASSERT_TRUE(reader.PopVariantOfByte(&byte_value));
128 ASSERT_TRUE(reader.PopVariantOfBool(&bool_value));
129 ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value));
130 ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_value));
131 ASSERT_TRUE(reader.PopVariantOfInt32(&int32_value));
132 ASSERT_TRUE(reader.PopVariantOfUint32(&uint32_value));
133 ASSERT_TRUE(reader.PopVariantOfInt64(&int64_value));
134 ASSERT_TRUE(reader.PopVariantOfUint64(&uint64_value));
135 ASSERT_TRUE(reader.PopVariantOfDouble(&double_value));
136 ASSERT_TRUE(reader.PopVariantOfString(&string_value));
137 ASSERT_TRUE(reader.PopVariantOfObjectPath(&object_path_value));
138 ASSERT_FALSE(reader.HasMoreData());
139
140 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
141 EXPECT_EQ(0, byte_value);
142 EXPECT_EQ(true, bool_value);
143 EXPECT_EQ(2, int16_value);
144 EXPECT_EQ(3U, uint16_value);
145 EXPECT_EQ(4, int32_value);
146 EXPECT_EQ(5U, uint32_value);
147 EXPECT_EQ(6, int64_value);
148 EXPECT_EQ(7U, uint64_value);
149 EXPECT_DOUBLE_EQ(8.0, double_value);
150 EXPECT_EQ("string", string_value);
151 EXPECT_EQ("/object/path", object_path_value);
152 }
153
154 TEST(MessageTest, ArrayOfBytes) {
155 dbus::Message message;
156 message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL));
157 dbus::MessageWriter writer(&message);
158 std::vector<uint8> bytes;
159 bytes.push_back(1);
160 bytes.push_back(2);
161 bytes.push_back(3);
162 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
163
164 dbus::MessageReader reader(&message);
165 std::vector<uint8> output_bytes;
166 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes));
167 ASSERT_FALSE(reader.HasMoreData());
168 ASSERT_EQ(3U, output_bytes.size());
169 ASSERT_EQ(1, output_bytes[0]);
170 ASSERT_EQ(2, output_bytes[1]);
171 ASSERT_EQ(3, output_bytes[2]);
172 }
173
174 // Test that an array can be properly written and read. We only have this
175 // test for array, as repeating this for other container types is too
176 // redundant.
177 TEST(MessageTest, OpenArrayAndPopArray) {
178 dbus::Message message;
179 message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL));
180 dbus::MessageWriter writer(&message);
181 dbus::MessageWriter array_writer(&message);
182 writer.OpenArray("s", &array_writer); // Open an array of strings.
183 array_writer.AppendString("foo");
184 array_writer.AppendString("bar");
185 array_writer.AppendString("baz");
186 writer.CloseContainer(&array_writer);
187
188 dbus::MessageReader reader(&message);
189 ASSERT_EQ(dbus::Message::ARRAY, reader.GetDataType());
190 dbus::MessageReader array_reader(&message);
191 ASSERT_TRUE(reader.PopArray(&array_reader));
192 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
193
194 std::string string_value;
195 ASSERT_TRUE(array_reader.PopString(&string_value));
196 EXPECT_EQ("foo", string_value);
197 ASSERT_TRUE(array_reader.PopString(&string_value));
198 EXPECT_EQ("bar", string_value);
199 ASSERT_TRUE(array_reader.PopString(&string_value));
200 EXPECT_EQ("baz", string_value);
201 // Should not have more data to read.
202 ASSERT_FALSE(array_reader.HasMoreData());
203 }
204
205 // Create a complex message using array, struct, variant, dict entry, and
206 // make sure it can be read properly.
207 TEST(MessageTest, CreateComplexMessageAndReadIt) {
208 dbus::Message message;
209 message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL));
210 dbus::MessageWriter writer(&message);
211 {
212 dbus::MessageWriter array_writer(&message);
213 // Open an array of variants.
214 writer.OpenArray("v", &array_writer);
215 {
216 // The first value in the array.
217 {
218 dbus::MessageWriter variant_writer(&message);
219 // Open a variant of a boolean.
220 array_writer.OpenVariant("b", &variant_writer);
221 variant_writer.AppendBool(true);
222 array_writer.CloseContainer(&variant_writer);
223 }
224
225 // The second value in the array.
226 {
227 dbus::MessageWriter variant_writer(&message);
228 // Open a variant of a struct that contains a string and an int32.
229 array_writer.OpenVariant("(si)", &variant_writer);
230 {
231 dbus::MessageWriter struct_writer(&message);
232 variant_writer.OpenStruct(&struct_writer);
233 struct_writer.AppendString("string");
234 struct_writer.AppendInt32(123);
235 variant_writer.CloseContainer(&struct_writer);
236 }
237 array_writer.CloseContainer(&variant_writer);
238 }
239
240 // The third value in the array.
241 {
242 dbus::MessageWriter variant_writer(&message);
243 // Open a variant of an array of string-to-int64 dict entries.
244 array_writer.OpenVariant("a{sx}", &variant_writer);
245 {
246 // Opens an array of string-to-int64 dict entries.
247 dbus::MessageWriter dict_array_writer(&message);
248 variant_writer.OpenArray("{sx}", &dict_array_writer);
249 {
250 // Opens a string-to-int64 dict entries.
251 dbus::MessageWriter dict_entry_writer(&message);
252 dict_array_writer.OpenDictEntry(&dict_entry_writer);
253 dict_entry_writer.AppendString("foo");
254 dict_entry_writer.AppendInt64(1234567890123456789);
255 dict_array_writer.CloseContainer(&dict_entry_writer);
256 }
257 variant_writer.CloseContainer(&dict_array_writer);
258 }
259 array_writer.CloseContainer(&variant_writer);
260 }
261 }
262 writer.CloseContainer(&array_writer);
263 }
264 // What we have created looks like this:
265 EXPECT_EQ("\n"
266 "array [\n"
267 " variant bool true\n"
268 " variant struct {\n"
269 " string \"string\"\n"
270 " int32 123\n"
271 " }\n"
272 " variant array [\n"
273 " dict entry {\n"
274 " string \"foo\"\n"
275 " int64 1234567890123456789\n"
276 " }\n"
277 " ]\n"
278 "]\n",
279 message.ToString());
280
281 dbus::MessageReader reader(&message);
282 dbus::MessageReader array_reader(&message);
283 ASSERT_TRUE(reader.PopArray(&array_reader));
284
285 // The first value in the array.
286 bool bool_value = false;
287 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value));
288 EXPECT_EQ(true, bool_value);
289
290 // The second value in the array.
291 {
292 dbus::MessageReader variant_reader(&message);
293 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
294 {
295 dbus::MessageReader struct_reader(&message);
296 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader));
297 std::string string_value;
298 ASSERT_TRUE(struct_reader.PopString(&string_value));
299 EXPECT_EQ("string", string_value);
300 int32 int32_value = 0;
301 ASSERT_TRUE(struct_reader.PopInt32(&int32_value));
302 EXPECT_EQ(123, int32_value);
303 ASSERT_FALSE(struct_reader.HasMoreData());
304 }
305 ASSERT_FALSE(variant_reader.HasMoreData());
306 }
307
308 // The third value in the array.
309 {
310 dbus::MessageReader variant_reader(&message);
311 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
312 {
313 dbus::MessageReader dict_array_reader(&message);
314 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader));
315 {
316 dbus::MessageReader dict_entry_reader(&message);
317 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader));
318 std::string string_value;
319 ASSERT_TRUE(dict_entry_reader.PopString(&string_value));
320 EXPECT_EQ("foo", string_value);
321 int64 int64_value = 0;
322 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value));
323 EXPECT_EQ(1234567890123456789, int64_value);
324 }
325 ASSERT_FALSE(dict_array_reader.HasMoreData());
326 }
327 ASSERT_FALSE(variant_reader.HasMoreData());
328 }
329 ASSERT_FALSE(array_reader.HasMoreData());
330 ASSERT_FALSE(reader.HasMoreData());
331 }
332
333 TEST(MessageTest, Message) {
334 dbus::Message message;
335 EXPECT_TRUE(message.raw_message() == NULL);
336 EXPECT_EQ(dbus::Message::MESSAGE_INVALID, message.GetMessageType());
337 }
338
339 TEST(MessageTest, MethodCall) {
340 dbus::MethodCall method_call("com.example.Interface", "SomeMethod");
341 EXPECT_TRUE(method_call.raw_message() != NULL);
342 EXPECT_EQ(dbus::Message::MESSAGE_METHOD_CALL, method_call.GetMessageType());
343 method_call.SetServiceName("com.example.Service");
344 method_call.SetObjectPath("/com/example/Object");
345
346 dbus::MessageWriter writer(&method_call);
347 writer.AppendString("payload");
348
349 EXPECT_EQ("destination: com.example.Service\n"
350 "path: /com/example/Object\n"
351 "interface: com.example.Interface\n"
352 "member: SomeMethod\n"
353 "\n"
354 "string \"payload\"\n",
355 method_call.ToString());
356 }
357
358 TEST(MessageTest, Response) {
359 dbus::Response response;
360 EXPECT_TRUE(response.raw_message() == NULL);
361 response.reset_raw_message(
362 dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_RETURN));
363 EXPECT_EQ(dbus::Message::MESSAGE_METHOD_RETURN, response.GetMessageType());
364 }
365
366 TEST(MessageTest, ToString_EmptyMessage) {
367 dbus::Message message;
368 EXPECT_EQ("", message.ToString());
369 }
OLDNEW
« dbus/message.cc ('K') | « dbus/message.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698