Index: dbus/message_unittest.cc |
diff --git a/dbus/message_unittest.cc b/dbus/message_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e7aaba18d9669de044238366da98378ef140aa94 |
--- /dev/null |
+++ b/dbus/message_unittest.cc |
@@ -0,0 +1,372 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "base/logging.h" |
+#include "dbus/message.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+// Test that a byte can be properly written and read. We only have this |
+// test for byte, as repeating this for other basic types is too redundant. |
+TEST(MessageTest, AppendAndPopByte) { |
+ dbus::Message message; |
+ message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL)); |
+ dbus::MessageWriter writer(&message); |
+ writer.AppendByte(123); // The input is 123. |
+ |
+ dbus::MessageReader reader(&message); |
+ ASSERT_TRUE(reader.HasMoreData()); // Should have data to read. |
+ ASSERT_EQ(dbus::Message::BYTE, reader.GetDataType()); |
+ |
+ bool bool_value = false; |
+ // Should fail as the type is not bool here. |
+ ASSERT_FALSE(reader.PopBool(&bool_value)); |
+ |
+ uint8 byte_value = 0; |
+ ASSERT_TRUE(reader.PopByte(&byte_value)); |
+ EXPECT_EQ(123, byte_value); // Should match with the input. |
+ ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read. |
+ |
+ // Try to get another byte. Should fail. |
+ ASSERT_FALSE(reader.PopByte(&byte_value)); |
+} |
+ |
+// Check all basic types can be properly written and read. |
+TEST(MessageTest, AppendAndPopBasicDataTypes) { |
+ dbus::Message message; |
+ message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL)); |
+ dbus::MessageWriter writer(&message); |
+ |
+ // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path". |
+ writer.AppendByte(0); |
+ writer.AppendBool(true); |
+ writer.AppendInt16(2); |
+ writer.AppendUint16(3); |
+ writer.AppendInt32(4); |
+ writer.AppendUint32(5); |
+ writer.AppendInt64(6); |
+ writer.AppendUint64(7); |
+ writer.AppendDouble(8.0); |
+ writer.AppendString("string"); |
+ writer.AppendObjectPath("/object/path"); |
+ |
+ uint8 byte_value = 0; |
+ bool bool_value = false; |
+ int16 int16_value = 0; |
+ uint16 uint16_value = 0; |
+ int32 int32_value = 0; |
+ uint32 uint32_value = 0; |
+ int64 int64_value = 0; |
+ uint64 uint64_value = 0; |
+ double double_value = 0; |
+ std::string string_value; |
+ std::string object_path_value; |
+ |
+ dbus::MessageReader reader(&message); |
+ ASSERT_TRUE(reader.HasMoreData()); |
+ ASSERT_TRUE(reader.PopByte(&byte_value)); |
+ ASSERT_TRUE(reader.PopBool(&bool_value)); |
+ ASSERT_TRUE(reader.PopInt16(&int16_value)); |
+ ASSERT_TRUE(reader.PopUint16(&uint16_value)); |
+ ASSERT_TRUE(reader.PopInt32(&int32_value)); |
+ ASSERT_TRUE(reader.PopUint32(&uint32_value)); |
+ ASSERT_TRUE(reader.PopInt64(&int64_value)); |
+ ASSERT_TRUE(reader.PopUint64(&uint64_value)); |
+ ASSERT_TRUE(reader.PopDouble(&double_value)); |
+ ASSERT_TRUE(reader.PopString(&string_value)); |
+ ASSERT_TRUE(reader.PopObjectPath(&object_path_value)); |
+ ASSERT_FALSE(reader.HasMoreData()); |
+ |
+ // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned. |
+ EXPECT_EQ(0, byte_value); |
+ EXPECT_EQ(true, bool_value); |
+ EXPECT_EQ(2, int16_value); |
+ EXPECT_EQ(3U, uint16_value); |
+ EXPECT_EQ(4, int32_value); |
+ EXPECT_EQ(5U, uint32_value); |
+ EXPECT_EQ(6, int64_value); |
+ EXPECT_EQ(7U, uint64_value); |
+ EXPECT_DOUBLE_EQ(8.0, double_value); |
+ EXPECT_EQ("string", string_value); |
+ EXPECT_EQ("/object/path", object_path_value); |
+} |
+ |
+// Check all variant types can be properly written and read. |
+TEST(MessageTest, AppendAndPopVariantDataTypes) { |
+ dbus::Message message; |
+ message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL)); |
+ dbus::MessageWriter writer(&message); |
+ |
+ // Append 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path". |
+ writer.AppendVariantOfByte(0); |
+ writer.AppendVariantOfBool(true); |
+ writer.AppendVariantOfInt16(2); |
+ writer.AppendVariantOfUint16(3); |
+ writer.AppendVariantOfInt32(4); |
+ writer.AppendVariantOfUint32(5); |
+ writer.AppendVariantOfInt64(6); |
+ writer.AppendVariantOfUint64(7); |
+ writer.AppendVariantOfDouble(8.0); |
+ writer.AppendVariantOfString("string"); |
+ writer.AppendVariantOfObjectPath("/object/path"); |
+ |
+ uint8 byte_value = 0; |
+ bool bool_value = false; |
+ int16 int16_value = 0; |
+ uint16 uint16_value = 0; |
+ int32 int32_value = 0; |
+ uint32 uint32_value = 0; |
+ int64 int64_value = 0; |
+ uint64 uint64_value = 0; |
+ double double_value = 0; |
+ std::string string_value; |
+ std::string object_path_value; |
+ |
+ dbus::MessageReader reader(&message); |
+ ASSERT_TRUE(reader.HasMoreData()); |
+ ASSERT_TRUE(reader.PopVariantOfByte(&byte_value)); |
+ ASSERT_TRUE(reader.PopVariantOfBool(&bool_value)); |
+ ASSERT_TRUE(reader.PopVariantOfInt16(&int16_value)); |
+ ASSERT_TRUE(reader.PopVariantOfUint16(&uint16_value)); |
+ ASSERT_TRUE(reader.PopVariantOfInt32(&int32_value)); |
+ ASSERT_TRUE(reader.PopVariantOfUint32(&uint32_value)); |
+ ASSERT_TRUE(reader.PopVariantOfInt64(&int64_value)); |
+ ASSERT_TRUE(reader.PopVariantOfUint64(&uint64_value)); |
+ ASSERT_TRUE(reader.PopVariantOfDouble(&double_value)); |
+ ASSERT_TRUE(reader.PopVariantOfString(&string_value)); |
+ ASSERT_TRUE(reader.PopVariantOfObjectPath(&object_path_value)); |
+ ASSERT_FALSE(reader.HasMoreData()); |
+ |
+ // 0, 1, 2, 3, 4, 5, 6, 7, 8, "string", "/object/path" should be returned. |
+ EXPECT_EQ(0, byte_value); |
+ EXPECT_EQ(true, bool_value); |
+ EXPECT_EQ(2, int16_value); |
+ EXPECT_EQ(3U, uint16_value); |
+ EXPECT_EQ(4, int32_value); |
+ EXPECT_EQ(5U, uint32_value); |
+ EXPECT_EQ(6, int64_value); |
+ EXPECT_EQ(7U, uint64_value); |
+ EXPECT_DOUBLE_EQ(8.0, double_value); |
+ EXPECT_EQ("string", string_value); |
+ EXPECT_EQ("/object/path", object_path_value); |
+} |
+ |
+TEST(MessageTest, ArrayOfBytes) { |
+ dbus::Message message; |
+ message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL)); |
+ dbus::MessageWriter writer(&message); |
+ std::vector<uint8> bytes; |
+ bytes.push_back(1); |
+ bytes.push_back(2); |
+ bytes.push_back(3); |
+ writer.AppendArrayOfBytes(bytes.data(), bytes.size()); |
+ |
+ dbus::MessageReader reader(&message); |
+ uint8* output_bytes = NULL; |
+ size_t length = 0; |
+ ASSERT_TRUE(reader.PopArrayOfBytes(&output_bytes, &length)); |
+ ASSERT_FALSE(reader.HasMoreData()); |
+ ASSERT_EQ(3U, length); |
+ ASSERT_EQ(1, output_bytes[0]); |
+ ASSERT_EQ(2, output_bytes[1]); |
+ ASSERT_EQ(3, output_bytes[2]); |
+} |
+ |
+// Test that an array can be properly written and read. We only have this |
+// test for array, as repeating this for other container types is too |
+// redundant. |
+TEST(MessageTest, OpenArrayAndPopArray) { |
+ dbus::Message message; |
+ message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL)); |
+ dbus::MessageWriter writer(&message); |
+ dbus::MessageWriter array_writer(&message); |
+ writer.OpenArray("s", &array_writer); // Open an array of strings. |
+ array_writer.AppendString("foo"); |
+ array_writer.AppendString("bar"); |
+ array_writer.AppendString("baz"); |
+ writer.CloseContainer(&array_writer); |
+ |
+ dbus::MessageReader reader(&message); |
+ ASSERT_EQ(dbus::Message::ARRAY, reader.GetDataType()); |
+ dbus::MessageReader array_reader(&message); |
+ ASSERT_TRUE(reader.PopArray(&array_reader)); |
+ ASSERT_FALSE(reader.HasMoreData()); // Should not have more data to read. |
+ |
+ std::string string_value; |
+ ASSERT_TRUE(array_reader.PopString(&string_value)); |
+ EXPECT_EQ("foo", string_value); |
+ ASSERT_TRUE(array_reader.PopString(&string_value)); |
+ EXPECT_EQ("bar", string_value); |
+ ASSERT_TRUE(array_reader.PopString(&string_value)); |
+ EXPECT_EQ("baz", string_value); |
+ // Should not have more data to read. |
+ ASSERT_FALSE(array_reader.HasMoreData()); |
+} |
+ |
+// Create a complex message using array, struct, variant, dict entry, and |
+// make sure it can be read properly. |
+TEST(MessageTest, CreateComplexMessageAndReadIt) { |
+ dbus::Message message; |
+ message.reset_raw_message(dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_CALL)); |
+ dbus::MessageWriter writer(&message); |
+ { |
+ dbus::MessageWriter array_writer(&message); |
+ // Open an array of variants. |
+ writer.OpenArray("v", &array_writer); |
+ { |
+ // The first value in the array. |
+ { |
+ dbus::MessageWriter variant_writer(&message); |
+ // Open a variant of a boolean. |
+ array_writer.OpenVariant("b", &variant_writer); |
+ variant_writer.AppendBool(true); |
+ array_writer.CloseContainer(&variant_writer); |
+ } |
+ |
+ // The second value in the array. |
+ { |
+ dbus::MessageWriter variant_writer(&message); |
+ // Open a variant of a struct that contains a string and an int32. |
+ array_writer.OpenVariant("(si)", &variant_writer); |
+ { |
+ dbus::MessageWriter struct_writer(&message); |
+ variant_writer.OpenStruct(&struct_writer); |
+ struct_writer.AppendString("string"); |
+ struct_writer.AppendInt32(123); |
+ variant_writer.CloseContainer(&struct_writer); |
+ } |
+ array_writer.CloseContainer(&variant_writer); |
+ } |
+ |
+ // The third value in the array. |
+ { |
+ dbus::MessageWriter variant_writer(&message); |
+ // Open a variant of an array of string-to-int64 dict entries. |
+ array_writer.OpenVariant("a{sx}", &variant_writer); |
+ { |
+ // Opens an array of string-to-int64 dict entries. |
+ dbus::MessageWriter dict_array_writer(&message); |
+ variant_writer.OpenArray("{sx}", &dict_array_writer); |
+ { |
+ // Opens a string-to-int64 dict entries. |
+ dbus::MessageWriter dict_entry_writer(&message); |
+ dict_array_writer.OpenDictEntry(&dict_entry_writer); |
+ dict_entry_writer.AppendString("foo"); |
+ dict_entry_writer.AppendInt64(1234567890123456789); |
Mark Mentovai
2011/07/30 19:41:14
Use GG_INT64_C(1234567890123456789) (base/port.h,
|
+ dict_array_writer.CloseContainer(&dict_entry_writer); |
+ } |
+ variant_writer.CloseContainer(&dict_array_writer); |
+ } |
+ array_writer.CloseContainer(&variant_writer); |
+ } |
+ } |
+ writer.CloseContainer(&array_writer); |
+ } |
+ // What we have created looks like this: |
+ EXPECT_EQ("signature: av\n" |
+ "\n" |
+ "array [\n" |
+ " variant bool true\n" |
+ " variant struct {\n" |
+ " string \"string\"\n" |
+ " int32 123\n" |
+ " }\n" |
+ " variant array [\n" |
+ " dict entry {\n" |
+ " string \"foo\"\n" |
+ " int64 1234567890123456789\n" |
+ " }\n" |
+ " ]\n" |
+ "]\n", |
+ message.ToString()); |
+ |
+ dbus::MessageReader reader(&message); |
+ dbus::MessageReader array_reader(&message); |
+ ASSERT_TRUE(reader.PopArray(&array_reader)); |
+ |
+ // The first value in the array. |
+ bool bool_value = false; |
+ ASSERT_TRUE(array_reader.PopVariantOfBool(&bool_value)); |
+ EXPECT_EQ(true, bool_value); |
+ |
+ // The second value in the array. |
+ { |
+ dbus::MessageReader variant_reader(&message); |
+ ASSERT_TRUE(array_reader.PopVariant(&variant_reader)); |
+ { |
+ dbus::MessageReader struct_reader(&message); |
+ ASSERT_TRUE(variant_reader.PopStruct(&struct_reader)); |
+ std::string string_value; |
+ ASSERT_TRUE(struct_reader.PopString(&string_value)); |
+ EXPECT_EQ("string", string_value); |
+ int32 int32_value = 0; |
+ ASSERT_TRUE(struct_reader.PopInt32(&int32_value)); |
+ EXPECT_EQ(123, int32_value); |
+ ASSERT_FALSE(struct_reader.HasMoreData()); |
+ } |
+ ASSERT_FALSE(variant_reader.HasMoreData()); |
+ } |
+ |
+ // The third value in the array. |
+ { |
+ dbus::MessageReader variant_reader(&message); |
+ ASSERT_TRUE(array_reader.PopVariant(&variant_reader)); |
+ { |
+ dbus::MessageReader dict_array_reader(&message); |
+ ASSERT_TRUE(variant_reader.PopArray(&dict_array_reader)); |
+ { |
+ dbus::MessageReader dict_entry_reader(&message); |
+ ASSERT_TRUE(dict_array_reader.PopDictEntry(&dict_entry_reader)); |
+ std::string string_value; |
+ ASSERT_TRUE(dict_entry_reader.PopString(&string_value)); |
+ EXPECT_EQ("foo", string_value); |
+ int64 int64_value = 0; |
+ ASSERT_TRUE(dict_entry_reader.PopInt64(&int64_value)); |
+ EXPECT_EQ(1234567890123456789, int64_value); |
Mark Mentovai
2011/07/30 19:41:14
Same.
|
+ } |
+ ASSERT_FALSE(dict_array_reader.HasMoreData()); |
+ } |
+ ASSERT_FALSE(variant_reader.HasMoreData()); |
+ } |
+ ASSERT_FALSE(array_reader.HasMoreData()); |
+ ASSERT_FALSE(reader.HasMoreData()); |
+} |
+ |
+TEST(MessageTest, Message) { |
+ dbus::Message message; |
+ EXPECT_TRUE(message.raw_message() == NULL); |
+ EXPECT_EQ(dbus::Message::MESSAGE_INVALID, message.GetMessageType()); |
+} |
+ |
+TEST(MessageTest, MethodCall) { |
+ dbus::MethodCall method_call("com.example.Interface", "SomeMethod"); |
+ EXPECT_TRUE(method_call.raw_message() != NULL); |
+ EXPECT_EQ(dbus::Message::MESSAGE_METHOD_CALL, method_call.GetMessageType()); |
+ method_call.SetServiceName("com.example.Service"); |
+ method_call.SetObjectPath("/com/example/Object"); |
+ |
+ dbus::MessageWriter writer(&method_call); |
+ writer.AppendString("payload"); |
+ |
+ EXPECT_EQ("destination: com.example.Service\n" |
+ "path: /com/example/Object\n" |
+ "interface: com.example.Interface\n" |
+ "member: SomeMethod\n" |
+ "signature: s\n" |
+ "\n" |
+ "string \"payload\"\n", |
+ method_call.ToString()); |
+} |
+ |
+TEST(MessageTest, Response) { |
+ dbus::Response response; |
+ EXPECT_TRUE(response.raw_message() == NULL); |
+ response.reset_raw_message( |
+ dbus_message_new(DBUS_MESSAGE_TYPE_METHOD_RETURN)); |
+ EXPECT_EQ(dbus::Message::MESSAGE_METHOD_RETURN, response.GetMessageType()); |
+} |
+ |
+TEST(MessageTest, ToString_EmptyMessage) { |
+ dbus::Message message; |
+ EXPECT_EQ("", message.ToString()); |
+} |