| Index: third_party/protobuf/src/google/protobuf/lite_unittest.cc
|
| diff --git a/third_party/protobuf/src/google/protobuf/lite_unittest.cc b/third_party/protobuf/src/google/protobuf/lite_unittest.cc
|
| index 7a0a57b77c05debe9cafec177458d06c42461ba5..d1948ab5cc3d4e7e84eef173140cd44ba65e5a1f 100644
|
| --- a/third_party/protobuf/src/google/protobuf/lite_unittest.cc
|
| +++ b/third_party/protobuf/src/google/protobuf/lite_unittest.cc
|
| @@ -1,6 +1,6 @@
|
| // Protocol Buffers - Google's data interchange format
|
| // Copyright 2008 Google Inc. All rights reserved.
|
| -// http://code.google.com/p/protobuf/
|
| +// https://developers.google.com/protocol-buffers/
|
| //
|
| // Redistribution and use in source and binary forms, with or without
|
| // modification, are permitted provided that the following conditions are
|
| @@ -33,9 +33,18 @@
|
| #include <string>
|
| #include <iostream>
|
|
|
| +#include <google/protobuf/stubs/logging.h>
|
| #include <google/protobuf/stubs/common.h>
|
| +#include <google/protobuf/arena_test_util.h>
|
| +#include <google/protobuf/map_lite_unittest.pb.h>
|
| +#include <google/protobuf/map_lite_test_util.h>
|
| #include <google/protobuf/test_util_lite.h>
|
| #include <google/protobuf/unittest_lite.pb.h>
|
| +#include <google/protobuf/io/coded_stream.h>
|
| +#include <google/protobuf/io/zero_copy_stream_impl_lite.h>
|
| +#include <google/protobuf/wire_format_lite.h>
|
| +#include <google/protobuf/wire_format_lite_inl.h>
|
| +#include <google/protobuf/stubs/strutil.h>
|
|
|
| using namespace std;
|
|
|
| @@ -57,10 +66,37 @@ void AssignParsingMergeMessages(
|
| msg3->set_optional_string("hello");
|
| }
|
|
|
| +void SetAllTypesInEmptyMessageUnknownFields(
|
| + google::protobuf::unittest::TestEmptyMessageLite* empty_message) {
|
| + protobuf_unittest::TestAllTypesLite message;
|
| + google::protobuf::TestUtilLite::ExpectClear(message);
|
| + google::protobuf::TestUtilLite::SetAllFields(&message);
|
| + string data = message.SerializeAsString();
|
| + empty_message->ParseFromString(data);
|
| +}
|
| +
|
| +void SetSomeTypesInEmptyMessageUnknownFields(
|
| + google::protobuf::unittest::TestEmptyMessageLite* empty_message) {
|
| + protobuf_unittest::TestAllTypesLite message;
|
| + google::protobuf::TestUtilLite::ExpectClear(message);
|
| + message.set_optional_int32(101);
|
| + message.set_optional_int64(102);
|
| + message.set_optional_uint32(103);
|
| + message.set_optional_uint64(104);
|
| + string data = message.SerializeAsString();
|
| + empty_message->ParseFromString(data);
|
| +}
|
| +
|
| } // namespace
|
|
|
| +#define EXPECT_TRUE GOOGLE_CHECK
|
| +#define ASSERT_TRUE GOOGLE_CHECK
|
| +#define EXPECT_FALSE(COND) GOOGLE_CHECK(!(COND))
|
| +#define EXPECT_EQ GOOGLE_CHECK_EQ
|
| +#define ASSERT_EQ GOOGLE_CHECK_EQ
|
| +
|
| int main(int argc, char* argv[]) {
|
| - string data, packed_data;
|
| + string data, data2, packed_data;
|
|
|
| {
|
| protobuf_unittest::TestAllTypesLite message, message2, message3;
|
| @@ -84,7 +120,6 @@ int main(int argc, char* argv[]) {
|
| google::protobuf::TestUtilLite::SetAllExtensions(&message);
|
| message2.CopyFrom(message);
|
| string extensions_data = message.SerializeAsString();
|
| - GOOGLE_CHECK(extensions_data == data);
|
| message3.ParseFromString(extensions_data);
|
| google::protobuf::TestUtilLite::ExpectAllExtensionsSet(message);
|
| google::protobuf::TestUtilLite::ExpectAllExtensionsSet(message2);
|
| @@ -180,6 +215,477 @@ int main(int argc, char* argv[]) {
|
| google::protobuf::unittest::TestParsingMergeLite::repeated_ext) == 3);
|
| }
|
|
|
| - cout << "PASS" << endl;
|
| + // Test unknown fields support for lite messages.
|
| + {
|
| + protobuf_unittest::TestAllTypesLite message, message2;
|
| + protobuf_unittest::TestEmptyMessageLite empty_message;
|
| + google::protobuf::TestUtilLite::ExpectClear(message);
|
| + google::protobuf::TestUtilLite::SetAllFields(&message);
|
| + data = message.SerializeAsString();
|
| + empty_message.ParseFromString(data);
|
| + data.clear();
|
| + data = empty_message.SerializeAsString();
|
| + message2.ParseFromString(data);
|
| + data = message2.SerializeAsString();
|
| + google::protobuf::TestUtilLite::ExpectAllFieldsSet(message2);
|
| + message.Clear();
|
| + google::protobuf::TestUtilLite::ExpectClear(message);
|
| + }
|
| +
|
| + {
|
| + protobuf_unittest::TestAllExtensionsLite message, message2;
|
| + protobuf_unittest::TestEmptyMessageLite empty_message;
|
| + google::protobuf::TestUtilLite::ExpectExtensionsClear(message);
|
| + google::protobuf::TestUtilLite::SetAllExtensions(&message);
|
| + data = message.SerializeAsString();
|
| + empty_message.ParseFromString(data);
|
| + data.clear();
|
| + data = empty_message.SerializeAsString();
|
| + message2.ParseFromString(data);
|
| + data = message2.SerializeAsString();
|
| + google::protobuf::TestUtilLite::ExpectAllExtensionsSet(message2);
|
| + message.Clear();
|
| + google::protobuf::TestUtilLite::ExpectExtensionsClear(message);
|
| + }
|
| +
|
| + {
|
| + protobuf_unittest::TestPackedTypesLite message, message2;
|
| + protobuf_unittest::TestEmptyMessageLite empty_message;
|
| + google::protobuf::TestUtilLite::ExpectPackedClear(message);
|
| + google::protobuf::TestUtilLite::SetPackedFields(&message);
|
| + data = message.SerializeAsString();
|
| + empty_message.ParseFromString(data);
|
| + data.clear();
|
| + data = empty_message.SerializeAsString();
|
| + message2.ParseFromString(data);
|
| + data = message2.SerializeAsString();
|
| + google::protobuf::TestUtilLite::ExpectPackedFieldsSet(message2);
|
| + message.Clear();
|
| + google::protobuf::TestUtilLite::ExpectPackedClear(message);
|
| + }
|
| +
|
| + {
|
| + protobuf_unittest::TestPackedExtensionsLite message, message2;
|
| + protobuf_unittest::TestEmptyMessageLite empty_message;
|
| + google::protobuf::TestUtilLite::ExpectPackedExtensionsClear(message);
|
| + google::protobuf::TestUtilLite::SetPackedExtensions(&message);
|
| + data = message.SerializeAsString();
|
| + empty_message.ParseFromString(data);
|
| + data.clear();
|
| + data = empty_message.SerializeAsString();
|
| + message2.ParseFromString(data);
|
| + data = message2.SerializeAsString();
|
| + google::protobuf::TestUtilLite::ExpectPackedExtensionsSet(message2);
|
| + message.Clear();
|
| + google::protobuf::TestUtilLite::ExpectPackedExtensionsClear(message);
|
| + }
|
| +
|
| + {
|
| + // Test Unknown fields swap
|
| + protobuf_unittest::TestEmptyMessageLite empty_message, empty_message2;
|
| + SetAllTypesInEmptyMessageUnknownFields(&empty_message);
|
| + SetSomeTypesInEmptyMessageUnknownFields(&empty_message2);
|
| + data = empty_message.SerializeAsString();
|
| + data2 = empty_message2.SerializeAsString();
|
| + empty_message.Swap(&empty_message2);
|
| + GOOGLE_CHECK_EQ(data, empty_message2.SerializeAsString());
|
| + GOOGLE_CHECK_EQ(data2, empty_message.SerializeAsString());
|
| + }
|
| +
|
| + {
|
| + // Test unknown fields swap with self
|
| + protobuf_unittest::TestEmptyMessageLite empty_message;
|
| + SetAllTypesInEmptyMessageUnknownFields(&empty_message);
|
| + data = empty_message.SerializeAsString();
|
| + empty_message.Swap(&empty_message);
|
| + GOOGLE_CHECK_EQ(data, empty_message.SerializeAsString());
|
| + }
|
| +
|
| + {
|
| + // Test MergeFrom with unknown fields
|
| + protobuf_unittest::TestAllTypesLite message, message2;
|
| + protobuf_unittest::TestEmptyMessageLite empty_message, empty_message2;
|
| + message.set_optional_int32(101);
|
| + message.add_repeated_int32(201);
|
| + message.set_optional_nested_enum(google::protobuf::unittest::TestAllTypesLite::BAZ);
|
| + message2.set_optional_int64(102);
|
| + message2.add_repeated_int64(202);
|
| + message2.set_optional_foreign_enum(google::protobuf::unittest::FOREIGN_LITE_BAZ);
|
| +
|
| + data = message.SerializeAsString();
|
| + empty_message.ParseFromString(data);
|
| + data = message2.SerializeAsString();
|
| + empty_message2.ParseFromString(data);
|
| + message.MergeFrom(message2);
|
| + empty_message.MergeFrom(empty_message2);
|
| +
|
| + data = empty_message.SerializeAsString();
|
| + message2.ParseFromString(data);
|
| + // We do not compare the serialized output of a normal message and a lite
|
| + // message because the order of fields do not match. We convert lite message
|
| + // back into normal message, then compare.
|
| + GOOGLE_CHECK_EQ(message.SerializeAsString(), message2.SerializeAsString());
|
| + }
|
| +
|
| + {
|
| + // Test unknown enum value
|
| + protobuf_unittest::TestAllTypesLite message;
|
| + string buffer;
|
| + {
|
| + google::protobuf::io::StringOutputStream output_stream(&buffer);
|
| + google::protobuf::io::CodedOutputStream coded_output(&output_stream);
|
| + google::protobuf::internal::WireFormatLite::WriteTag(
|
| + protobuf_unittest::TestAllTypesLite::kOptionalNestedEnumFieldNumber,
|
| + google::protobuf::internal::WireFormatLite::WIRETYPE_VARINT, &coded_output);
|
| + coded_output.WriteVarint32(10);
|
| + google::protobuf::internal::WireFormatLite::WriteTag(
|
| + protobuf_unittest::TestAllTypesLite::kRepeatedNestedEnumFieldNumber,
|
| + google::protobuf::internal::WireFormatLite::WIRETYPE_VARINT, &coded_output);
|
| + coded_output.WriteVarint32(20);
|
| + }
|
| + message.ParseFromString(buffer);
|
| + data = message.SerializeAsString();
|
| + GOOGLE_CHECK_EQ(data, buffer);
|
| + }
|
| +
|
| + {
|
| + // Test Clear with unknown fields
|
| + protobuf_unittest::TestEmptyMessageLite empty_message;
|
| + SetAllTypesInEmptyMessageUnknownFields(&empty_message);
|
| + empty_message.Clear();
|
| + GOOGLE_CHECK_EQ(0, empty_message.unknown_fields().size());
|
| + }
|
| +
|
| + // Tests for map lite =============================================
|
| +
|
| + {
|
| + // Accessors
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message);
|
| +
|
| + google::protobuf::MapLiteTestUtil::ModifyMapFields(&message);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsModified(message);
|
| + }
|
| +
|
| + {
|
| + // SetMapFieldsInitialized
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFieldsInitialized(&message);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSetInitialized(message);
|
| + }
|
| +
|
| + {
|
| + // Clear
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message);
|
| + message.Clear();
|
| + google::protobuf::MapLiteTestUtil::ExpectClear(message);
|
| + }
|
| +
|
| + {
|
| + // ClearMessageMap
|
| + protobuf_unittest::TestMessageMapLite message;
|
| +
|
| + // Creates a TestAllTypes with default value
|
| + google::protobuf::TestUtilLite::ExpectClear(
|
| + (*message.mutable_map_int32_message())[0]);
|
| + }
|
| +
|
| + {
|
| + // CopyFrom
|
| + protobuf_unittest::TestMapLite message1, message2;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| + message2.CopyFrom(message1);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| +
|
| + // Copying from self should be a no-op.
|
| + message2.CopyFrom(message2);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + }
|
| +
|
| + {
|
| + // CopyFromMessageMap
|
| + protobuf_unittest::TestMessageMapLite message1, message2;
|
| +
|
| + (*message1.mutable_map_int32_message())[0].add_repeated_int32(100);
|
| + (*message2.mutable_map_int32_message())[0].add_repeated_int32(101);
|
| +
|
| + message1.CopyFrom(message2);
|
| +
|
| + // Checks repeated field is overwritten.
|
| + EXPECT_EQ(1, message1.map_int32_message().at(0).repeated_int32_size());
|
| + EXPECT_EQ(101, message1.map_int32_message().at(0).repeated_int32(0));
|
| + }
|
| +
|
| + {
|
| + // SwapWithEmpty
|
| + protobuf_unittest::TestMapLite message1, message2;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message1);
|
| + google::protobuf::MapLiteTestUtil::ExpectClear(message2);
|
| +
|
| + message1.Swap(&message2);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + google::protobuf::MapLiteTestUtil::ExpectClear(message1);
|
| + }
|
| +
|
| + {
|
| + // SwapWithSelf
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message);
|
| +
|
| + message.Swap(&message);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message);
|
| + }
|
| +
|
| + {
|
| + // SwapWithOther
|
| + protobuf_unittest::TestMapLite message1, message2;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message2);
|
| + google::protobuf::MapLiteTestUtil::ModifyMapFields(&message2);
|
| +
|
| + message1.Swap(&message2);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsModified(message1);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + }
|
| +
|
| + {
|
| + // CopyConstructor
|
| + protobuf_unittest::TestMapLite message1;
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| +
|
| + protobuf_unittest::TestMapLite message2(message1);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + }
|
| +
|
| + {
|
| + // CopyAssignmentOperator
|
| + protobuf_unittest::TestMapLite message1;
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| +
|
| + protobuf_unittest::TestMapLite message2;
|
| + message2 = message1;
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| +
|
| + // Make sure that self-assignment does something sane.
|
| + message2.operator=(message2);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + }
|
| +
|
| + {
|
| + // NonEmptyMergeFrom
|
| + protobuf_unittest::TestMapLite message1, message2;
|
| +
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| +
|
| + // This field will test merging into an empty spot.
|
| + (*message2.mutable_map_int32_int32())[1] = 1;
|
| + message1.mutable_map_int32_int32()->erase(1);
|
| +
|
| + // This tests overwriting.
|
| + (*message2.mutable_map_int32_double())[1] = 1;
|
| + (*message1.mutable_map_int32_double())[1] = 2;
|
| +
|
| + message1.MergeFrom(message2);
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message1);
|
| + }
|
| +
|
| + {
|
| + // MergeFromMessageMap
|
| + protobuf_unittest::TestMessageMapLite message1, message2;
|
| +
|
| + (*message1.mutable_map_int32_message())[0].add_repeated_int32(100);
|
| + (*message2.mutable_map_int32_message())[0].add_repeated_int32(101);
|
| +
|
| + message1.MergeFrom(message2);
|
| +
|
| + // Checks repeated field is overwritten.
|
| + EXPECT_EQ(1, message1.map_int32_message().at(0).repeated_int32_size());
|
| + EXPECT_EQ(101, message1.map_int32_message().at(0).repeated_int32(0));
|
| + }
|
| +
|
| + {
|
| + // Test the generated SerializeWithCachedSizesToArray()
|
| + protobuf_unittest::TestMapLite message1, message2;
|
| + string data;
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| + int size = message1.ByteSize();
|
| + data.resize(size);
|
| + ::google::protobuf::uint8* start = reinterpret_cast< ::google::protobuf::uint8*>(::google::protobuf::string_as_array(&data));
|
| + ::google::protobuf::uint8* end = message1.SerializeWithCachedSizesToArray(start);
|
| + EXPECT_EQ(size, end - start);
|
| + EXPECT_TRUE(message2.ParseFromString(data));
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + }
|
| +
|
| + {
|
| + // Test the generated SerializeWithCachedSizes()
|
| + protobuf_unittest::TestMapLite message1, message2;
|
| + google::protobuf::MapLiteTestUtil::SetMapFields(&message1);
|
| + int size = message1.ByteSize();
|
| + string data;
|
| + data.resize(size);
|
| + {
|
| + // Allow the output stream to buffer only one byte at a time.
|
| + google::protobuf::io::ArrayOutputStream array_stream(
|
| + ::google::protobuf::string_as_array(&data), size, 1);
|
| + google::protobuf::io::CodedOutputStream output_stream(&array_stream);
|
| + message1.SerializeWithCachedSizes(&output_stream);
|
| + EXPECT_FALSE(output_stream.HadError());
|
| + EXPECT_EQ(size, output_stream.ByteCount());
|
| + }
|
| + EXPECT_TRUE(message2.ParseFromString(data));
|
| + google::protobuf::MapLiteTestUtil::ExpectMapFieldsSet(message2);
|
| + }
|
| +
|
| +
|
| + {
|
| + // Proto2UnknownEnum
|
| + protobuf_unittest::TestEnumMapPlusExtraLite from;
|
| + (*from.mutable_known_map_field())[0] =
|
| + protobuf_unittest::E_PROTO2_MAP_ENUM_FOO_LITE;
|
| + (*from.mutable_unknown_map_field())[0] =
|
| + protobuf_unittest::E_PROTO2_MAP_ENUM_EXTRA_LITE;
|
| + string data;
|
| + from.SerializeToString(&data);
|
| +
|
| + protobuf_unittest::TestEnumMapLite to;
|
| + EXPECT_TRUE(to.ParseFromString(data));
|
| + EXPECT_EQ(0, to.unknown_map_field().size());
|
| + EXPECT_FALSE(to.mutable_unknown_fields()->empty());
|
| + EXPECT_EQ(1, to.known_map_field().size());
|
| + EXPECT_EQ(protobuf_unittest::PROTO2_MAP_ENUM_FOO_LITE,
|
| + to.known_map_field().at(0));
|
| +
|
| + data.clear();
|
| + from.Clear();
|
| + to.SerializeToString(&data);
|
| + EXPECT_TRUE(from.ParseFromString(data));
|
| + EXPECT_EQ(1, from.known_map_field().size());
|
| + EXPECT_EQ(protobuf_unittest::E_PROTO2_MAP_ENUM_FOO_LITE,
|
| + from.known_map_field().at(0));
|
| + EXPECT_EQ(1, from.unknown_map_field().size());
|
| + EXPECT_EQ(protobuf_unittest::E_PROTO2_MAP_ENUM_EXTRA_LITE,
|
| + from.unknown_map_field().at(0));
|
| + }
|
| +
|
| + {
|
| + // StandardWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| + string data = "\x0A\x04\x08\x01\x10\x01";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(1, message.map_int32_int32().at(1));
|
| + }
|
| +
|
| + {
|
| + // UnorderedWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // put value before key in wire format
|
| + string data = "\x0A\x04\x10\x01\x08\x02";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(1, message.map_int32_int32().at(2));
|
| + }
|
| +
|
| + {
|
| + // DuplicatedKeyWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // Two key fields in wire format
|
| + string data = "\x0A\x06\x08\x01\x08\x02\x10\x01";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(1, message.map_int32_int32().at(2));
|
| + }
|
| +
|
| + {
|
| + // DuplicatedValueWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // Two value fields in wire format
|
| + string data = "\x0A\x06\x08\x01\x10\x01\x10\x02";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(2, message.map_int32_int32().at(1));
|
| + }
|
| +
|
| + {
|
| + // MissedKeyWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // No key field in wire format
|
| + string data = "\x0A\x02\x10\x01";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(1, message.map_int32_int32().at(0));
|
| + }
|
| +
|
| + {
|
| + // MissedValueWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // No value field in wire format
|
| + string data = "\x0A\x02\x08\x01";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(0, message.map_int32_int32().at(1));
|
| + }
|
| +
|
| + {
|
| + // UnknownFieldWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // Unknown field in wire format
|
| + string data = "\x0A\x06\x08\x02\x10\x03\x18\x01";
|
| +
|
| + EXPECT_TRUE(message.ParseFromString(data));
|
| + EXPECT_EQ(1, message.map_int32_int32().size());
|
| + EXPECT_EQ(3, message.map_int32_int32().at(2));
|
| + }
|
| +
|
| + {
|
| + // CorruptedWireFormat
|
| + protobuf_unittest::TestMapLite message;
|
| +
|
| + // corrupted data in wire format
|
| + string data = "\x0A\x06\x08\x02\x11\x03";
|
| +
|
| + EXPECT_FALSE(message.ParseFromString(data));
|
| + }
|
| +
|
| + {
|
| + // IsInitialized
|
| + protobuf_unittest::TestRequiredMessageMapLite map_message;
|
| +
|
| + // Add an uninitialized message.
|
| + (*map_message.mutable_map_field())[0];
|
| + EXPECT_FALSE(map_message.IsInitialized());
|
| +
|
| + // Initialize uninitialized message
|
| + (*map_message.mutable_map_field())[0].set_a(0);
|
| + (*map_message.mutable_map_field())[0].set_b(0);
|
| + (*map_message.mutable_map_field())[0].set_c(0);
|
| + EXPECT_TRUE(map_message.IsInitialized());
|
| + }
|
| +
|
| + std::cout << "PASS" << std::endl;
|
| return 0;
|
| }
|
|
|