blob: a58b36b2dc08eb05f433acb0d21df5440b645c36 [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
avi0ad0ce02015-12-23 03:12:45 +09007#include <stddef.h>
tfarina22cc81a2015-04-21 05:35:20 +09008#include <stdint.h>
9
dcheng30c5a172016-04-09 07:55:04 +090010#include <memory>
11
rsleevi@chromium.org087421c2011-07-31 05:36:27 +090012#include "base/logging.h"
brettw@chromium.orgb1788fb2012-11-15 05:54:35 +090013#include "base/posix/eintr_wrapper.h"
keybuk@google.combf4649a2012-02-15 06:29:06 +090014#include "dbus/object_path.h"
rharrison@chromium.org3d530352012-02-10 03:14:08 +090015#include "dbus/test_proto.pb.h"
satorux@chromium.orgb684e272011-07-31 04:13:31 +090016#include "testing/gtest/include/gtest/gtest.h"
17
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090018namespace dbus {
19
satorux@chromium.orgb684e272011-07-31 04:13:31 +090020// Test that a byte can be properly written and read. We only have this
21// test for byte, as repeating this for other basic types is too redundant.
22TEST(MessageTest, AppendAndPopByte) {
dcheng30c5a172016-04-09 07:55:04 +090023 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090024 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090025 writer.AppendByte(123); // The input is 123.
26
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090027 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090028 ASSERT_TRUE(reader.HasMoreData()); // Should have data to read.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090029 ASSERT_EQ(Message::BYTE, reader.GetDataType());
benchan464afff2014-08-25 15:50:29 +090030 ASSERT_EQ("y", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090031
32 bool bool_value = false;
33 // Should fail as the type is not bool here.
34 ASSERT_FALSE(reader.PopBool(&bool_value));
35
avi0ad0ce02015-12-23 03:12:45 +090036 uint8_t byte_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +090037 ASSERT_TRUE(reader.PopByte(&byte_value));
38 EXPECT_EQ(123, byte_value); // Should match with the input.
39 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
40
41 // Try to get another byte. Should fail.
42 ASSERT_FALSE(reader.PopByte(&byte_value));
43}
44
45// Check all basic types can be properly written and read.
46TEST(MessageTest, AppendAndPopBasicDataTypes) {
dcheng30c5a172016-04-09 07:55:04 +090047 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090048 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090049
50 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
51 writer.AppendByte(0);
52 writer.AppendBool(true);
53 writer.AppendInt16(2);
54 writer.AppendUint16(3);
55 writer.AppendInt32(4);
56 writer.AppendUint32(5);
57 writer.AppendInt64(6);
58 writer.AppendUint64(7);
59 writer.AppendDouble(8.0);
60 writer.AppendString("string");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090061 writer.AppendObjectPath(ObjectPath("/object/path"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +090062
avi0ad0ce02015-12-23 03:12:45 +090063 uint8_t byte_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +090064 bool bool_value = false;
avi0ad0ce02015-12-23 03:12:45 +090065 int16_t int16_value = 0;
66 uint16_t uint16_value = 0;
67 int32_t int32_value = 0;
68 uint32_t uint32_value = 0;
69 int64_t int64_value = 0;
70 uint64_t uint64_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +090071 double double_value = 0;
72 std::string string_value;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090073 ObjectPath object_path_value;
satorux@chromium.orgb684e272011-07-31 04:13:31 +090074
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +090075 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090076 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +090077 ASSERT_EQ("y", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090078 ASSERT_TRUE(reader.PopByte(&byte_value));
benchan464afff2014-08-25 15:50:29 +090079 ASSERT_EQ("b", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090080 ASSERT_TRUE(reader.PopBool(&bool_value));
benchan464afff2014-08-25 15:50:29 +090081 ASSERT_EQ("n", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090082 ASSERT_TRUE(reader.PopInt16(&int16_value));
benchan464afff2014-08-25 15:50:29 +090083 ASSERT_EQ("q", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090084 ASSERT_TRUE(reader.PopUint16(&uint16_value));
benchan464afff2014-08-25 15:50:29 +090085 ASSERT_EQ("i", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090086 ASSERT_TRUE(reader.PopInt32(&int32_value));
benchan464afff2014-08-25 15:50:29 +090087 ASSERT_EQ("u", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090088 ASSERT_TRUE(reader.PopUint32(&uint32_value));
benchan464afff2014-08-25 15:50:29 +090089 ASSERT_EQ("x", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090090 ASSERT_TRUE(reader.PopInt64(&int64_value));
benchan464afff2014-08-25 15:50:29 +090091 ASSERT_EQ("t", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090092 ASSERT_TRUE(reader.PopUint64(&uint64_value));
benchan464afff2014-08-25 15:50:29 +090093 ASSERT_EQ("d", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090094 ASSERT_TRUE(reader.PopDouble(&double_value));
benchan464afff2014-08-25 15:50:29 +090095 ASSERT_EQ("s", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090096 ASSERT_TRUE(reader.PopString(&string_value));
benchan464afff2014-08-25 15:50:29 +090097 ASSERT_EQ("o", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +090098 ASSERT_TRUE(reader.PopObjectPath(&object_path_value));
benchan464afff2014-08-25 15:50:29 +090099 ASSERT_EQ("", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900100 ASSERT_FALSE(reader.HasMoreData());
101
102 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
103 EXPECT_EQ(0, byte_value);
104 EXPECT_EQ(true, bool_value);
105 EXPECT_EQ(2, int16_value);
106 EXPECT_EQ(3U, uint16_value);
107 EXPECT_EQ(4, int32_value);
108 EXPECT_EQ(5U, uint32_value);
109 EXPECT_EQ(6, int64_value);
110 EXPECT_EQ(7U, uint64_value);
111 EXPECT_DOUBLE_EQ(8.0, double_value);
112 EXPECT_EQ("string", string_value);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900113 EXPECT_EQ(ObjectPath("/object/path"), object_path_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900114}
115
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900116// Check all basic types can be properly written and read.
117TEST(MessageTest, AppendAndPopFileDescriptor) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900118 if (!IsDBusTypeUnixFdSupported()) {
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900119 LOG(WARNING) << "FD passing is not supported";
120 return;
121 }
122
dcheng30c5a172016-04-09 07:55:04 +0900123 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900124 MessageWriter writer(message.get());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900125
126 // Append stdout.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900127 FileDescriptor temp(1);
sleffler@chromium.org48d575f2012-05-11 02:41:10 +0900128 // Descriptor should not be valid until checked.
129 ASSERT_FALSE(temp.is_valid());
130 // NB: thread IO requirements not relevant for unit tests.
131 temp.CheckValidity();
132 ASSERT_TRUE(temp.is_valid());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900133 writer.AppendFileDescriptor(temp);
134
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900135 FileDescriptor fd_value;
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900136
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900137 MessageReader reader(message.get());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900138 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +0900139 ASSERT_EQ(Message::UNIX_FD, reader.GetDataType());
140 ASSERT_EQ("h", reader.GetDataSignature());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900141 ASSERT_TRUE(reader.PopFileDescriptor(&fd_value));
142 ASSERT_FALSE(reader.HasMoreData());
sleffler@chromium.org48d575f2012-05-11 02:41:10 +0900143 // Descriptor is not valid until explicitly checked.
144 ASSERT_FALSE(fd_value.is_valid());
145 fd_value.CheckValidity();
146 ASSERT_TRUE(fd_value.is_valid());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900147
148 // Stdout should be returned but we cannot check the descriptor
149 // value because stdout will be dup'd. Instead check st_rdev
150 // which should be identical.
151 struct stat sb_stdout;
152 int status_stdout = HANDLE_EINTR(fstat(1, &sb_stdout));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900153 ASSERT_GE(status_stdout, 0);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900154 struct stat sb_fd;
155 int status_fd = HANDLE_EINTR(fstat(fd_value.value(), &sb_fd));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900156 ASSERT_GE(status_fd, 0);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900157 EXPECT_EQ(sb_stdout.st_rdev, sb_fd.st_rdev);
158}
159
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900160// Check all variant types can be properly written and read.
161TEST(MessageTest, AppendAndPopVariantDataTypes) {
dcheng30c5a172016-04-09 07:55:04 +0900162 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900163 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900164
165 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
166 writer.AppendVariantOfByte(0);
167 writer.AppendVariantOfBool(true);
168 writer.AppendVariantOfInt16(2);
169 writer.AppendVariantOfUint16(3);
170 writer.AppendVariantOfInt32(4);
171 writer.AppendVariantOfUint32(5);
172 writer.AppendVariantOfInt64(6);
173 writer.AppendVariantOfUint64(7);
174 writer.AppendVariantOfDouble(8.0);
175 writer.AppendVariantOfString("string");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900176 writer.AppendVariantOfObjectPath(ObjectPath("/object/path"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900177
avi0ad0ce02015-12-23 03:12:45 +0900178 uint8_t byte_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900179 bool bool_value = false;
avi0ad0ce02015-12-23 03:12:45 +0900180 int16_t int16_value = 0;
181 uint16_t uint16_value = 0;
182 int32_t int32_value = 0;
183 uint32_t uint32_value = 0;
184 int64_t int64_value = 0;
185 uint64_t uint64_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900186 double double_value = 0;
187 std::string string_value;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900188 ObjectPath object_path_value;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900189
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900190 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900191 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +0900192 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900193 ASSERT_TRUE(reader.PopVariantOfByte(&byte_value));
benchan464afff2014-08-25 15:50:29 +0900194 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900195 ASSERT_TRUE(reader.PopVariantOfBool(&bool_value));
benchan464afff2014-08-25 15:50:29 +0900196 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900197 ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value));
benchan464afff2014-08-25 15:50:29 +0900198 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900199 ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_value));
benchan464afff2014-08-25 15:50:29 +0900200 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900201 ASSERT_TRUE(reader.PopVariantOfInt32(&int32_value));
benchan464afff2014-08-25 15:50:29 +0900202 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900203 ASSERT_TRUE(reader.PopVariantOfUint32(&uint32_value));
benchan464afff2014-08-25 15:50:29 +0900204 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900205 ASSERT_TRUE(reader.PopVariantOfInt64(&int64_value));
benchan464afff2014-08-25 15:50:29 +0900206 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900207 ASSERT_TRUE(reader.PopVariantOfUint64(&uint64_value));
benchan464afff2014-08-25 15:50:29 +0900208 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900209 ASSERT_TRUE(reader.PopVariantOfDouble(&double_value));
benchan464afff2014-08-25 15:50:29 +0900210 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900211 ASSERT_TRUE(reader.PopVariantOfString(&string_value));
benchan464afff2014-08-25 15:50:29 +0900212 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900213 ASSERT_TRUE(reader.PopVariantOfObjectPath(&object_path_value));
benchan464afff2014-08-25 15:50:29 +0900214 ASSERT_EQ("", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900215 ASSERT_FALSE(reader.HasMoreData());
216
217 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
218 EXPECT_EQ(0, byte_value);
219 EXPECT_EQ(true, bool_value);
220 EXPECT_EQ(2, int16_value);
221 EXPECT_EQ(3U, uint16_value);
222 EXPECT_EQ(4, int32_value);
223 EXPECT_EQ(5U, uint32_value);
224 EXPECT_EQ(6, int64_value);
225 EXPECT_EQ(7U, uint64_value);
226 EXPECT_DOUBLE_EQ(8.0, double_value);
227 EXPECT_EQ("string", string_value);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900228 EXPECT_EQ(ObjectPath("/object/path"), object_path_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900229}
230
231TEST(MessageTest, ArrayOfBytes) {
dcheng30c5a172016-04-09 07:55:04 +0900232 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900233 MessageWriter writer(message.get());
avi0ad0ce02015-12-23 03:12:45 +0900234 std::vector<uint8_t> bytes;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900235 bytes.push_back(1);
236 bytes.push_back(2);
237 bytes.push_back(3);
238 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
239
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900240 MessageReader reader(message.get());
avi0ad0ce02015-12-23 03:12:45 +0900241 const uint8_t* output_bytes = NULL;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900242 size_t length = 0;
benchan464afff2014-08-25 15:50:29 +0900243 ASSERT_EQ("ay", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900244 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length));
245 ASSERT_FALSE(reader.HasMoreData());
246 ASSERT_EQ(3U, length);
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900247 EXPECT_EQ(1, output_bytes[0]);
248 EXPECT_EQ(2, output_bytes[1]);
249 EXPECT_EQ(3, output_bytes[2]);
250}
251
warxef0f8372016-03-31 06:27:41 +0900252TEST(MessageTest, ArrayOfDoubles) {
dcheng30c5a172016-04-09 07:55:04 +0900253 std::unique_ptr<Response> message(Response::CreateEmpty());
warxef0f8372016-03-31 06:27:41 +0900254 MessageWriter writer(message.get());
255 std::vector<double> doubles;
256 doubles.push_back(0.2);
257 doubles.push_back(0.5);
258 doubles.push_back(1);
259 writer.AppendArrayOfDoubles(doubles.data(), doubles.size());
260
261 MessageReader reader(message.get());
262 const double* output_doubles = NULL;
263 size_t length = 0;
264 ASSERT_EQ("ad", reader.GetDataSignature());
265 ASSERT_TRUE(reader.PopArrayOfDoubles(&output_doubles, &length));
266 ASSERT_FALSE(reader.HasMoreData());
267 ASSERT_EQ(3U, length);
268 EXPECT_EQ(0.2, output_doubles[0]);
269 EXPECT_EQ(0.5, output_doubles[1]);
270 EXPECT_EQ(1, output_doubles[2]);
271}
272
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900273TEST(MessageTest, ArrayOfBytes_Empty) {
dcheng30c5a172016-04-09 07:55:04 +0900274 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900275 MessageWriter writer(message.get());
avi0ad0ce02015-12-23 03:12:45 +0900276 std::vector<uint8_t> bytes;
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900277 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
278
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900279 MessageReader reader(message.get());
avi0ad0ce02015-12-23 03:12:45 +0900280 const uint8_t* output_bytes = NULL;
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900281 size_t length = 0;
benchan464afff2014-08-25 15:50:29 +0900282 ASSERT_EQ("ay", reader.GetDataSignature());
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900283 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length));
284 ASSERT_FALSE(reader.HasMoreData());
285 ASSERT_EQ(0U, length);
286 EXPECT_EQ(NULL, output_bytes);
287}
288
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900289TEST(MessageTest, ArrayOfStrings) {
dcheng30c5a172016-04-09 07:55:04 +0900290 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900291 MessageWriter writer(message.get());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900292 std::vector<std::string> strings;
293 strings.push_back("fee");
294 strings.push_back("fie");
295 strings.push_back("foe");
296 strings.push_back("fum");
297 writer.AppendArrayOfStrings(strings);
298
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900299 MessageReader reader(message.get());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900300 std::vector<std::string> output_strings;
benchan464afff2014-08-25 15:50:29 +0900301 ASSERT_EQ("as", reader.GetDataSignature());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900302 ASSERT_TRUE(reader.PopArrayOfStrings(&output_strings));
303 ASSERT_FALSE(reader.HasMoreData());
304 ASSERT_EQ(4U, output_strings.size());
305 EXPECT_EQ("fee", output_strings[0]);
306 EXPECT_EQ("fie", output_strings[1]);
307 EXPECT_EQ("foe", output_strings[2]);
308 EXPECT_EQ("fum", output_strings[3]);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900309}
310
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900311TEST(MessageTest, ArrayOfObjectPaths) {
dcheng30c5a172016-04-09 07:55:04 +0900312 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900313 MessageWriter writer(message.get());
314 std::vector<ObjectPath> object_paths;
315 object_paths.push_back(ObjectPath("/object/path/1"));
316 object_paths.push_back(ObjectPath("/object/path/2"));
317 object_paths.push_back(ObjectPath("/object/path/3"));
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900318 writer.AppendArrayOfObjectPaths(object_paths);
319
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900320 MessageReader reader(message.get());
321 std::vector<ObjectPath> output_object_paths;
benchan464afff2014-08-25 15:50:29 +0900322 ASSERT_EQ("ao", reader.GetDataSignature());
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900323 ASSERT_TRUE(reader.PopArrayOfObjectPaths(&output_object_paths));
324 ASSERT_FALSE(reader.HasMoreData());
325 ASSERT_EQ(3U, output_object_paths.size());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900326 EXPECT_EQ(ObjectPath("/object/path/1"), output_object_paths[0]);
327 EXPECT_EQ(ObjectPath("/object/path/2"), output_object_paths[1]);
328 EXPECT_EQ(ObjectPath("/object/path/3"), output_object_paths[2]);
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900329}
330
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900331TEST(MessageTest, ProtoBuf) {
dcheng30c5a172016-04-09 07:55:04 +0900332 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900333 MessageWriter writer(message.get());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900334 TestProto send_message;
335 send_message.set_text("testing");
336 send_message.set_number(123);
337 writer.AppendProtoAsArrayOfBytes(send_message);
338
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900339 MessageReader reader(message.get());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900340 TestProto receive_message;
benchan464afff2014-08-25 15:50:29 +0900341 ASSERT_EQ("ay", reader.GetDataSignature());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900342 ASSERT_TRUE(reader.PopArrayOfBytesAsProto(&receive_message));
343 EXPECT_EQ(receive_message.text(), send_message.text());
344 EXPECT_EQ(receive_message.number(), send_message.number());
345}
346
347
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900348// Test that an array can be properly written and read. We only have this
349// test for array, as repeating this for other container types is too
350// redundant.
351TEST(MessageTest, OpenArrayAndPopArray) {
dcheng30c5a172016-04-09 07:55:04 +0900352 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900353 MessageWriter writer(message.get());
354 MessageWriter array_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900355 writer.OpenArray("s", &array_writer); // Open an array of strings.
356 array_writer.AppendString("foo");
357 array_writer.AppendString("bar");
358 array_writer.AppendString("baz");
359 writer.CloseContainer(&array_writer);
360
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900361 MessageReader reader(message.get());
362 ASSERT_EQ(Message::ARRAY, reader.GetDataType());
benchan464afff2014-08-25 15:50:29 +0900363 ASSERT_EQ("as", reader.GetDataSignature());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900364 MessageReader array_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900365 ASSERT_TRUE(reader.PopArray(&array_reader));
366 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
367
368 std::string string_value;
369 ASSERT_TRUE(array_reader.PopString(&string_value));
370 EXPECT_EQ("foo", string_value);
371 ASSERT_TRUE(array_reader.PopString(&string_value));
372 EXPECT_EQ("bar", string_value);
373 ASSERT_TRUE(array_reader.PopString(&string_value));
374 EXPECT_EQ("baz", string_value);
375 // Should not have more data to read.
376 ASSERT_FALSE(array_reader.HasMoreData());
377}
378
379// Create a complex message using array, struct, variant, dict entry, and
380// make sure it can be read properly.
381TEST(MessageTest, CreateComplexMessageAndReadIt) {
dcheng30c5a172016-04-09 07:55:04 +0900382 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900383 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900384 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900385 MessageWriter array_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900386 // Open an array of variants.
387 writer.OpenArray("v", &array_writer);
388 {
389 // The first 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 a boolean.
393 array_writer.OpenVariant("b", &variant_writer);
394 variant_writer.AppendBool(true);
395 array_writer.CloseContainer(&variant_writer);
396 }
397
398 // The second value in the array.
399 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900400 MessageWriter variant_writer(NULL);
avi0ad0ce02015-12-23 03:12:45 +0900401 // Open a variant of a struct that contains a string and an int32_t.
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900402 array_writer.OpenVariant("(si)", &variant_writer);
403 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900404 MessageWriter struct_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900405 variant_writer.OpenStruct(&struct_writer);
406 struct_writer.AppendString("string");
407 struct_writer.AppendInt32(123);
408 variant_writer.CloseContainer(&struct_writer);
409 }
410 array_writer.CloseContainer(&variant_writer);
411 }
412
413 // The third value in the array.
414 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900415 MessageWriter variant_writer(NULL);
avi0ad0ce02015-12-23 03:12:45 +0900416 // Open a variant of an array of string-to-int64_t dict entries.
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900417 array_writer.OpenVariant("a{sx}", &variant_writer);
418 {
avi0ad0ce02015-12-23 03:12:45 +0900419 // Opens an array of string-to-int64_t dict entries.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900420 MessageWriter dict_array_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900421 variant_writer.OpenArray("{sx}", &dict_array_writer);
422 {
avi0ad0ce02015-12-23 03:12:45 +0900423 // Opens a string-to-int64_t dict entries.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900424 MessageWriter dict_entry_writer(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900425 dict_array_writer.OpenDictEntry(&dict_entry_writer);
426 dict_entry_writer.AppendString("foo");
tfarina22cc81a2015-04-21 05:35:20 +0900427 dict_entry_writer.AppendInt64(INT64_C(1234567890123456789));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900428 dict_array_writer.CloseContainer(&dict_entry_writer);
429 }
430 variant_writer.CloseContainer(&dict_array_writer);
431 }
432 array_writer.CloseContainer(&variant_writer);
433 }
434 }
435 writer.CloseContainer(&array_writer);
436 }
437 // What we have created looks like this:
avi0ad0ce02015-12-23 03:12:45 +0900438 EXPECT_EQ(
439 "message_type: MESSAGE_METHOD_RETURN\n"
440 "signature: av\n"
441 "\n"
442 "array [\n"
443 " variant bool true\n"
444 " variant struct {\n"
445 " string \"string\"\n"
446 " int32_t 123\n"
447 " }\n"
448 " variant array [\n"
449 " dict entry {\n"
450 " string \"foo\"\n"
451 " int64_t 1234567890123456789\n"
452 " }\n"
453 " ]\n"
454 "]\n",
455 message->ToString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900456
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900457 MessageReader reader(message.get());
benchan464afff2014-08-25 15:50:29 +0900458 ASSERT_EQ("av", reader.GetDataSignature());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900459 MessageReader array_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900460 ASSERT_TRUE(reader.PopArray(&array_reader));
461
462 // The first value in the array.
463 bool bool_value = false;
benchan464afff2014-08-25 15:50:29 +0900464 ASSERT_EQ("v", array_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900465 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value));
466 EXPECT_EQ(true, bool_value);
467
468 // The second value in the array.
469 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900470 MessageReader variant_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900471 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
472 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900473 MessageReader struct_reader(NULL);
benchan464afff2014-08-25 15:50:29 +0900474 ASSERT_EQ("(si)", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900475 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader));
476 std::string string_value;
477 ASSERT_TRUE(struct_reader.PopString(&string_value));
478 EXPECT_EQ("string", string_value);
avi0ad0ce02015-12-23 03:12:45 +0900479 int32_t int32_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900480 ASSERT_TRUE(struct_reader.PopInt32(&int32_value));
481 EXPECT_EQ(123, int32_value);
482 ASSERT_FALSE(struct_reader.HasMoreData());
483 }
484 ASSERT_FALSE(variant_reader.HasMoreData());
485 }
486
487 // The third value in the array.
488 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900489 MessageReader variant_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900490 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
491 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900492 MessageReader dict_array_reader(NULL);
benchan464afff2014-08-25 15:50:29 +0900493 ASSERT_EQ("a{sx}", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900494 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader));
495 {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900496 MessageReader dict_entry_reader(NULL);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900497 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader));
498 std::string string_value;
499 ASSERT_TRUE(dict_entry_reader.PopString(&string_value));
500 EXPECT_EQ("foo", string_value);
avi0ad0ce02015-12-23 03:12:45 +0900501 int64_t int64_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900502 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value));
tfarina22cc81a2015-04-21 05:35:20 +0900503 EXPECT_EQ(INT64_C(1234567890123456789), int64_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900504 }
505 ASSERT_FALSE(dict_array_reader.HasMoreData());
506 }
507 ASSERT_FALSE(variant_reader.HasMoreData());
508 }
509 ASSERT_FALSE(array_reader.HasMoreData());
510 ASSERT_FALSE(reader.HasMoreData());
511}
512
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900513TEST(MessageTest, MethodCall) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900514 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900515 EXPECT_TRUE(method_call.raw_message() != NULL);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900516 EXPECT_EQ(Message::MESSAGE_METHOD_CALL, method_call.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900517 EXPECT_EQ("MESSAGE_METHOD_CALL", method_call.GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900518 method_call.SetDestination("com.example.Service");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900519 method_call.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900520
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900521 MessageWriter writer(&method_call);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900522 writer.AppendString("payload");
523
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900524 EXPECT_EQ("message_type: MESSAGE_METHOD_CALL\n"
525 "destination: com.example.Service\n"
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900526 "path: /com/example/Object\n"
527 "interface: com.example.Interface\n"
528 "member: SomeMethod\n"
529 "signature: s\n"
530 "\n"
531 "string \"payload\"\n",
532 method_call.ToString());
533}
534
satorux@chromium.org8facb242011-08-11 07:34:02 +0900535TEST(MessageTest, MethodCall_FromRawMessage) {
536 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL);
537 dbus_message_set_interface(raw_message, "com.example.Interface");
538 dbus_message_set_member(raw_message, "SomeMethod");
539
dcheng30c5a172016-04-09 07:55:04 +0900540 std::unique_ptr<MethodCall> method_call(
541 MethodCall::FromRawMessage(raw_message));
satorux@chromium.org8facb242011-08-11 07:34:02 +0900542 EXPECT_EQ("com.example.Interface", method_call->GetInterface());
543 EXPECT_EQ("SomeMethod", method_call->GetMember());
544}
545
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900546TEST(MessageTest, Signal) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900547 Signal signal("com.example.Interface", "SomeSignal");
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900548 EXPECT_TRUE(signal.raw_message() != NULL);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900549 EXPECT_EQ(Message::MESSAGE_SIGNAL, signal.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900550 EXPECT_EQ("MESSAGE_SIGNAL", signal.GetMessageTypeAsString());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900551 signal.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900552
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900553 MessageWriter writer(&signal);
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900554 writer.AppendString("payload");
555
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900556 EXPECT_EQ("message_type: MESSAGE_SIGNAL\n"
557 "path: /com/example/Object\n"
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900558 "interface: com.example.Interface\n"
559 "member: SomeSignal\n"
560 "signature: s\n"
561 "\n"
562 "string \"payload\"\n",
563 signal.ToString());
564}
565
566TEST(MessageTest, Signal_FromRawMessage) {
567 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_SIGNAL);
568 dbus_message_set_interface(raw_message, "com.example.Interface");
569 dbus_message_set_member(raw_message, "SomeSignal");
570
dcheng30c5a172016-04-09 07:55:04 +0900571 std::unique_ptr<Signal> signal(Signal::FromRawMessage(raw_message));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900572 EXPECT_EQ("com.example.Interface", signal->GetInterface());
573 EXPECT_EQ("SomeSignal", signal->GetMember());
574}
575
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900576TEST(MessageTest, Response) {
dcheng30c5a172016-04-09 07:55:04 +0900577 std::unique_ptr<Response> response(Response::CreateEmpty());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900578 EXPECT_TRUE(response->raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900579 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900580 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900581}
582
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900583TEST(MessageTest, Response_FromMethodCall) {
avi0ad0ce02015-12-23 03:12:45 +0900584 const uint32_t kSerial = 123;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900585 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900586 method_call.SetSerial(kSerial);
587
dcheng30c5a172016-04-09 07:55:04 +0900588 std::unique_ptr<Response> response(Response::FromMethodCall(&method_call));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900589 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900590 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900591 // The serial should be copied to the reply serial.
592 EXPECT_EQ(kSerial, response->GetReplySerial());
593}
594
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900595TEST(MessageTest, ErrorResponse_FromMethodCall) {
avi0ad0ce02015-12-23 03:12:45 +0900596 const uint32_t kSerial = 123;
satorux@chromium.org8facb242011-08-11 07:34:02 +0900597const char kErrorMessage[] = "error message";
598
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900599 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900600 method_call.SetSerial(kSerial);
601
dcheng30c5a172016-04-09 07:55:04 +0900602 std::unique_ptr<ErrorResponse> error_response(ErrorResponse::FromMethodCall(
603 &method_call, DBUS_ERROR_FAILED, kErrorMessage));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900604 EXPECT_EQ(Message::MESSAGE_ERROR, error_response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900605 EXPECT_EQ("MESSAGE_ERROR", error_response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900606 // The serial should be copied to the reply serial.
607 EXPECT_EQ(kSerial, error_response->GetReplySerial());
608
609 // Error message should be added to the payload.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900610 MessageReader reader(error_response.get());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900611 std::string error_message;
612 ASSERT_TRUE(reader.PopString(&error_message));
613 EXPECT_EQ(kErrorMessage, error_message);
614}
615
satorux@chromium.org8facb242011-08-11 07:34:02 +0900616TEST(MessageTest, GetAndSetHeaders) {
dcheng30c5a172016-04-09 07:55:04 +0900617 std::unique_ptr<Response> message(Response::CreateEmpty());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900618
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900619 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900620 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900621 EXPECT_EQ("", message->GetInterface());
622 EXPECT_EQ("", message->GetMember());
623 EXPECT_EQ("", message->GetErrorName());
624 EXPECT_EQ("", message->GetSender());
625 EXPECT_EQ(0U, message->GetSerial());
626 EXPECT_EQ(0U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900627
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900628 EXPECT_TRUE(message->SetDestination("org.chromium.destination"));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900629 EXPECT_TRUE(message->SetPath(ObjectPath("/org/chromium/path")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900630 EXPECT_TRUE(message->SetInterface("org.chromium.interface"));
631 EXPECT_TRUE(message->SetMember("member"));
632 EXPECT_TRUE(message->SetErrorName("org.chromium.error"));
633 EXPECT_TRUE(message->SetSender(":1.2"));
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900634 message->SetSerial(123);
635 message->SetReplySerial(456);
satorux@chromium.org8facb242011-08-11 07:34:02 +0900636
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900637 EXPECT_EQ("org.chromium.destination", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900638 EXPECT_EQ(ObjectPath("/org/chromium/path"), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900639 EXPECT_EQ("org.chromium.interface", message->GetInterface());
640 EXPECT_EQ("member", message->GetMember());
641 EXPECT_EQ("org.chromium.error", message->GetErrorName());
642 EXPECT_EQ(":1.2", message->GetSender());
643 EXPECT_EQ(123U, message->GetSerial());
644 EXPECT_EQ(456U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900645}
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900646
647TEST(MessageTest, SetInvalidHeaders) {
dcheng30c5a172016-04-09 07:55:04 +0900648 std::unique_ptr<Response> message(Response::CreateEmpty());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900649 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900650 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900651 EXPECT_EQ("", message->GetInterface());
652 EXPECT_EQ("", message->GetMember());
653 EXPECT_EQ("", message->GetErrorName());
654 EXPECT_EQ("", message->GetSender());
655
656 // Empty element between periods.
657 EXPECT_FALSE(message->SetDestination("org..chromium"));
658 // Trailing '/' is only allowed for the root path.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900659 EXPECT_FALSE(message->SetPath(ObjectPath("/org/chromium/")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900660 // Interface name cannot contain '/'.
661 EXPECT_FALSE(message->SetInterface("org/chromium/interface"));
662 // Member name cannot begin with a digit.
663 EXPECT_FALSE(message->SetMember("1member"));
664 // Error name cannot begin with a period.
665 EXPECT_FALSE(message->SetErrorName(".org.chromium.error"));
666 // Disallowed characters.
667 EXPECT_FALSE(message->SetSender("?!#*"));
668
669 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900670 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900671 EXPECT_EQ("", message->GetInterface());
672 EXPECT_EQ("", message->GetMember());
673 EXPECT_EQ("", message->GetErrorName());
674 EXPECT_EQ("", message->GetSender());
675}
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900676
677TEST(MessageTest, ToString_LongString) {
678 const std::string kLongString(1000, 'o');
679
dcheng30c5a172016-04-09 07:55:04 +0900680 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900681 MessageWriter writer(message.get());
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900682 writer.AppendString(kLongString);
683
684 ASSERT_EQ("message_type: MESSAGE_METHOD_RETURN\n"
685 "signature: s\n\n"
686 "string \"oooooooooooooooooooooooooooooooooooooooooooooooo"
687 "oooooooooooooooooooooooooooooooooooooooooooooooooooo... "
688 "(1000 bytes in total)\"\n",
689 message->ToString());
690}
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900691
692} // namespace dbus