Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "dbus/message.h" | 5 #include "dbus/message.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/posix/eintr_wrapper.h" | 10 #include "base/posix/eintr_wrapper.h" |
| 11 #include "dbus/object_path.h" | 11 #include "dbus/object_path.h" |
| 12 #include "dbus/test_proto.pb.h" | 12 #include "dbus/test_proto.pb.h" |
| 13 #include "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
| 14 | 14 |
| 15 namespace dbus { | 15 namespace dbus { |
| 16 | 16 |
| 17 // Test that a byte can be properly written and read. We only have this | 17 // Test that a byte can be properly written and read. We only have this |
| 18 // test for byte, as repeating this for other basic types is too redundant. | 18 // test for byte, as repeating this for other basic types is too redundant. |
| 19 TEST(MessageTest, AppendAndPopByte) { | 19 TEST(MessageTest, AppendAndPopByte) { |
| 20 scoped_ptr<Response> message(Response::CreateEmpty()); | 20 scoped_ptr<Response> message(Response::CreateEmpty()); |
| 21 MessageWriter writer(message.get()); | 21 MessageWriter writer(message.get()); |
| 22 writer.AppendByte(123); // The input is 123. | 22 writer.AppendByte(123); // The input is 123. |
| 23 | 23 |
| 24 MessageReader reader(message.get()); | 24 MessageReader reader(message.get()); |
| 25 ASSERT_TRUE(reader.HasMoreData()); // Should have data to read. | 25 ASSERT_TRUE(reader.HasMoreData()); // Should have data to read. |
| 26 ASSERT_EQ(Message::BYTE, reader.GetDataType()); | 26 ASSERT_EQ(Message::BYTE, reader.GetDataType()); |
| 27 ASSERT_EQ("y", reader.GetDataSignature()); | |
| 27 | 28 |
| 28 bool bool_value = false; | 29 bool bool_value = false; |
| 29 // Should fail as the type is not bool here. | 30 // Should fail as the type is not bool here. |
| 30 ASSERT_FALSE(reader.PopBool(&bool_value)); | 31 ASSERT_FALSE(reader.PopBool(&bool_value)); |
| 31 | 32 |
| 32 uint8 byte_value = 0; | 33 uint8 byte_value = 0; |
| 33 ASSERT_TRUE(reader.PopByte(&byte_value)); | 34 ASSERT_TRUE(reader.PopByte(&byte_value)); |
| 34 EXPECT_EQ(123, byte_value); // Should match with the input. | 35 EXPECT_EQ(123, byte_value); // Should match with the input. |
| 35 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read. | 36 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read. |
| 36 | 37 |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 63 int32 int32_value = 0; | 64 int32 int32_value = 0; |
| 64 uint32 uint32_value = 0; | 65 uint32 uint32_value = 0; |
| 65 int64 int64_value = 0; | 66 int64 int64_value = 0; |
| 66 uint64 uint64_value = 0; | 67 uint64 uint64_value = 0; |
| 67 double double_value = 0; | 68 double double_value = 0; |
| 68 std::string string_value; | 69 std::string string_value; |
| 69 ObjectPath object_path_value; | 70 ObjectPath object_path_value; |
| 70 | 71 |
| 71 MessageReader reader(message.get()); | 72 MessageReader reader(message.get()); |
| 72 ASSERT_TRUE(reader.HasMoreData()); | 73 ASSERT_TRUE(reader.HasMoreData()); |
| 74 ASSERT_EQ("y", reader.GetDataSignature()); | |
| 73 ASSERT_TRUE(reader.PopByte(&byte_value)); | 75 ASSERT_TRUE(reader.PopByte(&byte_value)); |
| 76 ASSERT_EQ("b", reader.GetDataSignature()); | |
| 74 ASSERT_TRUE(reader.PopBool(&bool_value)); | 77 ASSERT_TRUE(reader.PopBool(&bool_value)); |
| 78 ASSERT_EQ("n", reader.GetDataSignature()); | |
| 75 ASSERT_TRUE(reader.PopInt16(&int16_value)); | 79 ASSERT_TRUE(reader.PopInt16(&int16_value)); |
| 80 ASSERT_EQ("q", reader.GetDataSignature()); | |
| 76 ASSERT_TRUE(reader.PopUint16(&uint16_value)); | 81 ASSERT_TRUE(reader.PopUint16(&uint16_value)); |
| 82 ASSERT_EQ("i", reader.GetDataSignature()); | |
| 77 ASSERT_TRUE(reader.PopInt32(&int32_value)); | 83 ASSERT_TRUE(reader.PopInt32(&int32_value)); |
| 84 ASSERT_EQ("u", reader.GetDataSignature()); | |
| 78 ASSERT_TRUE(reader.PopUint32(&uint32_value)); | 85 ASSERT_TRUE(reader.PopUint32(&uint32_value)); |
| 86 ASSERT_EQ("x", reader.GetDataSignature()); | |
| 79 ASSERT_TRUE(reader.PopInt64(&int64_value)); | 87 ASSERT_TRUE(reader.PopInt64(&int64_value)); |
| 88 ASSERT_EQ("t", reader.GetDataSignature()); | |
| 80 ASSERT_TRUE(reader.PopUint64(&uint64_value)); | 89 ASSERT_TRUE(reader.PopUint64(&uint64_value)); |
| 90 ASSERT_EQ("d", reader.GetDataSignature()); | |
| 81 ASSERT_TRUE(reader.PopDouble(&double_value)); | 91 ASSERT_TRUE(reader.PopDouble(&double_value)); |
| 92 ASSERT_EQ("s", reader.GetDataSignature()); | |
| 82 ASSERT_TRUE(reader.PopString(&string_value)); | 93 ASSERT_TRUE(reader.PopString(&string_value)); |
| 94 ASSERT_EQ("o", reader.GetDataSignature()); | |
| 83 ASSERT_TRUE(reader.PopObjectPath(&object_path_value)); | 95 ASSERT_TRUE(reader.PopObjectPath(&object_path_value)); |
| 96 ASSERT_EQ("", reader.GetDataSignature()); | |
| 84 ASSERT_FALSE(reader.HasMoreData()); | 97 ASSERT_FALSE(reader.HasMoreData()); |
| 85 | 98 |
| 86 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned. | 99 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned. |
| 87 EXPECT_EQ(0, byte_value); | 100 EXPECT_EQ(0, byte_value); |
| 88 EXPECT_EQ(true, bool_value); | 101 EXPECT_EQ(true, bool_value); |
| 89 EXPECT_EQ(2, int16_value); | 102 EXPECT_EQ(2, int16_value); |
| 90 EXPECT_EQ(3U, uint16_value); | 103 EXPECT_EQ(3U, uint16_value); |
| 91 EXPECT_EQ(4, int32_value); | 104 EXPECT_EQ(4, int32_value); |
| 92 EXPECT_EQ(5U, uint32_value); | 105 EXPECT_EQ(5U, uint32_value); |
| 93 EXPECT_EQ(6, int64_value); | 106 EXPECT_EQ(6, int64_value); |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 113 ASSERT_FALSE(temp.is_valid()); | 126 ASSERT_FALSE(temp.is_valid()); |
| 114 // NB: thread IO requirements not relevant for unit tests. | 127 // NB: thread IO requirements not relevant for unit tests. |
| 115 temp.CheckValidity(); | 128 temp.CheckValidity(); |
| 116 ASSERT_TRUE(temp.is_valid()); | 129 ASSERT_TRUE(temp.is_valid()); |
| 117 writer.AppendFileDescriptor(temp); | 130 writer.AppendFileDescriptor(temp); |
| 118 | 131 |
| 119 FileDescriptor fd_value; | 132 FileDescriptor fd_value; |
| 120 | 133 |
| 121 MessageReader reader(message.get()); | 134 MessageReader reader(message.get()); |
| 122 ASSERT_TRUE(reader.HasMoreData()); | 135 ASSERT_TRUE(reader.HasMoreData()); |
| 136 ASSERT_EQ(Message::UNIX_FD, reader.GetDataType()); | |
| 137 ASSERT_EQ("h", reader.GetDataSignature()); | |
| 123 ASSERT_TRUE(reader.PopFileDescriptor(&fd_value)); | 138 ASSERT_TRUE(reader.PopFileDescriptor(&fd_value)); |
| 124 ASSERT_FALSE(reader.HasMoreData()); | 139 ASSERT_FALSE(reader.HasMoreData()); |
| 125 // Descriptor is not valid until explicitly checked. | 140 // Descriptor is not valid until explicitly checked. |
| 126 ASSERT_FALSE(fd_value.is_valid()); | 141 ASSERT_FALSE(fd_value.is_valid()); |
| 127 fd_value.CheckValidity(); | 142 fd_value.CheckValidity(); |
| 128 ASSERT_TRUE(fd_value.is_valid()); | 143 ASSERT_TRUE(fd_value.is_valid()); |
| 129 | 144 |
| 130 // Stdout should be returned but we cannot check the descriptor | 145 // Stdout should be returned but we cannot check the descriptor |
| 131 // value because stdout will be dup'd. Instead check st_rdev | 146 // value because stdout will be dup'd. Instead check st_rdev |
| 132 // which should be identical. | 147 // which should be identical. |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 164 int32 int32_value = 0; | 179 int32 int32_value = 0; |
| 165 uint32 uint32_value = 0; | 180 uint32 uint32_value = 0; |
| 166 int64 int64_value = 0; | 181 int64 int64_value = 0; |
| 167 uint64 uint64_value = 0; | 182 uint64 uint64_value = 0; |
| 168 double double_value = 0; | 183 double double_value = 0; |
| 169 std::string string_value; | 184 std::string string_value; |
| 170 ObjectPath object_path_value; | 185 ObjectPath object_path_value; |
| 171 | 186 |
| 172 MessageReader reader(message.get()); | 187 MessageReader reader(message.get()); |
| 173 ASSERT_TRUE(reader.HasMoreData()); | 188 ASSERT_TRUE(reader.HasMoreData()); |
| 174 ASSERT_TRUE(reader.PopVariantOfByte(&byte_value)); | 189 ASSERT_TRUE(reader.PopVariantOfByte(&byte_value)); |
|
satorux1
2014/08/25 05:33:27
maybe add tests for reader.GetDataSignature() in t
Ben Chan
2014/08/25 05:43:08
Done.
| |
| 175 ASSERT_TRUE(reader.PopVariantOfBool(&bool_value)); | 190 ASSERT_TRUE(reader.PopVariantOfBool(&bool_value)); |
| 176 ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value)); | 191 ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value)); |
| 177 ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_value)); | 192 ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_value)); |
| 178 ASSERT_TRUE(reader.PopVariantOfInt32(&int32_value)); | 193 ASSERT_TRUE(reader.PopVariantOfInt32(&int32_value)); |
| 179 ASSERT_TRUE(reader.PopVariantOfUint32(&uint32_value)); | 194 ASSERT_TRUE(reader.PopVariantOfUint32(&uint32_value)); |
| 180 ASSERT_TRUE(reader.PopVariantOfInt64(&int64_value)); | 195 ASSERT_TRUE(reader.PopVariantOfInt64(&int64_value)); |
| 181 ASSERT_TRUE(reader.PopVariantOfUint64(&uint64_value)); | 196 ASSERT_TRUE(reader.PopVariantOfUint64(&uint64_value)); |
| 182 ASSERT_TRUE(reader.PopVariantOfDouble(&double_value)); | 197 ASSERT_TRUE(reader.PopVariantOfDouble(&double_value)); |
| 183 ASSERT_TRUE(reader.PopVariantOfString(&string_value)); | 198 ASSERT_TRUE(reader.PopVariantOfString(&string_value)); |
| 184 ASSERT_TRUE(reader.PopVariantOfObjectPath(&object_path_value)); | 199 ASSERT_TRUE(reader.PopVariantOfObjectPath(&object_path_value)); |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 203 MessageWriter writer(message.get()); | 218 MessageWriter writer(message.get()); |
| 204 std::vector<uint8> bytes; | 219 std::vector<uint8> bytes; |
| 205 bytes.push_back(1); | 220 bytes.push_back(1); |
| 206 bytes.push_back(2); | 221 bytes.push_back(2); |
| 207 bytes.push_back(3); | 222 bytes.push_back(3); |
| 208 writer.AppendArrayOfBytes(bytes.data(), bytes.size()); | 223 writer.AppendArrayOfBytes(bytes.data(), bytes.size()); |
| 209 | 224 |
| 210 MessageReader reader(message.get()); | 225 MessageReader reader(message.get()); |
| 211 const uint8* output_bytes = NULL; | 226 const uint8* output_bytes = NULL; |
| 212 size_t length = 0; | 227 size_t length = 0; |
| 228 ASSERT_EQ("ay", reader.GetDataSignature()); | |
| 213 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length)); | 229 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length)); |
| 214 ASSERT_FALSE(reader.HasMoreData()); | 230 ASSERT_FALSE(reader.HasMoreData()); |
| 215 ASSERT_EQ(3U, length); | 231 ASSERT_EQ(3U, length); |
| 216 EXPECT_EQ(1, output_bytes[0]); | 232 EXPECT_EQ(1, output_bytes[0]); |
| 217 EXPECT_EQ(2, output_bytes[1]); | 233 EXPECT_EQ(2, output_bytes[1]); |
| 218 EXPECT_EQ(3, output_bytes[2]); | 234 EXPECT_EQ(3, output_bytes[2]); |
| 219 } | 235 } |
| 220 | 236 |
| 221 TEST(MessageTest, ArrayOfBytes_Empty) { | 237 TEST(MessageTest, ArrayOfBytes_Empty) { |
| 222 scoped_ptr<Response> message(Response::CreateEmpty()); | 238 scoped_ptr<Response> message(Response::CreateEmpty()); |
| 223 MessageWriter writer(message.get()); | 239 MessageWriter writer(message.get()); |
| 224 std::vector<uint8> bytes; | 240 std::vector<uint8> bytes; |
| 225 writer.AppendArrayOfBytes(bytes.data(), bytes.size()); | 241 writer.AppendArrayOfBytes(bytes.data(), bytes.size()); |
| 226 | 242 |
| 227 MessageReader reader(message.get()); | 243 MessageReader reader(message.get()); |
| 228 const uint8* output_bytes = NULL; | 244 const uint8* output_bytes = NULL; |
| 229 size_t length = 0; | 245 size_t length = 0; |
| 246 ASSERT_EQ("ay", reader.GetDataSignature()); | |
| 230 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length)); | 247 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length)); |
| 231 ASSERT_FALSE(reader.HasMoreData()); | 248 ASSERT_FALSE(reader.HasMoreData()); |
| 232 ASSERT_EQ(0U, length); | 249 ASSERT_EQ(0U, length); |
| 233 EXPECT_EQ(NULL, output_bytes); | 250 EXPECT_EQ(NULL, output_bytes); |
| 234 } | 251 } |
| 235 | 252 |
| 236 TEST(MessageTest, ArrayOfStrings) { | 253 TEST(MessageTest, ArrayOfStrings) { |
| 237 scoped_ptr<Response> message(Response::CreateEmpty()); | 254 scoped_ptr<Response> message(Response::CreateEmpty()); |
| 238 MessageWriter writer(message.get()); | 255 MessageWriter writer(message.get()); |
| 239 std::vector<std::string> strings; | 256 std::vector<std::string> strings; |
| 240 strings.push_back("fee"); | 257 strings.push_back("fee"); |
| 241 strings.push_back("fie"); | 258 strings.push_back("fie"); |
| 242 strings.push_back("foe"); | 259 strings.push_back("foe"); |
| 243 strings.push_back("fum"); | 260 strings.push_back("fum"); |
| 244 writer.AppendArrayOfStrings(strings); | 261 writer.AppendArrayOfStrings(strings); |
| 245 | 262 |
| 246 MessageReader reader(message.get()); | 263 MessageReader reader(message.get()); |
| 247 std::vector<std::string> output_strings; | 264 std::vector<std::string> output_strings; |
| 265 ASSERT_EQ("as", reader.GetDataSignature()); | |
| 248 ASSERT_TRUE(reader.PopArrayOfStrings(&output_strings)); | 266 ASSERT_TRUE(reader.PopArrayOfStrings(&output_strings)); |
| 249 ASSERT_FALSE(reader.HasMoreData()); | 267 ASSERT_FALSE(reader.HasMoreData()); |
| 250 ASSERT_EQ(4U, output_strings.size()); | 268 ASSERT_EQ(4U, output_strings.size()); |
| 251 EXPECT_EQ("fee", output_strings[0]); | 269 EXPECT_EQ("fee", output_strings[0]); |
| 252 EXPECT_EQ("fie", output_strings[1]); | 270 EXPECT_EQ("fie", output_strings[1]); |
| 253 EXPECT_EQ("foe", output_strings[2]); | 271 EXPECT_EQ("foe", output_strings[2]); |
| 254 EXPECT_EQ("fum", output_strings[3]); | 272 EXPECT_EQ("fum", output_strings[3]); |
| 255 } | 273 } |
| 256 | 274 |
| 257 TEST(MessageTest, ArrayOfObjectPaths) { | 275 TEST(MessageTest, ArrayOfObjectPaths) { |
| 258 scoped_ptr<Response> message(Response::CreateEmpty()); | 276 scoped_ptr<Response> message(Response::CreateEmpty()); |
| 259 MessageWriter writer(message.get()); | 277 MessageWriter writer(message.get()); |
| 260 std::vector<ObjectPath> object_paths; | 278 std::vector<ObjectPath> object_paths; |
| 261 object_paths.push_back(ObjectPath("/object/path/1")); | 279 object_paths.push_back(ObjectPath("/object/path/1")); |
| 262 object_paths.push_back(ObjectPath("/object/path/2")); | 280 object_paths.push_back(ObjectPath("/object/path/2")); |
| 263 object_paths.push_back(ObjectPath("/object/path/3")); | 281 object_paths.push_back(ObjectPath("/object/path/3")); |
| 264 writer.AppendArrayOfObjectPaths(object_paths); | 282 writer.AppendArrayOfObjectPaths(object_paths); |
| 265 | 283 |
| 266 MessageReader reader(message.get()); | 284 MessageReader reader(message.get()); |
| 267 std::vector<ObjectPath> output_object_paths; | 285 std::vector<ObjectPath> output_object_paths; |
| 286 ASSERT_EQ("ao", reader.GetDataSignature()); | |
| 268 ASSERT_TRUE(reader.PopArrayOfObjectPaths(&output_object_paths)); | 287 ASSERT_TRUE(reader.PopArrayOfObjectPaths(&output_object_paths)); |
| 269 ASSERT_FALSE(reader.HasMoreData()); | 288 ASSERT_FALSE(reader.HasMoreData()); |
| 270 ASSERT_EQ(3U, output_object_paths.size()); | 289 ASSERT_EQ(3U, output_object_paths.size()); |
| 271 EXPECT_EQ(ObjectPath("/object/path/1"), output_object_paths[0]); | 290 EXPECT_EQ(ObjectPath("/object/path/1"), output_object_paths[0]); |
| 272 EXPECT_EQ(ObjectPath("/object/path/2"), output_object_paths[1]); | 291 EXPECT_EQ(ObjectPath("/object/path/2"), output_object_paths[1]); |
| 273 EXPECT_EQ(ObjectPath("/object/path/3"), output_object_paths[2]); | 292 EXPECT_EQ(ObjectPath("/object/path/3"), output_object_paths[2]); |
| 274 } | 293 } |
| 275 | 294 |
| 276 TEST(MessageTest, ProtoBuf) { | 295 TEST(MessageTest, ProtoBuf) { |
| 277 scoped_ptr<Response> message(Response::CreateEmpty()); | 296 scoped_ptr<Response> message(Response::CreateEmpty()); |
| 278 MessageWriter writer(message.get()); | 297 MessageWriter writer(message.get()); |
| 279 TestProto send_message; | 298 TestProto send_message; |
| 280 send_message.set_text("testing"); | 299 send_message.set_text("testing"); |
| 281 send_message.set_number(123); | 300 send_message.set_number(123); |
| 282 writer.AppendProtoAsArrayOfBytes(send_message); | 301 writer.AppendProtoAsArrayOfBytes(send_message); |
| 283 | 302 |
| 284 MessageReader reader(message.get()); | 303 MessageReader reader(message.get()); |
|
satorux1
2014/08/25 05:33:27
ditto. maybe add a test for reader.GetDataSignatur
Ben Chan
2014/08/25 05:43:08
Done.
| |
| 285 TestProto receive_message; | 304 TestProto receive_message; |
| 286 ASSERT_TRUE(reader.PopArrayOfBytesAsProto(&receive_message)); | 305 ASSERT_TRUE(reader.PopArrayOfBytesAsProto(&receive_message)); |
| 287 EXPECT_EQ(receive_message.text(), send_message.text()); | 306 EXPECT_EQ(receive_message.text(), send_message.text()); |
| 288 EXPECT_EQ(receive_message.number(), send_message.number()); | 307 EXPECT_EQ(receive_message.number(), send_message.number()); |
| 289 } | 308 } |
| 290 | 309 |
| 291 | 310 |
| 292 // Test that an array can be properly written and read. We only have this | 311 // Test that an array can be properly written and read. We only have this |
| 293 // test for array, as repeating this for other container types is too | 312 // test for array, as repeating this for other container types is too |
| 294 // redundant. | 313 // redundant. |
| 295 TEST(MessageTest, OpenArrayAndPopArray) { | 314 TEST(MessageTest, OpenArrayAndPopArray) { |
| 296 scoped_ptr<Response> message(Response::CreateEmpty()); | 315 scoped_ptr<Response> message(Response::CreateEmpty()); |
| 297 MessageWriter writer(message.get()); | 316 MessageWriter writer(message.get()); |
| 298 MessageWriter array_writer(NULL); | 317 MessageWriter array_writer(NULL); |
| 299 writer.OpenArray("s", &array_writer); // Open an array of strings. | 318 writer.OpenArray("s", &array_writer); // Open an array of strings. |
| 300 array_writer.AppendString("foo"); | 319 array_writer.AppendString("foo"); |
| 301 array_writer.AppendString("bar"); | 320 array_writer.AppendString("bar"); |
| 302 array_writer.AppendString("baz"); | 321 array_writer.AppendString("baz"); |
| 303 writer.CloseContainer(&array_writer); | 322 writer.CloseContainer(&array_writer); |
| 304 | 323 |
| 305 MessageReader reader(message.get()); | 324 MessageReader reader(message.get()); |
| 306 ASSERT_EQ(Message::ARRAY, reader.GetDataType()); | 325 ASSERT_EQ(Message::ARRAY, reader.GetDataType()); |
| 326 ASSERT_EQ("as", reader.GetDataSignature()); | |
| 307 MessageReader array_reader(NULL); | 327 MessageReader array_reader(NULL); |
| 308 ASSERT_TRUE(reader.PopArray(&array_reader)); | 328 ASSERT_TRUE(reader.PopArray(&array_reader)); |
| 309 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read. | 329 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read. |
| 310 | 330 |
| 311 std::string string_value; | 331 std::string string_value; |
| 312 ASSERT_TRUE(array_reader.PopString(&string_value)); | 332 ASSERT_TRUE(array_reader.PopString(&string_value)); |
| 313 EXPECT_EQ("foo", string_value); | 333 EXPECT_EQ("foo", string_value); |
| 314 ASSERT_TRUE(array_reader.PopString(&string_value)); | 334 ASSERT_TRUE(array_reader.PopString(&string_value)); |
| 315 EXPECT_EQ("bar", string_value); | 335 EXPECT_EQ("bar", string_value); |
| 316 ASSERT_TRUE(array_reader.PopString(&string_value)); | 336 ASSERT_TRUE(array_reader.PopString(&string_value)); |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 390 " variant array [\n" | 410 " variant array [\n" |
| 391 " dict entry {\n" | 411 " dict entry {\n" |
| 392 " string \"foo\"\n" | 412 " string \"foo\"\n" |
| 393 " int64 1234567890123456789\n" | 413 " int64 1234567890123456789\n" |
| 394 " }\n" | 414 " }\n" |
| 395 " ]\n" | 415 " ]\n" |
| 396 "]\n", | 416 "]\n", |
| 397 message->ToString()); | 417 message->ToString()); |
| 398 | 418 |
| 399 MessageReader reader(message.get()); | 419 MessageReader reader(message.get()); |
| 420 ASSERT_EQ("av", reader.GetDataSignature()); | |
| 400 MessageReader array_reader(NULL); | 421 MessageReader array_reader(NULL); |
| 401 ASSERT_TRUE(reader.PopArray(&array_reader)); | 422 ASSERT_TRUE(reader.PopArray(&array_reader)); |
| 402 | 423 |
| 403 // The first value in the array. | 424 // The first value in the array. |
| 404 bool bool_value = false; | 425 bool bool_value = false; |
| 426 ASSERT_EQ("v", array_reader.GetDataSignature()); | |
| 405 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value)); | 427 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value)); |
| 406 EXPECT_EQ(true, bool_value); | 428 EXPECT_EQ(true, bool_value); |
| 407 | 429 |
| 408 // The second value in the array. | 430 // The second value in the array. |
| 409 { | 431 { |
| 410 MessageReader variant_reader(NULL); | 432 MessageReader variant_reader(NULL); |
| 411 ASSERT_TRUE(array_reader.PopVariant(&variant_reader)); | 433 ASSERT_TRUE(array_reader.PopVariant(&variant_reader)); |
| 412 { | 434 { |
| 413 MessageReader struct_reader(NULL); | 435 MessageReader struct_reader(NULL); |
| 436 ASSERT_EQ("(si)", variant_reader.GetDataSignature()); | |
| 414 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader)); | 437 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader)); |
| 415 std::string string_value; | 438 std::string string_value; |
| 416 ASSERT_TRUE(struct_reader.PopString(&string_value)); | 439 ASSERT_TRUE(struct_reader.PopString(&string_value)); |
| 417 EXPECT_EQ("string", string_value); | 440 EXPECT_EQ("string", string_value); |
| 418 int32 int32_value = 0; | 441 int32 int32_value = 0; |
| 419 ASSERT_TRUE(struct_reader.PopInt32(&int32_value)); | 442 ASSERT_TRUE(struct_reader.PopInt32(&int32_value)); |
| 420 EXPECT_EQ(123, int32_value); | 443 EXPECT_EQ(123, int32_value); |
| 421 ASSERT_FALSE(struct_reader.HasMoreData()); | 444 ASSERT_FALSE(struct_reader.HasMoreData()); |
| 422 } | 445 } |
| 423 ASSERT_FALSE(variant_reader.HasMoreData()); | 446 ASSERT_FALSE(variant_reader.HasMoreData()); |
| 424 } | 447 } |
| 425 | 448 |
| 426 // The third value in the array. | 449 // The third value in the array. |
| 427 { | 450 { |
| 428 MessageReader variant_reader(NULL); | 451 MessageReader variant_reader(NULL); |
| 429 ASSERT_TRUE(array_reader.PopVariant(&variant_reader)); | 452 ASSERT_TRUE(array_reader.PopVariant(&variant_reader)); |
| 430 { | 453 { |
| 431 MessageReader dict_array_reader(NULL); | 454 MessageReader dict_array_reader(NULL); |
| 455 ASSERT_EQ("a{sx}", variant_reader.GetDataSignature()); | |
| 432 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader)); | 456 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader)); |
| 433 { | 457 { |
| 434 MessageReader dict_entry_reader(NULL); | 458 MessageReader dict_entry_reader(NULL); |
| 435 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader)); | 459 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader)); |
| 436 std::string string_value; | 460 std::string string_value; |
| 437 ASSERT_TRUE(dict_entry_reader.PopString(&string_value)); | 461 ASSERT_TRUE(dict_entry_reader.PopString(&string_value)); |
| 438 EXPECT_EQ("foo", string_value); | 462 EXPECT_EQ("foo", string_value); |
| 439 int64 int64_value = 0; | 463 int64 int64_value = 0; |
| 440 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value)); | 464 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value)); |
| 441 EXPECT_EQ(GG_INT64_C(1234567890123456789), int64_value); | 465 EXPECT_EQ(GG_INT64_C(1234567890123456789), int64_value); |
| (...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 623 | 647 |
| 624 ASSERT_EQ("message_type: MESSAGE_METHOD_RETURN\n" | 648 ASSERT_EQ("message_type: MESSAGE_METHOD_RETURN\n" |
| 625 "signature: s\n\n" | 649 "signature: s\n\n" |
| 626 "string \"oooooooooooooooooooooooooooooooooooooooooooooooo" | 650 "string \"oooooooooooooooooooooooooooooooooooooooooooooooo" |
| 627 "oooooooooooooooooooooooooooooooooooooooooooooooooooo... " | 651 "oooooooooooooooooooooooooooooooooooooooooooooooooooo... " |
| 628 "(1000 bytes in total)\"\n", | 652 "(1000 bytes in total)\"\n", |
| 629 message->ToString()); | 653 message->ToString()); |
| 630 } | 654 } |
| 631 | 655 |
| 632 } // namespace dbus | 656 } // namespace dbus |
| OLD | NEW |