blob: b75f2fd2610aa10eb631828b670cfee2d5164f4b [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.
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
338
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900339// Test that an array can be properly written and read. We only have this
340// test for array, as repeating this for other container types is too
341// redundant.
342TEST(MessageTest, OpenArrayAndPopArray) {
dcheng30c5a172016-04-09 07:55:04 +0900343 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900344 MessageWriter writer(message.get());
Ben Chan333256c2017-11-10 05:20:16 +0900345 MessageWriter array_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900346 writer.OpenArray("s", &array_writer); // Open an array of strings.
347 array_writer.AppendString("foo");
348 array_writer.AppendString("bar");
349 array_writer.AppendString("baz");
350 writer.CloseContainer(&array_writer);
351
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900352 MessageReader reader(message.get());
353 ASSERT_EQ(Message::ARRAY, reader.GetDataType());
benchan464afff2014-08-25 15:50:29 +0900354 ASSERT_EQ("as", reader.GetDataSignature());
Ben Chan333256c2017-11-10 05:20:16 +0900355 MessageReader array_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900356 ASSERT_TRUE(reader.PopArray(&array_reader));
357 ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read.
358
359 std::string string_value;
360 ASSERT_TRUE(array_reader.PopString(&string_value));
361 EXPECT_EQ("foo", string_value);
362 ASSERT_TRUE(array_reader.PopString(&string_value));
363 EXPECT_EQ("bar", string_value);
364 ASSERT_TRUE(array_reader.PopString(&string_value));
365 EXPECT_EQ("baz", string_value);
366 // Should not have more data to read.
367 ASSERT_FALSE(array_reader.HasMoreData());
368}
369
370// Create a complex message using array, struct, variant, dict entry, and
371// make sure it can be read properly.
372TEST(MessageTest, CreateComplexMessageAndReadIt) {
dcheng30c5a172016-04-09 07:55:04 +0900373 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900374 MessageWriter writer(message.get());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900375 {
Ben Chan333256c2017-11-10 05:20:16 +0900376 MessageWriter array_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900377 // Open an array of variants.
378 writer.OpenArray("v", &array_writer);
379 {
380 // The first value in the array.
381 {
Ben Chan333256c2017-11-10 05:20:16 +0900382 MessageWriter variant_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900383 // Open a variant of a boolean.
384 array_writer.OpenVariant("b", &variant_writer);
385 variant_writer.AppendBool(true);
386 array_writer.CloseContainer(&variant_writer);
387 }
388
389 // The second value in the array.
390 {
Ben Chan333256c2017-11-10 05:20:16 +0900391 MessageWriter variant_writer(nullptr);
avi0ad0ce02015-12-23 03:12:45 +0900392 // Open a variant of a struct that contains a string and an int32_t.
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900393 array_writer.OpenVariant("(si)", &variant_writer);
394 {
Ben Chan333256c2017-11-10 05:20:16 +0900395 MessageWriter struct_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900396 variant_writer.OpenStruct(&struct_writer);
397 struct_writer.AppendString("string");
398 struct_writer.AppendInt32(123);
399 variant_writer.CloseContainer(&struct_writer);
400 }
401 array_writer.CloseContainer(&variant_writer);
402 }
403
404 // The third value in the array.
405 {
Ben Chan333256c2017-11-10 05:20:16 +0900406 MessageWriter variant_writer(nullptr);
avi0ad0ce02015-12-23 03:12:45 +0900407 // Open a variant of an array of string-to-int64_t dict entries.
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900408 array_writer.OpenVariant("a{sx}", &variant_writer);
409 {
avi0ad0ce02015-12-23 03:12:45 +0900410 // Opens an array of string-to-int64_t dict entries.
Ben Chan333256c2017-11-10 05:20:16 +0900411 MessageWriter dict_array_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900412 variant_writer.OpenArray("{sx}", &dict_array_writer);
413 {
avi0ad0ce02015-12-23 03:12:45 +0900414 // Opens a string-to-int64_t dict entries.
Ben Chan333256c2017-11-10 05:20:16 +0900415 MessageWriter dict_entry_writer(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900416 dict_array_writer.OpenDictEntry(&dict_entry_writer);
417 dict_entry_writer.AppendString("foo");
tfarina22cc81a2015-04-21 05:35:20 +0900418 dict_entry_writer.AppendInt64(INT64_C(1234567890123456789));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900419 dict_array_writer.CloseContainer(&dict_entry_writer);
420 }
421 variant_writer.CloseContainer(&dict_array_writer);
422 }
423 array_writer.CloseContainer(&variant_writer);
424 }
425 }
426 writer.CloseContainer(&array_writer);
427 }
428 // What we have created looks like this:
avi0ad0ce02015-12-23 03:12:45 +0900429 EXPECT_EQ(
430 "message_type: MESSAGE_METHOD_RETURN\n"
431 "signature: av\n"
432 "\n"
433 "array [\n"
434 " variant bool true\n"
435 " variant struct {\n"
436 " string \"string\"\n"
437 " int32_t 123\n"
438 " }\n"
439 " variant array [\n"
440 " dict entry {\n"
441 " string \"foo\"\n"
442 " int64_t 1234567890123456789\n"
443 " }\n"
444 " ]\n"
445 "]\n",
446 message->ToString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900447
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900448 MessageReader reader(message.get());
benchan464afff2014-08-25 15:50:29 +0900449 ASSERT_EQ("av", reader.GetDataSignature());
Ben Chan333256c2017-11-10 05:20:16 +0900450 MessageReader array_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900451 ASSERT_TRUE(reader.PopArray(&array_reader));
452
453 // The first value in the array.
454 bool bool_value = false;
benchan464afff2014-08-25 15:50:29 +0900455 ASSERT_EQ("v", array_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900456 ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value));
457 EXPECT_EQ(true, bool_value);
458
459 // The second value in the array.
460 {
Ben Chan333256c2017-11-10 05:20:16 +0900461 MessageReader variant_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900462 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
463 {
Ben Chan333256c2017-11-10 05:20:16 +0900464 MessageReader struct_reader(nullptr);
benchan464afff2014-08-25 15:50:29 +0900465 ASSERT_EQ("(si)", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900466 ASSERT_TRUE(variant_reader.PopStruct(&struct_reader));
467 std::string string_value;
468 ASSERT_TRUE(struct_reader.PopString(&string_value));
469 EXPECT_EQ("string", string_value);
avi0ad0ce02015-12-23 03:12:45 +0900470 int32_t int32_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900471 ASSERT_TRUE(struct_reader.PopInt32(&int32_value));
472 EXPECT_EQ(123, int32_value);
473 ASSERT_FALSE(struct_reader.HasMoreData());
474 }
475 ASSERT_FALSE(variant_reader.HasMoreData());
476 }
477
478 // The third value in the array.
479 {
Ben Chan333256c2017-11-10 05:20:16 +0900480 MessageReader variant_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900481 ASSERT_TRUE(array_reader.PopVariant(&variant_reader));
482 {
Ben Chan333256c2017-11-10 05:20:16 +0900483 MessageReader dict_array_reader(nullptr);
benchan464afff2014-08-25 15:50:29 +0900484 ASSERT_EQ("a{sx}", variant_reader.GetDataSignature());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900485 ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader));
486 {
Ben Chan333256c2017-11-10 05:20:16 +0900487 MessageReader dict_entry_reader(nullptr);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900488 ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader));
489 std::string string_value;
490 ASSERT_TRUE(dict_entry_reader.PopString(&string_value));
491 EXPECT_EQ("foo", string_value);
avi0ad0ce02015-12-23 03:12:45 +0900492 int64_t int64_value = 0;
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900493 ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value));
tfarina22cc81a2015-04-21 05:35:20 +0900494 EXPECT_EQ(INT64_C(1234567890123456789), int64_value);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900495 }
496 ASSERT_FALSE(dict_array_reader.HasMoreData());
497 }
498 ASSERT_FALSE(variant_reader.HasMoreData());
499 }
500 ASSERT_FALSE(array_reader.HasMoreData());
501 ASSERT_FALSE(reader.HasMoreData());
502}
503
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900504TEST(MessageTest, MethodCall) {
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900505 MethodCall method_call("com.example.Interface", "SomeMethod");
Ben Chan333256c2017-11-10 05:20:16 +0900506 EXPECT_NE(nullptr, method_call.raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900507 EXPECT_EQ(Message::MESSAGE_METHOD_CALL, method_call.GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900508 EXPECT_EQ("MESSAGE_METHOD_CALL", method_call.GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900509 method_call.SetDestination("com.example.Service");
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900510 method_call.SetPath(ObjectPath("/com/example/Object"));
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900511
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900512 MessageWriter writer(&method_call);
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900513 writer.AppendString("payload");
514
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900515 EXPECT_EQ("message_type: MESSAGE_METHOD_CALL\n"
516 "destination: com.example.Service\n"
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900517 "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());
524}
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
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900547 EXPECT_EQ("message_type: MESSAGE_SIGNAL\n"
548 "path: /com/example/Object\n"
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900549 "interface: com.example.Interface\n"
550 "member: SomeSignal\n"
551 "signature: s\n"
552 "\n"
553 "string \"payload\"\n",
554 signal.ToString());
555}
556
557TEST(MessageTest, Signal_FromRawMessage) {
558 DBusMessage* raw_message = dbus_message_new(DBUS_MESSAGE_TYPE_SIGNAL);
559 dbus_message_set_interface(raw_message, "com.example.Interface");
560 dbus_message_set_member(raw_message, "SomeSignal");
561
dcheng30c5a172016-04-09 07:55:04 +0900562 std::unique_ptr<Signal> signal(Signal::FromRawMessage(raw_message));
satorux@chromium.org7f0c4512011-08-23 16:29:21 +0900563 EXPECT_EQ("com.example.Interface", signal->GetInterface());
564 EXPECT_EQ("SomeSignal", signal->GetMember());
565}
566
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900567TEST(MessageTest, Response) {
dcheng30c5a172016-04-09 07:55:04 +0900568 std::unique_ptr<Response> response(Response::CreateEmpty());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900569 EXPECT_TRUE(response->raw_message());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900570 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900571 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.orgb684e272011-07-31 04:13:31 +0900572}
573
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900574TEST(MessageTest, Response_FromMethodCall) {
avi0ad0ce02015-12-23 03:12:45 +0900575 const uint32_t kSerial = 123;
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900576 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900577 method_call.SetSerial(kSerial);
578
dcheng30c5a172016-04-09 07:55:04 +0900579 std::unique_ptr<Response> response(Response::FromMethodCall(&method_call));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900580 EXPECT_EQ(Message::MESSAGE_METHOD_RETURN, response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900581 EXPECT_EQ("MESSAGE_METHOD_RETURN", response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900582 // The serial should be copied to the reply serial.
583 EXPECT_EQ(kSerial, response->GetReplySerial());
584}
585
satorux@chromium.orgfb67cde2011-08-17 08:22:23 +0900586TEST(MessageTest, ErrorResponse_FromMethodCall) {
avi0ad0ce02015-12-23 03:12:45 +0900587 const uint32_t kSerial = 123;
satorux@chromium.org8facb242011-08-11 07:34:02 +0900588const char kErrorMessage[] = "error message";
589
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900590 MethodCall method_call("com.example.Interface", "SomeMethod");
satorux@chromium.org8facb242011-08-11 07:34:02 +0900591 method_call.SetSerial(kSerial);
592
dcheng30c5a172016-04-09 07:55:04 +0900593 std::unique_ptr<ErrorResponse> error_response(ErrorResponse::FromMethodCall(
594 &method_call, DBUS_ERROR_FAILED, kErrorMessage));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900595 EXPECT_EQ(Message::MESSAGE_ERROR, error_response->GetMessageType());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900596 EXPECT_EQ("MESSAGE_ERROR", error_response->GetMessageTypeAsString());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900597 // The serial should be copied to the reply serial.
598 EXPECT_EQ(kSerial, error_response->GetReplySerial());
599
600 // Error message should be added to the payload.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900601 MessageReader reader(error_response.get());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900602 std::string error_message;
603 ASSERT_TRUE(reader.PopString(&error_message));
604 EXPECT_EQ(kErrorMessage, error_message);
605}
606
satorux@chromium.org8facb242011-08-11 07:34:02 +0900607TEST(MessageTest, GetAndSetHeaders) {
dcheng30c5a172016-04-09 07:55:04 +0900608 std::unique_ptr<Response> message(Response::CreateEmpty());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900609
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900610 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900611 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900612 EXPECT_EQ("", message->GetInterface());
613 EXPECT_EQ("", message->GetMember());
614 EXPECT_EQ("", message->GetErrorName());
615 EXPECT_EQ("", message->GetSender());
616 EXPECT_EQ(0U, message->GetSerial());
617 EXPECT_EQ(0U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900618
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900619 EXPECT_TRUE(message->SetDestination("org.chromium.destination"));
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900620 EXPECT_TRUE(message->SetPath(ObjectPath("/org/chromium/path")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900621 EXPECT_TRUE(message->SetInterface("org.chromium.interface"));
622 EXPECT_TRUE(message->SetMember("member"));
623 EXPECT_TRUE(message->SetErrorName("org.chromium.error"));
624 EXPECT_TRUE(message->SetSender(":1.2"));
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900625 message->SetSerial(123);
626 message->SetReplySerial(456);
satorux@chromium.org8facb242011-08-11 07:34:02 +0900627
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900628 EXPECT_EQ("org.chromium.destination", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900629 EXPECT_EQ(ObjectPath("/org/chromium/path"), message->GetPath());
satorux@chromium.orgffa83a92011-08-24 12:32:06 +0900630 EXPECT_EQ("org.chromium.interface", message->GetInterface());
631 EXPECT_EQ("member", message->GetMember());
632 EXPECT_EQ("org.chromium.error", message->GetErrorName());
633 EXPECT_EQ(":1.2", message->GetSender());
634 EXPECT_EQ(123U, message->GetSerial());
635 EXPECT_EQ(456U, message->GetReplySerial());
satorux@chromium.org8facb242011-08-11 07:34:02 +0900636}
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900637
638TEST(MessageTest, SetInvalidHeaders) {
dcheng30c5a172016-04-09 07:55:04 +0900639 std::unique_ptr<Response> message(Response::CreateEmpty());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900640 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900641 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900642 EXPECT_EQ("", message->GetInterface());
643 EXPECT_EQ("", message->GetMember());
644 EXPECT_EQ("", message->GetErrorName());
645 EXPECT_EQ("", message->GetSender());
646
647 // Empty element between periods.
648 EXPECT_FALSE(message->SetDestination("org..chromium"));
649 // Trailing '/' is only allowed for the root path.
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900650 EXPECT_FALSE(message->SetPath(ObjectPath("/org/chromium/")));
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900651 // Interface name cannot contain '/'.
652 EXPECT_FALSE(message->SetInterface("org/chromium/interface"));
653 // Member name cannot begin with a digit.
654 EXPECT_FALSE(message->SetMember("1member"));
655 // Error name cannot begin with a period.
656 EXPECT_FALSE(message->SetErrorName(".org.chromium.error"));
657 // Disallowed characters.
658 EXPECT_FALSE(message->SetSender("?!#*"));
659
660 EXPECT_EQ("", message->GetDestination());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900661 EXPECT_EQ(ObjectPath(std::string()), message->GetPath());
hashimoto@chromium.orgb0305512012-05-23 15:55:22 +0900662 EXPECT_EQ("", message->GetInterface());
663 EXPECT_EQ("", message->GetMember());
664 EXPECT_EQ("", message->GetErrorName());
665 EXPECT_EQ("", message->GetSender());
666}
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900667
668TEST(MessageTest, ToString_LongString) {
669 const std::string kLongString(1000, 'o');
670
dcheng30c5a172016-04-09 07:55:04 +0900671 std::unique_ptr<Response> message(Response::CreateEmpty());
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900672 MessageWriter writer(message.get());
satorux@chromium.org6a7aa372012-06-08 01:41:26 +0900673 writer.AppendString(kLongString);
674
675 ASSERT_EQ("message_type: MESSAGE_METHOD_RETURN\n"
676 "signature: s\n\n"
677 "string \"oooooooooooooooooooooooooooooooooooooooooooooooo"
678 "oooooooooooooooooooooooooooooooooooooooooooooooooooo... "
679 "(1000 bytes in total)\"\n",
680 message->ToString());
681}
thestig@chromium.orgf0b7eac2013-06-13 15:37:19 +0900682
683} // namespace dbus