blob: ef2a6d06c647db6849b1063c0953059aaae83563 [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));
Abhishek Bhardwaj76f36522018-05-23 16:22:19 +090038 EXPECT_EQ(123, byte_value); // Should match with the input.
satorux@chromium.orgb684e272011-07-31 04:13:31 +090039 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.
hashimoto6550fcf2016-09-14 13:05:02 +0900127 const int fd_in = 1;
128 writer.AppendFileDescriptor(fd_in);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900129
hashimoto6550fcf2016-09-14 13:05:02 +0900130 base::ScopedFD fd_out;
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900131
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900132 MessageReader reader(message.get());
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900133 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +0900134 ASSERT_EQ(Message::UNIX_FD, reader.GetDataType());
135 ASSERT_EQ("h", reader.GetDataSignature());
hashimoto6550fcf2016-09-14 13:05:02 +0900136 ASSERT_TRUE(reader.PopFileDescriptor(&fd_out));
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900137 ASSERT_FALSE(reader.HasMoreData());
138
139 // Stdout should be returned but we cannot check the descriptor
140 // value because stdout will be dup'd. Instead check st_rdev
141 // which should be identical.
142 struct stat sb_stdout;
hashimoto6550fcf2016-09-14 13:05:02 +0900143 int status_stdout = HANDLE_EINTR(fstat(fd_in, &sb_stdout));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900144 ASSERT_GE(status_stdout, 0);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900145 struct stat sb_fd;
hashimoto6550fcf2016-09-14 13:05:02 +0900146 int status_fd = HANDLE_EINTR(fstat(fd_out.get(), &sb_fd));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900147 ASSERT_GE(status_fd, 0);
sleffler@chromium.org22fab402012-03-30 15:46:20 +0900148 EXPECT_EQ(sb_stdout.st_rdev, sb_fd.st_rdev);
149}
150
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900151// Check all variant types can be properly written and read.
152TEST(MessageTest, AppendAndPopVariantDataTypes) {
dcheng30c5a172016-04-09 07:55:04 +0900153 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900154 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900155
156 // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path".
157 writer.AppendVariantOfByte(0);
158 writer.AppendVariantOfBool(true);
159 writer.AppendVariantOfInt16(2);
160 writer.AppendVariantOfUint16(3);
161 writer.AppendVariantOfInt32(4);
162 writer.AppendVariantOfUint32(5);
163 writer.AppendVariantOfInt64(6);
164 writer.AppendVariantOfUint64(7);
165 writer.AppendVariantOfDouble(8.0);
166 writer.AppendVariantOfString("string");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900167 writer.AppendVariantOfObjectPath(ObjectPath("/object/path"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900168
avi0ad0ce02015-12-23 03:12:45 +0900169 uint8_t byte_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900170 bool bool_value = false;
avi0ad0ce02015-12-23 03:12:45 +0900171 int16_t int16_value = 0;
172 uint16_t uint16_value = 0;
173 int32_t int32_value = 0;
174 uint32_t uint32_value = 0;
175 int64_t int64_value = 0;
176 uint64_t uint64_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900177 double double_value = 0;
178 std::string string_value;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900179 ObjectPath object_path_value;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900180
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900181 MessageReader reader(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900182 ASSERT_TRUE(reader.HasMoreData());
benchan464afff2014-08-25 15:50:29 +0900183 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900184 ASSERT_TRUE(reader.PopVariantOfByte(&byte_value));
benchan464afff2014-08-25 15:50:29 +0900185 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900186 ASSERT_TRUE(reader.PopVariantOfBool(&bool_value));
benchan464afff2014-08-25 15:50:29 +0900187 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900188 ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value));
benchan464afff2014-08-25 15:50:29 +0900189 ASSERT_EQ("v", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900190 ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_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.PopVariantOfInt32(&int32_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.PopVariantOfUint32(&uint32_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.PopVariantOfInt64(&int64_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.PopVariantOfUint64(&uint64_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.PopVariantOfDouble(&double_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.PopVariantOfString(&string_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.PopVariantOfObjectPath(&object_path_value));
benchan464afff2014-08-25 15:50:29 +0900205 ASSERT_EQ("", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900206 ASSERT_FALSE(reader.HasMoreData());
207
208 // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned.
209 EXPECT_EQ(0, byte_value);
210 EXPECT_EQ(true, bool_value);
211 EXPECT_EQ(2, int16_value);
212 EXPECT_EQ(3U, uint16_value);
213 EXPECT_EQ(4, int32_value);
214 EXPECT_EQ(5U, uint32_value);
215 EXPECT_EQ(6, int64_value);
216 EXPECT_EQ(7U, uint64_value);
217 EXPECT_DOUBLE_EQ(8.0, double_value);
218 EXPECT_EQ("string", string_value);
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900219 EXPECT_EQ(ObjectPath("/object/path"), object_path_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900220}
221
222TEST(MessageTest, ArrayOfBytes) {
dcheng30c5a172016-04-09 07:55:04 +0900223 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900224 MessageWriter writer(message.get());
avi0ad0ce02015-12-23 03:12:45 +0900225 std::vector<uint8_t> bytes;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900226 bytes.push_back(1);
227 bytes.push_back(2);
228 bytes.push_back(3);
229 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
230
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900231 MessageReader reader(message.get());
Ben Chan333256c2017-11-10 05:20:16 +0900232 const uint8_t* output_bytes = nullptr;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900233 size_t length = 0;
benchan464afff2014-08-25 15:50:29 +0900234 ASSERT_EQ("ay", reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900235 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length));
236 ASSERT_FALSE(reader.HasMoreData());
237 ASSERT_EQ(3U, length);
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900238 EXPECT_EQ(1, output_bytes[0]);
239 EXPECT_EQ(2, output_bytes[1]);
240 EXPECT_EQ(3, output_bytes[2]);
241}
242
warxef0f8372016-03-31 06:27:41 +0900243TEST(MessageTest, ArrayOfDoubles) {
dcheng30c5a172016-04-09 07:55:04 +0900244 std::unique_ptr<Response> message(Response::CreateEmpty());
warxef0f8372016-03-31 06:27:41 +0900245 MessageWriter writer(message.get());
246 std::vector<double> doubles;
247 doubles.push_back(0.2);
248 doubles.push_back(0.5);
249 doubles.push_back(1);
250 writer.AppendArrayOfDoubles(doubles.data(), doubles.size());
251
252 MessageReader reader(message.get());
Ben Chan333256c2017-11-10 05:20:16 +0900253 const double* output_doubles = nullptr;
warxef0f8372016-03-31 06:27:41 +0900254 size_t length = 0;
255 ASSERT_EQ("ad", reader.GetDataSignature());
256 ASSERT_TRUE(reader.PopArrayOfDoubles(&output_doubles, &length));
257 ASSERT_FALSE(reader.HasMoreData());
258 ASSERT_EQ(3U, length);
259 EXPECT_EQ(0.2, output_doubles[0]);
260 EXPECT_EQ(0.5, output_doubles[1]);
261 EXPECT_EQ(1, output_doubles[2]);
262}
263
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900264TEST(MessageTest, ArrayOfBytes_Empty) {
dcheng30c5a172016-04-09 07:55:04 +0900265 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900266 MessageWriter writer(message.get());
avi0ad0ce02015-12-23 03:12:45 +0900267 std::vector<uint8_t> bytes;
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900268 writer.AppendArrayOfBytes(bytes.data(), bytes.size());
269
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900270 MessageReader reader(message.get());
Ben Chan333256c2017-11-10 05:20:16 +0900271 const uint8_t* output_bytes = nullptr;
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900272 size_t length = 0;
benchan464afff2014-08-25 15:50:29 +0900273 ASSERT_EQ("ay", reader.GetDataSignature());
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900274 ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length));
275 ASSERT_FALSE(reader.HasMoreData());
276 ASSERT_EQ(0U, length);
Ben Chan333256c2017-11-10 05:20:16 +0900277 EXPECT_EQ(nullptr, output_bytes);
satorux@chromium.org39a0d9b2011-11-11 11:13:56 +0900278}
279
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900280TEST(MessageTest, ArrayOfStrings) {
dcheng30c5a172016-04-09 07:55:04 +0900281 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900282 MessageWriter writer(message.get());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900283 std::vector<std::string> strings;
284 strings.push_back("fee");
285 strings.push_back("fie");
286 strings.push_back("foe");
287 strings.push_back("fum");
288 writer.AppendArrayOfStrings(strings);
289
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900290 MessageReader reader(message.get());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900291 std::vector<std::string> output_strings;
benchan464afff2014-08-25 15:50:29 +0900292 ASSERT_EQ("as", reader.GetDataSignature());
mdm@chromium.org3d2baf02011-09-20 03:22:14 +0900293 ASSERT_TRUE(reader.PopArrayOfStrings(&output_strings));
294 ASSERT_FALSE(reader.HasMoreData());
295 ASSERT_EQ(4U, output_strings.size());
296 EXPECT_EQ("fee", output_strings[0]);
297 EXPECT_EQ("fie", output_strings[1]);
298 EXPECT_EQ("foe", output_strings[2]);
299 EXPECT_EQ("fum", output_strings[3]);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900300}
301
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900302TEST(MessageTest, ArrayOfObjectPaths) {
dcheng30c5a172016-04-09 07:55:04 +0900303 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900304 MessageWriter writer(message.get());
305 std::vector<ObjectPath> object_paths;
306 object_paths.push_back(ObjectPath("/object/path/1"));
307 object_paths.push_back(ObjectPath("/object/path/2"));
308 object_paths.push_back(ObjectPath("/object/path/3"));
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900309 writer.AppendArrayOfObjectPaths(object_paths);
310
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900311 MessageReader reader(message.get());
312 std::vector<ObjectPath> output_object_paths;
benchan464afff2014-08-25 15:50:29 +0900313 ASSERT_EQ("ao", reader.GetDataSignature());
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900314 ASSERT_TRUE(reader.PopArrayOfObjectPaths(&output_object_paths));
315 ASSERT_FALSE(reader.HasMoreData());
316 ASSERT_EQ(3U, output_object_paths.size());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900317 EXPECT_EQ(ObjectPath("/object/path/1"), output_object_paths[0]);
318 EXPECT_EQ(ObjectPath("/object/path/2"), output_object_paths[1]);
319 EXPECT_EQ(ObjectPath("/object/path/3"), output_object_paths[2]);
satorux@chromium.orgf0ceb482011-08-23 03:28:42 +0900320}
321
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900322TEST(MessageTest, ProtoBuf) {
dcheng30c5a172016-04-09 07:55:04 +0900323 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900324 MessageWriter writer(message.get());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900325 TestProto send_message;
326 send_message.set_text("testing");
327 send_message.set_number(123);
328 writer.AppendProtoAsArrayOfBytes(send_message);
329
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900330 MessageReader reader(message.get());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900331 TestProto receive_message;
benchan464afff2014-08-25 15:50:29 +0900332 ASSERT_EQ("ay", reader.GetDataSignature());
rharrison@chromium.org3d530352012-02-10 03:14:08 +0900333 ASSERT_TRUE(reader.PopArrayOfBytesAsProto(&receive_message));
334 EXPECT_EQ(receive_message.text(), send_message.text());
335 EXPECT_EQ(receive_message.number(), send_message.number());
336}
337
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900338// Test that an array can be properly written and read. We only have this
339// test for array, as repeating this for other container types is too
340// redundant.
341TEST(MessageTest, OpenArrayAndPopArray) {
dcheng30c5a172016-04-09 07:55:04 +0900342 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900343 MessageWriter writer(message.get());
Ben Chan333256c2017-11-10 05:20:16 +0900344 MessageWriter array_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900345 writer.OpenArray("s", &array_writer); // Open an array of strings.
346 array_writer.AppendString("foo");
347 array_writer.AppendString("bar");
348 array_writer.AppendString("baz");
349 writer.CloseContainer(&array_writer);
350
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900351 MessageReader reader(message.get());
352 ASSERT_EQ(Message::ARRAY, reader.GetDataType());
benchan464afff2014-08-25 15:50:29 +0900353 ASSERT_EQ("as", reader.GetDataSignature());
Ben Chan333256c2017-11-10 05:20:16 +0900354 MessageReader array_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900355 ASSERT_TRUE(reader.PopArray(&array_reader));
356 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
357
358 std::string string_value;
359 ASSERT_TRUE(array_reader.PopString(&string_value));
360 EXPECT_EQ("foo", string_value);
361 ASSERT_TRUE(array_reader.PopString(&string_value));
362 EXPECT_EQ("bar", string_value);
363 ASSERT_TRUE(array_reader.PopString(&string_value));
364 EXPECT_EQ("baz", string_value);
365 // Should not have more data to read.
366 ASSERT_FALSE(array_reader.HasMoreData());
367}
368
369// Create a complex message using array, struct, variant, dict entry, and
370// make sure it can be read properly.
371TEST(MessageTest, CreateComplexMessageAndReadIt) {
dcheng30c5a172016-04-09 07:55:04 +0900372 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900373 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900374 {
Ben Chan333256c2017-11-10 05:20:16 +0900375 MessageWriter array_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900376 // Open an array of variants.
377 writer.OpenArray("v", &array_writer);
378 {
379 // The first value in the array.
380 {
Ben Chan333256c2017-11-10 05:20:16 +0900381 MessageWriter variant_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900382 // Open a variant of a boolean.
383 array_writer.OpenVariant("b", &variant_writer);
384 variant_writer.AppendBool(true);
385 array_writer.CloseContainer(&variant_writer);
386 }
387
388 // The second value in the array.
389 {
Ben Chan333256c2017-11-10 05:20:16 +0900390 MessageWriter variant_writer(nullptr);
avi0ad0ce02015-12-23 03:12:45 +0900391 // Open a variant of a struct that contains a string and an int32_t.
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900392 array_writer.OpenVariant("(si)", &variant_writer);
393 {
Ben Chan333256c2017-11-10 05:20:16 +0900394 MessageWriter struct_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900395 variant_writer.OpenStruct(&struct_writer);
396 struct_writer.AppendString("string");
397 struct_writer.AppendInt32(123);
398 variant_writer.CloseContainer(&struct_writer);
399 }
400 array_writer.CloseContainer(&variant_writer);
401 }
402
403 // The third value in the array.
404 {
Ben Chan333256c2017-11-10 05:20:16 +0900405 MessageWriter variant_writer(nullptr);
avi0ad0ce02015-12-23 03:12:45 +0900406 // Open a variant of an array of string-to-int64_t dict entries.
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900407 array_writer.OpenVariant("a{sx}", &variant_writer);
408 {
avi0ad0ce02015-12-23 03:12:45 +0900409 // Opens an array of string-to-int64_t dict entries.
Ben Chan333256c2017-11-10 05:20:16 +0900410 MessageWriter dict_array_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900411 variant_writer.OpenArray("{sx}", &dict_array_writer);
412 {
avi0ad0ce02015-12-23 03:12:45 +0900413 // Opens a string-to-int64_t dict entries.
Ben Chan333256c2017-11-10 05:20:16 +0900414 MessageWriter dict_entry_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900415 dict_array_writer.OpenDictEntry(&dict_entry_writer);
416 dict_entry_writer.AppendString("foo");
tfarina22cc81a2015-04-21 05:35:20 +0900417 dict_entry_writer.AppendInt64(INT64_C(1234567890123456789));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900418 dict_array_writer.CloseContainer(&dict_entry_writer);
419 }
420 variant_writer.CloseContainer(&dict_array_writer);
421 }
422 array_writer.CloseContainer(&variant_writer);
423 }
424 }
425 writer.CloseContainer(&array_writer);
426 }
427 // What we have created looks like this:
avi0ad0ce02015-12-23 03:12:45 +0900428 EXPECT_EQ(
429 "message_type: MESSAGE_METHOD_RETURN\n"
430 "signature: av\n"
431 "\n"
432 "array [\n"
433 " variant bool true\n"
434 " variant struct {\n"
435 " string \"string\"\n"
436 " int32_t 123\n"
437 " }\n"
438 " variant array [\n"
439 " dict entry {\n"
440 " string \"foo\"\n"
441 " int64_t 1234567890123456789\n"
442 " }\n"
443 " ]\n"
444 "]\n",
445 message->ToString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900446
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900447 MessageReader reader(message.get());
benchan464afff2014-08-25 15:50:29 +0900448 ASSERT_EQ("av", reader.GetDataSignature());
Ben Chan333256c2017-11-10 05:20:16 +0900449 MessageReader array_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900450 ASSERT_TRUE(reader.PopArray(&array_reader));
451
452 // The first value in the array.
453 bool bool_value = false;
benchan464afff2014-08-25 15:50:29 +0900454 ASSERT_EQ("v", array_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900455 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value));
456 EXPECT_EQ(true, bool_value);
457
458 // The second value in the array.
459 {
Ben Chan333256c2017-11-10 05:20:16 +0900460 MessageReader variant_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900461 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
462 {
Ben Chan333256c2017-11-10 05:20:16 +0900463 MessageReader struct_reader(nullptr);
benchan464afff2014-08-25 15:50:29 +0900464 ASSERT_EQ("(si)", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900465 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader));
466 std::string string_value;
467 ASSERT_TRUE(struct_reader.PopString(&string_value));
468 EXPECT_EQ("string", string_value);
avi0ad0ce02015-12-23 03:12:45 +0900469 int32_t int32_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900470 ASSERT_TRUE(struct_reader.PopInt32(&int32_value));
471 EXPECT_EQ(123, int32_value);
472 ASSERT_FALSE(struct_reader.HasMoreData());
473 }
474 ASSERT_FALSE(variant_reader.HasMoreData());
475 }
476
477 // The third value in the array.
478 {
Ben Chan333256c2017-11-10 05:20:16 +0900479 MessageReader variant_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900480 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
481 {
Ben Chan333256c2017-11-10 05:20:16 +0900482 MessageReader dict_array_reader(nullptr);
benchan464afff2014-08-25 15:50:29 +0900483 ASSERT_EQ("a{sx}", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900484 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader));
485 {
Ben Chan333256c2017-11-10 05:20:16 +0900486 MessageReader dict_entry_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900487 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader));
488 std::string string_value;
489 ASSERT_TRUE(dict_entry_reader.PopString(&string_value));
490 EXPECT_EQ("foo", string_value);
avi0ad0ce02015-12-23 03:12:45 +0900491 int64_t int64_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900492 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value));
tfarina22cc81a2015-04-21 05:35:20 +0900493 EXPECT_EQ(INT64_C(1234567890123456789), int64_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900494 }
495 ASSERT_FALSE(dict_array_reader.HasMoreData());
496 }
497 ASSERT_FALSE(variant_reader.HasMoreData());
498 }
499 ASSERT_FALSE(array_reader.HasMoreData());
500 ASSERT_FALSE(reader.HasMoreData());
501}
502
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900503TEST(MessageTest, MethodCall) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900504 MethodCall method_call("com.example.Interface", "SomeMethod");
Ben Chan333256c2017-11-10 05:20:16 +0900505 EXPECT_NE(nullptr, method_call.raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900506 EXPECT_EQ(Message::MESSAGE_METHOD_CALL, method_call.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900507 EXPECT_EQ("MESSAGE_METHOD_CALL", method_call.GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900508 method_call.SetDestination("com.example.Service");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900509 method_call.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900510
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900511 MessageWriter writer(&method_call);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900512 writer.AppendString("payload");
513
Abhishek Bhardwaj76f36522018-05-23 16:22:19 +0900514 EXPECT_EQ(
515 "message_type: MESSAGE_METHOD_CALL\n"
516 "destination: com.example.Service\n"
517 "path: /com/example/Object\n"
518 "interface: com.example.Interface\n"
519 "member: SomeMethod\n"
520 "signature: s\n"
521 "\n"
522 "string \"payload\"\n",
523 method_call.ToString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900524}
525
satorux@chromium.org8facb242011-08-11 07:34:02 +0900526TEST(MessageTest, MethodCall_FromRawMessage) {
527 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL);
528 dbus_message_set_interface(raw_message, "com.example.Interface");
529 dbus_message_set_member(raw_message, "SomeMethod");
530
dcheng30c5a172016-04-09 07:55:04 +0900531 std::unique_ptr<MethodCall> method_call(
532 MethodCall::FromRawMessage(raw_message));
satorux@chromium.org8facb242011-08-11 07:34:02 +0900533 EXPECT_EQ("com.example.Interface", method_call->GetInterface());
534 EXPECT_EQ("SomeMethod", method_call->GetMember());
535}
536
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900537TEST(MessageTest, Signal) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900538 Signal signal("com.example.Interface", "SomeSignal");
Ben Chan333256c2017-11-10 05:20:16 +0900539 EXPECT_NE(nullptr, signal.raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900540 EXPECT_EQ(Message::MESSAGE_SIGNAL, signal.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900541 EXPECT_EQ("MESSAGE_SIGNAL", signal.GetMessageTypeAsString());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900542 signal.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900543
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900544 MessageWriter writer(&signal);
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900545 writer.AppendString("payload");
546
Abhishek Bhardwaj76f36522018-05-23 16:22:19 +0900547 EXPECT_EQ(
548 "message_type: MESSAGE_SIGNAL\n"
549 "path: /com/example/Object\n"
550 "interface: com.example.Interface\n"
551 "member: SomeSignal\n"
552 "signature: s\n"
553 "\n"
554 "string \"payload\"\n",
555 signal.ToString());
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900556}
557
558TEST(MessageTest, Signal_FromRawMessage) {
559 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_SIGNAL);
560 dbus_message_set_interface(raw_message, "com.example.Interface");
561 dbus_message_set_member(raw_message, "SomeSignal");
562
dcheng30c5a172016-04-09 07:55:04 +0900563 std::unique_ptr<Signal> signal(Signal::FromRawMessage(raw_message));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900564 EXPECT_EQ("com.example.Interface", signal->GetInterface());
565 EXPECT_EQ("SomeSignal", signal->GetMember());
566}
567
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900568TEST(MessageTest, Response) {
dcheng30c5a172016-04-09 07:55:04 +0900569 std::unique_ptr<Response> response(Response::CreateEmpty());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900570 EXPECT_TRUE(response->raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900571 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900572 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900573}
574
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900575TEST(MessageTest, Response_FromMethodCall) {
avi0ad0ce02015-12-23 03:12:45 +0900576 const uint32_t kSerial = 123;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900577 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900578 method_call.SetSerial(kSerial);
579
dcheng30c5a172016-04-09 07:55:04 +0900580 std::unique_ptr<Response> response(Response::FromMethodCall(&method_call));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900581 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900582 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900583 // The serial should be copied to the reply serial.
584 EXPECT_EQ(kSerial, response->GetReplySerial());
585}
586
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900587TEST(MessageTest, ErrorResponse_FromMethodCall) {
avi0ad0ce02015-12-23 03:12:45 +0900588 const uint32_t kSerial = 123;
Abhishek Bhardwaj76f36522018-05-23 16:22:19 +0900589 const char kErrorMessage[] = "error message";
satorux@chromium.org8facb242011-08-11 07:34:02 +0900590
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900591 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900592 method_call.SetSerial(kSerial);
593
dcheng30c5a172016-04-09 07:55:04 +0900594 std::unique_ptr<ErrorResponse> error_response(ErrorResponse::FromMethodCall(
595 &method_call, DBUS_ERROR_FAILED, kErrorMessage));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900596 EXPECT_EQ(Message::MESSAGE_ERROR, error_response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900597 EXPECT_EQ("MESSAGE_ERROR", error_response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900598 // The serial should be copied to the reply serial.
599 EXPECT_EQ(kSerial, error_response->GetReplySerial());
600
601 // Error message should be added to the payload.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900602 MessageReader reader(error_response.get());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900603 std::string error_message;
604 ASSERT_TRUE(reader.PopString(&error_message));
605 EXPECT_EQ(kErrorMessage, error_message);
606}
607
satorux@chromium.org8facb242011-08-11 07:34:02 +0900608TEST(MessageTest, GetAndSetHeaders) {
dcheng30c5a172016-04-09 07:55:04 +0900609 std::unique_ptr<Response> message(Response::CreateEmpty());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900610
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900611 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900612 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900613 EXPECT_EQ("", message->GetInterface());
614 EXPECT_EQ("", message->GetMember());
615 EXPECT_EQ("", message->GetErrorName());
616 EXPECT_EQ("", message->GetSender());
617 EXPECT_EQ(0U, message->GetSerial());
618 EXPECT_EQ(0U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900619
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900620 EXPECT_TRUE(message->SetDestination("org.chromium.destination"));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900621 EXPECT_TRUE(message->SetPath(ObjectPath("/org/chromium/path")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900622 EXPECT_TRUE(message->SetInterface("org.chromium.interface"));
623 EXPECT_TRUE(message->SetMember("member"));
624 EXPECT_TRUE(message->SetErrorName("org.chromium.error"));
625 EXPECT_TRUE(message->SetSender(":1.2"));
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900626 message->SetSerial(123);
627 message->SetReplySerial(456);
satorux@chromium.org8facb242011-08-11 07:34:02 +0900628
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900629 EXPECT_EQ("org.chromium.destination", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900630 EXPECT_EQ(ObjectPath("/org/chromium/path"), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900631 EXPECT_EQ("org.chromium.interface", message->GetInterface());
632 EXPECT_EQ("member", message->GetMember());
633 EXPECT_EQ("org.chromium.error", message->GetErrorName());
634 EXPECT_EQ(":1.2", message->GetSender());
635 EXPECT_EQ(123U, message->GetSerial());
636 EXPECT_EQ(456U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900637}
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900638
639TEST(MessageTest, SetInvalidHeaders) {
dcheng30c5a172016-04-09 07:55:04 +0900640 std::unique_ptr<Response> message(Response::CreateEmpty());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900641 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900642 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900643 EXPECT_EQ("", message->GetInterface());
644 EXPECT_EQ("", message->GetMember());
645 EXPECT_EQ("", message->GetErrorName());
646 EXPECT_EQ("", message->GetSender());
647
648 // Empty element between periods.
649 EXPECT_FALSE(message->SetDestination("org..chromium"));
650 // Trailing '/' is only allowed for the root path.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900651 EXPECT_FALSE(message->SetPath(ObjectPath("/org/chromium/")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900652 // Interface name cannot contain '/'.
653 EXPECT_FALSE(message->SetInterface("org/chromium/interface"));
654 // Member name cannot begin with a digit.
655 EXPECT_FALSE(message->SetMember("1member"));
656 // Error name cannot begin with a period.
657 EXPECT_FALSE(message->SetErrorName(".org.chromium.error"));
658 // Disallowed characters.
659 EXPECT_FALSE(message->SetSender("?!#*"));
660
661 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900662 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900663 EXPECT_EQ("", message->GetInterface());
664 EXPECT_EQ("", message->GetMember());
665 EXPECT_EQ("", message->GetErrorName());
666 EXPECT_EQ("", message->GetSender());
667}
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900668
669TEST(MessageTest, ToString_LongString) {
670 const std::string kLongString(1000, 'o');
671
dcheng30c5a172016-04-09 07:55:04 +0900672 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900673 MessageWriter writer(message.get());
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900674 writer.AppendString(kLongString);
675
Abhishek Bhardwaj76f36522018-05-23 16:22:19 +0900676 ASSERT_EQ(
677 "message_type: MESSAGE_METHOD_RETURN\n"
678 "signature: s\n\n"
679 "string \"oooooooooooooooooooooooooooooooooooooooooooooooo"
680 "oooooooooooooooooooooooooooooooooooooooooooooooooooo... "
681 "(1000 bytes in total)\"\n",
682 message->ToString());
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900683}
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900684
685} // namespace dbus