blob: 0eaea8395f52bc66bed9031df7731c8e0a059703 [file] [log] [blame]
keybuk@chromium.orge34b29e2012-02-08 08:48:35 +09001// Copyright (c) 2012 The Chromium Authors. All rights reserved.
satorux@chromium.orgb684e272011-07-31 04:13:31 +09002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
satorux@chromium.orgb684e272011-07-31 04:13:31 +09005#include "dbus/message.h"
rsleevi@chromium.org087421c2011-07-31 05:36:27 +09006
7#include "base/basictypes.h"
8#include "base/logging.h"
satorux@chromium.org8facb242011-08-11 07:34:02 +09009#include "base/memory/scoped_ptr.h"
brettw@chromium.orgb1788fb2012-11-15 05:54:35 +090010#include "base/posix/eintr_wrapper.h"
keybuk@google.combf4649a2012-02-15 06:29:06 +090011#include "dbus/object_path.h"
rharrison@chromium.org3d530352012-02-10 03:14:08 +090012#include "dbus/test_proto.pb.h"
satorux@chromium.orgb684e272011-07-31 04:13:31 +090013#include "testing/gtest/include/gtest/gtest.h"
14
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090015namespace dbus {
16
satorux@chromium.orgb684e272011-07-31 04:13:31 +090017// 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.
19TEST(MessageTest, AppendAndPopByte) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090020 scoped_ptr<Response> message(Response::CreateEmpty());
21 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090022 writer.AppendByte(123); // The input is 123.
23
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090024 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090025 ASSERT_TRUE(reader.HasMoreData()); // Should have data to read.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090026 ASSERT_EQ(Message::BYTE, reader.GetDataType());
benchan464afff2014-08-25 15:50:29 +090027 ASSERT_EQ("y", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090028
29 bool bool_value = false;
30 // Should fail as the type is not bool here.
31 ASSERT_FALSE(reader.PopBool(&bool_value));
32
33 uint8 byte_value = 0;
34 ASSERT_TRUE(reader.PopByte(&byte_value));
35 EXPECT_EQ(123, byte_value); // Should match with the input.
36 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
37
38 // Try to get another byte. Should fail.
39 ASSERT_FALSE(reader.PopByte(&byte_value));
40}
41
42// Check all basic types can be properly written and read.
43TEST(MessageTest, AppendAndPopBasicDataTypes) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090044 scoped_ptr<Response> message(Response::CreateEmpty());
45 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090046
47 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
48 writer.AppendByte(0);
49 writer.AppendBool(true);
50 writer.AppendInt16(2);
51 writer.AppendUint16(3);
52 writer.AppendInt32(4);
53 writer.AppendUint32(5);
54 writer.AppendInt64(6);
55 writer.AppendUint64(7);
56 writer.AppendDouble(8.0);
57 writer.AppendString("string");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090058 writer.AppendObjectPath(ObjectPath("/object/path"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +090059
60 uint8 byte_value = 0;
61 bool bool_value = false;
62 int16 int16_value = 0;
63 uint16 uint16_value = 0;
64 int32 int32_value = 0;
65 uint32 uint32_value = 0;
66 int64 int64_value = 0;
67 uint64 uint64_value = 0;
68 double double_value = 0;
69 std::string string_value;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090070 ObjectPath object_path_value;
satorux@chromium.orgb684e272011-07-31 04:13:31 +090071
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090072 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090073 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +090074 ASSERT_EQ("y", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090075 ASSERT_TRUE(reader.PopByte(&byte_value));
benchan464afff2014-08-25 15:50:29 +090076 ASSERT_EQ("b", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090077 ASSERT_TRUE(reader.PopBool(&bool_value));
benchan464afff2014-08-25 15:50:29 +090078 ASSERT_EQ("n", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090079 ASSERT_TRUE(reader.PopInt16(&int16_value));
benchan464afff2014-08-25 15:50:29 +090080 ASSERT_EQ("q", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090081 ASSERT_TRUE(reader.PopUint16(&uint16_value));
benchan464afff2014-08-25 15:50:29 +090082 ASSERT_EQ("i", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090083 ASSERT_TRUE(reader.PopInt32(&int32_value));
benchan464afff2014-08-25 15:50:29 +090084 ASSERT_EQ("u", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090085 ASSERT_TRUE(reader.PopUint32(&uint32_value));
benchan464afff2014-08-25 15:50:29 +090086 ASSERT_EQ("x", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090087 ASSERT_TRUE(reader.PopInt64(&int64_value));
benchan464afff2014-08-25 15:50:29 +090088 ASSERT_EQ("t", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090089 ASSERT_TRUE(reader.PopUint64(&uint64_value));
benchan464afff2014-08-25 15:50:29 +090090 ASSERT_EQ("d", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090091 ASSERT_TRUE(reader.PopDouble(&double_value));
benchan464afff2014-08-25 15:50:29 +090092 ASSERT_EQ("s", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090093 ASSERT_TRUE(reader.PopString(&string_value));
benchan464afff2014-08-25 15:50:29 +090094 ASSERT_EQ("o", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090095 ASSERT_TRUE(reader.PopObjectPath(&object_path_value));
benchan464afff2014-08-25 15:50:29 +090096 ASSERT_EQ("", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090097 ASSERT_FALSE(reader.HasMoreData());
98
99 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
100 EXPECT_EQ(0, byte_value);
101 EXPECT_EQ(true, bool_value);
102 EXPECT_EQ(2, int16_value);
103 EXPECT_EQ(3U, uint16_value);
104 EXPECT_EQ(4, int32_value);
105 EXPECT_EQ(5U, uint32_value);
106 EXPECT_EQ(6, int64_value);
107 EXPECT_EQ(7U, uint64_value);
108 EXPECT_DOUBLE_EQ(8.0, double_value);
109 EXPECT_EQ("string", string_value);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900110 EXPECT_EQ(ObjectPath("/object/path"), object_path_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900111}
112
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900113// Check all basic types can be properly written and read.
114TEST(MessageTest, AppendAndPopFileDescriptor) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900115 if (!IsDBusTypeUnixFdSupported()) {
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900116 LOG(WARNING) << "FD passing is not supported";
117 return;
118 }
119
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900120 scoped_ptr<Response> message(Response::CreateEmpty());
121 MessageWriter writer(message.get());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900122
123 // Append stdout.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900124 FileDescriptor temp(1);
sleffler@chromium.org48d575f2012-05-11 02:41:10 +0900125 // Descriptor should not be valid until checked.
126 ASSERT_FALSE(temp.is_valid());
127 // NB: thread IO requirements not relevant for unit tests.
128 temp.CheckValidity();
129 ASSERT_TRUE(temp.is_valid());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900130 writer.AppendFileDescriptor(temp);
131
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900132 FileDescriptor fd_value;
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900133
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900134 MessageReader reader(message.get());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900135 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +0900136 ASSERT_EQ(Message::UNIX_FD, reader.GetDataType());
137 ASSERT_EQ("h", reader.GetDataSignature());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900138 ASSERT_TRUE(reader.PopFileDescriptor(&fd_value));
139 ASSERT_FALSE(reader.HasMoreData());
sleffler@chromium.org48d575f2012-05-11 02:41:10 +0900140 // Descriptor is not valid until explicitly checked.
141 ASSERT_FALSE(fd_value.is_valid());
142 fd_value.CheckValidity();
143 ASSERT_TRUE(fd_value.is_valid());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900144
145 // Stdout should be returned but we cannot check the descriptor
146 // value because stdout will be dup'd. Instead check st_rdev
147 // which should be identical.
148 struct stat sb_stdout;
149 int status_stdout = HANDLE_EINTR(fstat(1, &sb_stdout));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900150 ASSERT_GE(status_stdout, 0);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900151 struct stat sb_fd;
152 int status_fd = HANDLE_EINTR(fstat(fd_value.value(), &sb_fd));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900153 ASSERT_GE(status_fd, 0);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900154 EXPECT_EQ(sb_stdout.st_rdev, sb_fd.st_rdev);
155}
156
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900157// Check all variant types can be properly written and read.
158TEST(MessageTest, AppendAndPopVariantDataTypes) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900159 scoped_ptr<Response> message(Response::CreateEmpty());
160 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900161
162 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
163 writer.AppendVariantOfByte(0);
164 writer.AppendVariantOfBool(true);
165 writer.AppendVariantOfInt16(2);
166 writer.AppendVariantOfUint16(3);
167 writer.AppendVariantOfInt32(4);
168 writer.AppendVariantOfUint32(5);
169 writer.AppendVariantOfInt64(6);
170 writer.AppendVariantOfUint64(7);
171 writer.AppendVariantOfDouble(8.0);
172 writer.AppendVariantOfString("string");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900173 writer.AppendVariantOfObjectPath(ObjectPath("/object/path"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900174
175 uint8 byte_value = 0;
176 bool bool_value = false;
177 int16 int16_value = 0;
178 uint16 uint16_value = 0;
179 int32 int32_value = 0;
180 uint32 uint32_value = 0;
181 int64 int64_value = 0;
182 uint64 uint64_value = 0;
183 double double_value = 0;
184 std::string string_value;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900185 ObjectPath object_path_value;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900186
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900187 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900188 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +0900189 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900190 ASSERT_TRUE(reader.PopVariantOfByte(&byte_value));
benchan464afff2014-08-25 15:50:29 +0900191 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900192 ASSERT_TRUE(reader.PopVariantOfBool(&bool_value));
benchan464afff2014-08-25 15:50:29 +0900193 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900194 ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value));
benchan464afff2014-08-25 15:50:29 +0900195 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900196 ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_value));
benchan464afff2014-08-25 15:50:29 +0900197 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900198 ASSERT_TRUE(reader.PopVariantOfInt32(&int32_value));
benchan464afff2014-08-25 15:50:29 +0900199 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900200 ASSERT_TRUE(reader.PopVariantOfUint32(&uint32_value));
benchan464afff2014-08-25 15:50:29 +0900201 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900202 ASSERT_TRUE(reader.PopVariantOfInt64(&int64_value));
benchan464afff2014-08-25 15:50:29 +0900203 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900204 ASSERT_TRUE(reader.PopVariantOfUint64(&uint64_value));
benchan464afff2014-08-25 15:50:29 +0900205 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900206 ASSERT_TRUE(reader.PopVariantOfDouble(&double_value));
benchan464afff2014-08-25 15:50:29 +0900207 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900208 ASSERT_TRUE(reader.PopVariantOfString(&string_value));
benchan464afff2014-08-25 15:50:29 +0900209 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900210 ASSERT_TRUE(reader.PopVariantOfObjectPath(&object_path_value));
benchan464afff2014-08-25 15:50:29 +0900211 ASSERT_EQ("", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900212 ASSERT_FALSE(reader.HasMoreData());
213
214 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
215 EXPECT_EQ(0, byte_value);
216 EXPECT_EQ(true, bool_value);
217 EXPECT_EQ(2, int16_value);
218 EXPECT_EQ(3U, uint16_value);
219 EXPECT_EQ(4, int32_value);
220 EXPECT_EQ(5U, uint32_value);
221 EXPECT_EQ(6, int64_value);
222 EXPECT_EQ(7U, uint64_value);
223 EXPECT_DOUBLE_EQ(8.0, double_value);
224 EXPECT_EQ("string", string_value);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900225 EXPECT_EQ(ObjectPath("/object/path"), object_path_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900226}
227
228TEST(MessageTest, ArrayOfBytes) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900229 scoped_ptr<Response> message(Response::CreateEmpty());
230 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900231 std::vector<uint8> bytes;
232 bytes.push_back(1);
233 bytes.push_back(2);
234 bytes.push_back(3);
235 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
236
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900237 MessageReader reader(message.get());
derat@chromium.org2bf9e5c2014-02-25 00:59:40 +0900238 const uint8* output_bytes = NULL;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900239 size_t length = 0;
benchan464afff2014-08-25 15:50:29 +0900240 ASSERT_EQ("ay", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900241 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length));
242 ASSERT_FALSE(reader.HasMoreData());
243 ASSERT_EQ(3U, length);
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900244 EXPECT_EQ(1, output_bytes[0]);
245 EXPECT_EQ(2, output_bytes[1]);
246 EXPECT_EQ(3, output_bytes[2]);
247}
248
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900249TEST(MessageTest, ArrayOfBytes_Empty) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900250 scoped_ptr<Response> message(Response::CreateEmpty());
251 MessageWriter writer(message.get());
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900252 std::vector<uint8> bytes;
253 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
254
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900255 MessageReader reader(message.get());
derat@chromium.org2bf9e5c2014-02-25 00:59:40 +0900256 const uint8* output_bytes = NULL;
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900257 size_t length = 0;
benchan464afff2014-08-25 15:50:29 +0900258 ASSERT_EQ("ay", reader.GetDataSignature());
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900259 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length));
260 ASSERT_FALSE(reader.HasMoreData());
261 ASSERT_EQ(0U, length);
262 EXPECT_EQ(NULL, output_bytes);
263}
264
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900265TEST(MessageTest, ArrayOfStrings) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900266 scoped_ptr<Response> message(Response::CreateEmpty());
267 MessageWriter writer(message.get());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900268 std::vector<std::string> strings;
269 strings.push_back("fee");
270 strings.push_back("fie");
271 strings.push_back("foe");
272 strings.push_back("fum");
273 writer.AppendArrayOfStrings(strings);
274
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900275 MessageReader reader(message.get());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900276 std::vector<std::string> output_strings;
benchan464afff2014-08-25 15:50:29 +0900277 ASSERT_EQ("as", reader.GetDataSignature());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900278 ASSERT_TRUE(reader.PopArrayOfStrings(&output_strings));
279 ASSERT_FALSE(reader.HasMoreData());
280 ASSERT_EQ(4U, output_strings.size());
281 EXPECT_EQ("fee", output_strings[0]);
282 EXPECT_EQ("fie", output_strings[1]);
283 EXPECT_EQ("foe", output_strings[2]);
284 EXPECT_EQ("fum", output_strings[3]);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900285}
286
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900287TEST(MessageTest, ArrayOfObjectPaths) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900288 scoped_ptr<Response> message(Response::CreateEmpty());
289 MessageWriter writer(message.get());
290 std::vector<ObjectPath> object_paths;
291 object_paths.push_back(ObjectPath("/object/path/1"));
292 object_paths.push_back(ObjectPath("/object/path/2"));
293 object_paths.push_back(ObjectPath("/object/path/3"));
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900294 writer.AppendArrayOfObjectPaths(object_paths);
295
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900296 MessageReader reader(message.get());
297 std::vector<ObjectPath> output_object_paths;
benchan464afff2014-08-25 15:50:29 +0900298 ASSERT_EQ("ao", reader.GetDataSignature());
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900299 ASSERT_TRUE(reader.PopArrayOfObjectPaths(&output_object_paths));
300 ASSERT_FALSE(reader.HasMoreData());
301 ASSERT_EQ(3U, output_object_paths.size());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900302 EXPECT_EQ(ObjectPath("/object/path/1"), output_object_paths[0]);
303 EXPECT_EQ(ObjectPath("/object/path/2"), output_object_paths[1]);
304 EXPECT_EQ(ObjectPath("/object/path/3"), output_object_paths[2]);
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900305}
306
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900307TEST(MessageTest, ProtoBuf) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900308 scoped_ptr<Response> message(Response::CreateEmpty());
309 MessageWriter writer(message.get());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900310 TestProto send_message;
311 send_message.set_text("testing");
312 send_message.set_number(123);
313 writer.AppendProtoAsArrayOfBytes(send_message);
314
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900315 MessageReader reader(message.get());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900316 TestProto receive_message;
benchan464afff2014-08-25 15:50:29 +0900317 ASSERT_EQ("ay", reader.GetDataSignature());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900318 ASSERT_TRUE(reader.PopArrayOfBytesAsProto(&receive_message));
319 EXPECT_EQ(receive_message.text(), send_message.text());
320 EXPECT_EQ(receive_message.number(), send_message.number());
321}
322
323
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900324// Test that an array can be properly written and read. We only have this
325// test for array, as repeating this for other container types is too
326// redundant.
327TEST(MessageTest, OpenArrayAndPopArray) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900328 scoped_ptr<Response> message(Response::CreateEmpty());
329 MessageWriter writer(message.get());
330 MessageWriter array_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900331 writer.OpenArray("s", &array_writer); // Open an array of strings.
332 array_writer.AppendString("foo");
333 array_writer.AppendString("bar");
334 array_writer.AppendString("baz");
335 writer.CloseContainer(&array_writer);
336
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900337 MessageReader reader(message.get());
338 ASSERT_EQ(Message::ARRAY, reader.GetDataType());
benchan464afff2014-08-25 15:50:29 +0900339 ASSERT_EQ("as", reader.GetDataSignature());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900340 MessageReader array_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900341 ASSERT_TRUE(reader.PopArray(&array_reader));
342 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
343
344 std::string string_value;
345 ASSERT_TRUE(array_reader.PopString(&string_value));
346 EXPECT_EQ("foo", string_value);
347 ASSERT_TRUE(array_reader.PopString(&string_value));
348 EXPECT_EQ("bar", string_value);
349 ASSERT_TRUE(array_reader.PopString(&string_value));
350 EXPECT_EQ("baz", string_value);
351 // Should not have more data to read.
352 ASSERT_FALSE(array_reader.HasMoreData());
353}
354
355// Create a complex message using array, struct, variant, dict entry, and
356// make sure it can be read properly.
357TEST(MessageTest, CreateComplexMessageAndReadIt) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900358 scoped_ptr<Response> message(Response::CreateEmpty());
359 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900360 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900361 MessageWriter array_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900362 // Open an array of variants.
363 writer.OpenArray("v", &array_writer);
364 {
365 // The first value in the array.
366 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900367 MessageWriter variant_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900368 // Open a variant of a boolean.
369 array_writer.OpenVariant("b", &variant_writer);
370 variant_writer.AppendBool(true);
371 array_writer.CloseContainer(&variant_writer);
372 }
373
374 // The second value in the array.
375 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900376 MessageWriter variant_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900377 // Open a variant of a struct that contains a string and an int32.
378 array_writer.OpenVariant("(si)", &variant_writer);
379 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900380 MessageWriter struct_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900381 variant_writer.OpenStruct(&struct_writer);
382 struct_writer.AppendString("string");
383 struct_writer.AppendInt32(123);
384 variant_writer.CloseContainer(&struct_writer);
385 }
386 array_writer.CloseContainer(&variant_writer);
387 }
388
389 // The third value in the array.
390 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900391 MessageWriter variant_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900392 // Open a variant of an array of string-to-int64 dict entries.
393 array_writer.OpenVariant("a{sx}", &variant_writer);
394 {
395 // Opens an array of string-to-int64 dict entries.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900396 MessageWriter dict_array_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900397 variant_writer.OpenArray("{sx}", &dict_array_writer);
398 {
399 // Opens a string-to-int64 dict entries.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900400 MessageWriter dict_entry_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900401 dict_array_writer.OpenDictEntry(&dict_entry_writer);
402 dict_entry_writer.AppendString("foo");
rsleevi@chromium.org087421c2011-07-31 05:36:27 +0900403 dict_entry_writer.AppendInt64(GG_INT64_C(1234567890123456789));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900404 dict_array_writer.CloseContainer(&dict_entry_writer);
405 }
406 variant_writer.CloseContainer(&dict_array_writer);
407 }
408 array_writer.CloseContainer(&variant_writer);
409 }
410 }
411 writer.CloseContainer(&array_writer);
412 }
413 // What we have created looks like this:
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900414 EXPECT_EQ("message_type: MESSAGE_METHOD_RETURN\n"
415 "signature: av\n"
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900416 "\n"
417 "array [\n"
418 " variant bool true\n"
419 " variant struct {\n"
420 " string \"string\"\n"
421 " int32 123\n"
422 " }\n"
423 " variant array [\n"
424 " dict entry {\n"
425 " string \"foo\"\n"
426 " int64 1234567890123456789\n"
427 " }\n"
428 " ]\n"
429 "]\n",
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900430 message->ToString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900431
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900432 MessageReader reader(message.get());
benchan464afff2014-08-25 15:50:29 +0900433 ASSERT_EQ("av", reader.GetDataSignature());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900434 MessageReader array_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900435 ASSERT_TRUE(reader.PopArray(&array_reader));
436
437 // The first value in the array.
438 bool bool_value = false;
benchan464afff2014-08-25 15:50:29 +0900439 ASSERT_EQ("v", array_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900440 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value));
441 EXPECT_EQ(true, bool_value);
442
443 // The second value in the array.
444 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900445 MessageReader variant_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900446 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
447 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900448 MessageReader struct_reader(NULL);
benchan464afff2014-08-25 15:50:29 +0900449 ASSERT_EQ("(si)", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900450 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader));
451 std::string string_value;
452 ASSERT_TRUE(struct_reader.PopString(&string_value));
453 EXPECT_EQ("string", string_value);
454 int32 int32_value = 0;
455 ASSERT_TRUE(struct_reader.PopInt32(&int32_value));
456 EXPECT_EQ(123, int32_value);
457 ASSERT_FALSE(struct_reader.HasMoreData());
458 }
459 ASSERT_FALSE(variant_reader.HasMoreData());
460 }
461
462 // The third value in the array.
463 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900464 MessageReader variant_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900465 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
466 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900467 MessageReader dict_array_reader(NULL);
benchan464afff2014-08-25 15:50:29 +0900468 ASSERT_EQ("a{sx}", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900469 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader));
470 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900471 MessageReader dict_entry_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900472 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader));
473 std::string string_value;
474 ASSERT_TRUE(dict_entry_reader.PopString(&string_value));
475 EXPECT_EQ("foo", string_value);
476 int64 int64_value = 0;
477 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value));
rsleevi@chromium.org087421c2011-07-31 05:36:27 +0900478 EXPECT_EQ(GG_INT64_C(1234567890123456789), int64_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900479 }
480 ASSERT_FALSE(dict_array_reader.HasMoreData());
481 }
482 ASSERT_FALSE(variant_reader.HasMoreData());
483 }
484 ASSERT_FALSE(array_reader.HasMoreData());
485 ASSERT_FALSE(reader.HasMoreData());
486}
487
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900488TEST(MessageTest, MethodCall) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900489 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900490 EXPECT_TRUE(method_call.raw_message() != NULL);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900491 EXPECT_EQ(Message::MESSAGE_METHOD_CALL, method_call.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900492 EXPECT_EQ("MESSAGE_METHOD_CALL", method_call.GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900493 method_call.SetDestination("com.example.Service");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900494 method_call.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900495
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900496 MessageWriter writer(&method_call);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900497 writer.AppendString("payload");
498
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900499 EXPECT_EQ("message_type: MESSAGE_METHOD_CALL\n"
500 "destination: com.example.Service\n"
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900501 "path: /com/example/Object\n"
502 "interface: com.example.Interface\n"
503 "member: SomeMethod\n"
504 "signature: s\n"
505 "\n"
506 "string \"payload\"\n",
507 method_call.ToString());
508}
509
satorux@chromium.org8facb242011-08-11 07:34:02 +0900510TEST(MessageTest, MethodCall_FromRawMessage) {
511 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL);
512 dbus_message_set_interface(raw_message, "com.example.Interface");
513 dbus_message_set_member(raw_message, "SomeMethod");
514
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900515 scoped_ptr<MethodCall> method_call(MethodCall::FromRawMessage(raw_message));
satorux@chromium.org8facb242011-08-11 07:34:02 +0900516 EXPECT_EQ("com.example.Interface", method_call->GetInterface());
517 EXPECT_EQ("SomeMethod", method_call->GetMember());
518}
519
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900520TEST(MessageTest, Signal) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900521 Signal signal("com.example.Interface", "SomeSignal");
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900522 EXPECT_TRUE(signal.raw_message() != NULL);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900523 EXPECT_EQ(Message::MESSAGE_SIGNAL, signal.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900524 EXPECT_EQ("MESSAGE_SIGNAL", signal.GetMessageTypeAsString());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900525 signal.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900526
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900527 MessageWriter writer(&signal);
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900528 writer.AppendString("payload");
529
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900530 EXPECT_EQ("message_type: MESSAGE_SIGNAL\n"
531 "path: /com/example/Object\n"
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900532 "interface: com.example.Interface\n"
533 "member: SomeSignal\n"
534 "signature: s\n"
535 "\n"
536 "string \"payload\"\n",
537 signal.ToString());
538}
539
540TEST(MessageTest, Signal_FromRawMessage) {
541 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_SIGNAL);
542 dbus_message_set_interface(raw_message, "com.example.Interface");
543 dbus_message_set_member(raw_message, "SomeSignal");
544
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900545 scoped_ptr<Signal> signal(Signal::FromRawMessage(raw_message));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900546 EXPECT_EQ("com.example.Interface", signal->GetInterface());
547 EXPECT_EQ("SomeSignal", signal->GetMember());
548}
549
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900550TEST(MessageTest, Response) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900551 scoped_ptr<Response> response(Response::CreateEmpty());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900552 EXPECT_TRUE(response->raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900553 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900554 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900555}
556
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900557TEST(MessageTest, Response_FromMethodCall) {
satorux@chromium.org8facb242011-08-11 07:34:02 +0900558 const uint32 kSerial = 123;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900559 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900560 method_call.SetSerial(kSerial);
561
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900562 scoped_ptr<Response> response(
563 Response::FromMethodCall(&method_call));
564 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900565 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900566 // The serial should be copied to the reply serial.
567 EXPECT_EQ(kSerial, response->GetReplySerial());
568}
569
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900570TEST(MessageTest, ErrorResponse_FromMethodCall) {
satorux@chromium.org8facb242011-08-11 07:34:02 +0900571 const uint32 kSerial = 123;
572const char kErrorMessage[] = "error message";
573
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900574 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900575 method_call.SetSerial(kSerial);
576
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900577 scoped_ptr<ErrorResponse> error_response(
578 ErrorResponse::FromMethodCall(&method_call,
579 DBUS_ERROR_FAILED,
580 kErrorMessage));
581 EXPECT_EQ(Message::MESSAGE_ERROR, error_response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900582 EXPECT_EQ("MESSAGE_ERROR", error_response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900583 // The serial should be copied to the reply serial.
584 EXPECT_EQ(kSerial, error_response->GetReplySerial());
585
586 // Error message should be added to the payload.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900587 MessageReader reader(error_response.get());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900588 std::string error_message;
589 ASSERT_TRUE(reader.PopString(&error_message));
590 EXPECT_EQ(kErrorMessage, error_message);
591}
592
satorux@chromium.org8facb242011-08-11 07:34:02 +0900593TEST(MessageTest, GetAndSetHeaders) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900594 scoped_ptr<Response> message(Response::CreateEmpty());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900595
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900596 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900597 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900598 EXPECT_EQ("", message->GetInterface());
599 EXPECT_EQ("", message->GetMember());
600 EXPECT_EQ("", message->GetErrorName());
601 EXPECT_EQ("", message->GetSender());
602 EXPECT_EQ(0U, message->GetSerial());
603 EXPECT_EQ(0U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900604
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900605 EXPECT_TRUE(message->SetDestination("org.chromium.destination"));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900606 EXPECT_TRUE(message->SetPath(ObjectPath("/org/chromium/path")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900607 EXPECT_TRUE(message->SetInterface("org.chromium.interface"));
608 EXPECT_TRUE(message->SetMember("member"));
609 EXPECT_TRUE(message->SetErrorName("org.chromium.error"));
610 EXPECT_TRUE(message->SetSender(":1.2"));
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900611 message->SetSerial(123);
612 message->SetReplySerial(456);
satorux@chromium.org8facb242011-08-11 07:34:02 +0900613
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900614 EXPECT_EQ("org.chromium.destination", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900615 EXPECT_EQ(ObjectPath("/org/chromium/path"), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900616 EXPECT_EQ("org.chromium.interface", message->GetInterface());
617 EXPECT_EQ("member", message->GetMember());
618 EXPECT_EQ("org.chromium.error", message->GetErrorName());
619 EXPECT_EQ(":1.2", message->GetSender());
620 EXPECT_EQ(123U, message->GetSerial());
621 EXPECT_EQ(456U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900622}
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900623
624TEST(MessageTest, SetInvalidHeaders) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900625 scoped_ptr<Response> message(Response::CreateEmpty());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900626 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900627 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900628 EXPECT_EQ("", message->GetInterface());
629 EXPECT_EQ("", message->GetMember());
630 EXPECT_EQ("", message->GetErrorName());
631 EXPECT_EQ("", message->GetSender());
632
633 // Empty element between periods.
634 EXPECT_FALSE(message->SetDestination("org..chromium"));
635 // Trailing '/' is only allowed for the root path.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900636 EXPECT_FALSE(message->SetPath(ObjectPath("/org/chromium/")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900637 // Interface name cannot contain '/'.
638 EXPECT_FALSE(message->SetInterface("org/chromium/interface"));
639 // Member name cannot begin with a digit.
640 EXPECT_FALSE(message->SetMember("1member"));
641 // Error name cannot begin with a period.
642 EXPECT_FALSE(message->SetErrorName(".org.chromium.error"));
643 // Disallowed characters.
644 EXPECT_FALSE(message->SetSender("?!#*"));
645
646 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900647 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900648 EXPECT_EQ("", message->GetInterface());
649 EXPECT_EQ("", message->GetMember());
650 EXPECT_EQ("", message->GetErrorName());
651 EXPECT_EQ("", message->GetSender());
652}
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900653
654TEST(MessageTest, ToString_LongString) {
655 const std::string kLongString(1000, 'o');
656
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900657 scoped_ptr<Response> message(Response::CreateEmpty());
658 MessageWriter writer(message.get());
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900659 writer.AppendString(kLongString);
660
661 ASSERT_EQ("message_type: MESSAGE_METHOD_RETURN\n"
662 "signature: s\n\n"
663 "string \"oooooooooooooooooooooooooooooooooooooooooooooooo"
664 "oooooooooooooooooooooooooooooooooooooooooooooooooooo... "
665 "(1000 bytes in total)\"\n",
666 message->ToString());
667}
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900668
669} // namespace dbus