| // Protocol Buffers - Google's data interchange format | 
 | // Copyright 2015 Google Inc.  All rights reserved. | 
 | // 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 | 
 | // met: | 
 | // | 
 | //     * Redistributions of source code must retain the above copyright | 
 | // notice, this list of conditions and the following disclaimer. | 
 | //     * Redistributions in binary form must reproduce the above | 
 | // copyright notice, this list of conditions and the following disclaimer | 
 | // in the documentation and/or other materials provided with the | 
 | // distribution. | 
 | //     * Neither the name of Google Inc. nor the names of its | 
 | // contributors may be used to endorse or promote products derived from | 
 | // this software without specific prior written permission. | 
 | // | 
 | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
 | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
 | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 
 | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 
 | // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 
 | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 
 | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
 | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
 | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
 | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 
 | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
 |  | 
 | #import "GPBTestUtilities.h" | 
 |  | 
 | #import <objc/runtime.h> | 
 |  | 
 | #import "GPBMessage.h" | 
 |  | 
 | #import "objectivec/Tests/MapProto2Unittest.pbobjc.h" | 
 | #import "objectivec/Tests/MapUnittest.pbobjc.h" | 
 | #import "objectivec/Tests/Unittest.pbobjc.h" | 
 | #import "objectivec/Tests/UnittestPreserveUnknownEnum.pbobjc.h" | 
 | #import "objectivec/Tests/UnittestRuntimeProto2.pbobjc.h" | 
 | #import "objectivec/Tests/UnittestRuntimeProto3.pbobjc.h" | 
 |  | 
 | @interface MessageSerializationTests : GPBTestCase | 
 | @end | 
 |  | 
 | @implementation MessageSerializationTests | 
 |  | 
 | // TODO(thomasvl): Pull tests over from GPBMessageTests that are serialization | 
 | // specific. | 
 |  | 
 | - (void)testProto3SerializationHandlingDefaults { | 
 |   // Proto2 covered in other tests. | 
 |  | 
 |   Message3 *msg = [[Message3 alloc] init]; | 
 |  | 
 |   // Add defaults, no output. | 
 |  | 
 |   NSData *data = [msg data]; | 
 |   XCTAssertEqual([data length], 0U); | 
 |  | 
 |   // All zeros, still nothing. | 
 |  | 
 |   msg.optionalInt32 = 0; | 
 |   msg.optionalInt64 = 0; | 
 |   msg.optionalUint32 = 0; | 
 |   msg.optionalUint64 = 0; | 
 |   msg.optionalSint32 = 0; | 
 |   msg.optionalSint64 = 0; | 
 |   msg.optionalFixed32 = 0; | 
 |   msg.optionalFixed64 = 0; | 
 |   msg.optionalSfixed32 = 0; | 
 |   msg.optionalSfixed64 = 0; | 
 |   msg.optionalFloat = 0.0f; | 
 |   msg.optionalDouble = 0.0; | 
 |   msg.optionalBool = NO; | 
 |   msg.optionalString = @""; | 
 |   msg.optionalBytes = [NSData data]; | 
 |   msg.optionalEnum = Message3_Enum_Foo;  // first value | 
 |  | 
 |   data = [msg data]; | 
 |   XCTAssertEqual([data length], 0U); | 
 |  | 
 |   // The two that also take nil as nothing. | 
 |  | 
 |   msg.optionalString = nil; | 
 |   msg.optionalBytes = nil; | 
 |  | 
 |   data = [msg data]; | 
 |   XCTAssertEqual([data length], 0U); | 
 |  | 
 |   // Set one field... | 
 |  | 
 |   msg.optionalInt32 = 1; | 
 |  | 
 |   data = [msg data]; | 
 |   const uint8_t expectedBytes[] = {0x08, 0x01}; | 
 |   NSData *expected = [NSData dataWithBytes:expectedBytes length:2]; | 
 |   XCTAssertEqualObjects(data, expected); | 
 |  | 
 |   // Back to zero... | 
 |  | 
 |   msg.optionalInt32 = 0; | 
 |  | 
 |   data = [msg data]; | 
 |   XCTAssertEqual([data length], 0U); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | - (void)testProto3SerializationHandlingOptionals { | 
 |   // | 
 |   // Proto3 optionals should be just like proto2, zero values also get serialized. | 
 |   // | 
 |  | 
 |   // Disable clang-format for the macros. | 
 |   // clang-format off | 
 |  | 
 | //%PDDM-DEFINE PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(FIELD, ZERO_VALUE, EXPECTED_LEN) | 
 | //%  {  // optional##FIELD | 
 | //%    Message3Optional *msg = [[Message3Optional alloc] init]; | 
 | //%    NSData *data = [msg data]; | 
 | //%    XCTAssertEqual([data length], 0U); | 
 | //%    msg.optional##FIELD = ZERO_VALUE; | 
 | //%    data = [msg data]; | 
 | //%    XCTAssertEqual(data.length, EXPECTED_LEN); | 
 | //%    NSError *err = nil; | 
 | //%    Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 | //%    XCTAssertNotNil(msg2); | 
 | //%    XCTAssertNil(err); | 
 | //%    XCTAssertTrue(msg2.hasOptional##FIELD); | 
 | //%    XCTAssertEqualObjects(msg, msg2); | 
 | //%    [msg release]; | 
 | //%  } | 
 | //% | 
 | //%PDDM-DEFINE PROTO3_TEST_SERIALIZE_OPTIONAL_FIELDS() | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Int32, 0, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Int64, 0, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Uint32, 0, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Uint64, 0, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Sint32, 0, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Sint64, 0, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Fixed32, 0, 5) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Fixed64, 0, 9) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Sfixed32, 0, 5) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Sfixed64, 0, 9) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Float, 0.0f, 5) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Double, 0.0, 9) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Bool, NO, 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(String, @"", 2) | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Bytes, [NSData data], 2) | 
 | //%  // | 
 | //%  // Test doesn't apply to optionalMessage (no groups in proto3). | 
 | //%  // | 
 | //% | 
 | //%PROTO3_TEST_SERIALIZE_OPTIONAL_FIELD(Enum, Message3Optional_Enum_Foo, 3) | 
 | //%PDDM-EXPAND PROTO3_TEST_SERIALIZE_OPTIONAL_FIELDS() | 
 | // This block of code is generated, do not edit it directly. | 
 |  | 
 |   {  // optionalInt32 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalInt32 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalInt32); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalInt64 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalInt64 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalInt64); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalUint32 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalUint32 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalUint32); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalUint64 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalUint64 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalUint64); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalSint32 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalSint32 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalSint32); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalSint64 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalSint64 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalSint64); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalFixed32 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalFixed32 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 5); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalFixed32); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalFixed64 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalFixed64 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 9); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalFixed64); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalSfixed32 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalSfixed32 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 5); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalSfixed32); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalSfixed64 | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalSfixed64 = 0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 9); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalSfixed64); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalFloat | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalFloat = 0.0f; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 5); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalFloat); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalDouble | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalDouble = 0.0; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 9); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalDouble); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalBool | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalBool = NO; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalBool); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalString | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalString = @""; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalString); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   {  // optionalBytes | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalBytes = [NSData data]; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 2); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalBytes); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 |   // | 
 |   // Test doesn't apply to optionalMessage (no groups in proto3). | 
 |   // | 
 |  | 
 |   {  // optionalEnum | 
 |     Message3Optional *msg = [[Message3Optional alloc] init]; | 
 |     NSData *data = [msg data]; | 
 |     XCTAssertEqual([data length], 0U); | 
 |     msg.optionalEnum = Message3Optional_Enum_Foo; | 
 |     data = [msg data]; | 
 |     XCTAssertEqual(data.length, 3); | 
 |     NSError *err = nil; | 
 |     Message3Optional *msg2 = [Message3Optional parseFromData:data error:&err]; | 
 |     XCTAssertNotNil(msg2); | 
 |     XCTAssertNil(err); | 
 |     XCTAssertTrue(msg2.hasOptionalEnum); | 
 |     XCTAssertEqualObjects(msg, msg2); | 
 |     [msg release]; | 
 |   } | 
 |  | 
 | //%PDDM-EXPAND-END PROTO3_TEST_SERIALIZE_OPTIONAL_FIELDS() | 
 |  | 
 |   // clang-format on | 
 | } | 
 |  | 
 | - (void)testProto2UnknownEnumToUnknownField { | 
 |   Message3 *orig = [[Message3 alloc] init]; | 
 |  | 
 |   orig.optionalEnum = Message3_Enum_Extra3; | 
 |   orig.repeatedEnumArray = [GPBEnumArray arrayWithValidationFunction:Message3_Enum_IsValidValue | 
 |                                                             rawValue:Message3_Enum_Extra3]; | 
 |   orig.oneofEnum = Message3_Enum_Extra3; | 
 |  | 
 |   NSData *data = [orig data]; | 
 |   XCTAssertNotNil(data); | 
 |   Message2 *msg = [[Message2 alloc] initWithData:data error:NULL]; | 
 |  | 
 |   // None of the fields should be set. | 
 |  | 
 |   XCTAssertFalse(msg.hasOptionalEnum); | 
 |   XCTAssertEqual(msg.repeatedEnumArray.count, 0U); | 
 |   XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_GPBUnsetOneOfCase); | 
 |  | 
 |   // All the values should be in unknown fields. | 
 |  | 
 |   GPBUnknownFieldSet *unknownFields = msg.unknownFields; | 
 |  | 
 |   XCTAssertEqual([unknownFields countOfFields], 3U); | 
 |   XCTAssertTrue([unknownFields hasField:Message2_FieldNumber_OptionalEnum]); | 
 |   XCTAssertTrue([unknownFields hasField:Message2_FieldNumber_RepeatedEnumArray]); | 
 |   XCTAssertTrue([unknownFields hasField:Message2_FieldNumber_OneofEnum]); | 
 |  | 
 |   GPBUnknownField *field = [unknownFields getField:Message2_FieldNumber_OptionalEnum]; | 
 |   XCTAssertEqual(field.varintList.count, 1U); | 
 |   XCTAssertEqual([field.varintList valueAtIndex:0], (uint64_t)Message3_Enum_Extra3); | 
 |  | 
 |   field = [unknownFields getField:Message2_FieldNumber_RepeatedEnumArray]; | 
 |   XCTAssertEqual(field.varintList.count, 1U); | 
 |   XCTAssertEqual([field.varintList valueAtIndex:0], (uint64_t)Message3_Enum_Extra3); | 
 |  | 
 |   field = [unknownFields getField:Message2_FieldNumber_OneofEnum]; | 
 |   XCTAssertEqual(field.varintList.count, 1U); | 
 |   XCTAssertEqual([field.varintList valueAtIndex:0], (uint64_t)Message3_Enum_Extra3); | 
 |  | 
 |   [msg release]; | 
 |   [orig release]; | 
 | } | 
 |  | 
 | - (void)testProto3UnknownEnumPreserving { | 
 |   UnknownEnumsMyMessagePlusExtra *orig = [UnknownEnumsMyMessagePlusExtra message]; | 
 |  | 
 |   orig.e = UnknownEnumsMyEnumPlusExtra_EExtra; | 
 |   orig.repeatedEArray = | 
 |       [GPBEnumArray arrayWithValidationFunction:UnknownEnumsMyEnumPlusExtra_IsValidValue | 
 |                                        rawValue:UnknownEnumsMyEnumPlusExtra_EExtra]; | 
 |   orig.repeatedPackedEArray = | 
 |       [GPBEnumArray arrayWithValidationFunction:UnknownEnumsMyEnumPlusExtra_IsValidValue | 
 |                                        rawValue:UnknownEnumsMyEnumPlusExtra_EExtra]; | 
 |   orig.oneofE1 = UnknownEnumsMyEnumPlusExtra_EExtra; | 
 |  | 
 |   // Everything should be there via raw values. | 
 |  | 
 |   NSData *data = [orig data]; | 
 |   XCTAssertNotNil(data); | 
 |   UnknownEnumsMyMessage *msg = [UnknownEnumsMyMessage parseFromData:data error:NULL]; | 
 |  | 
 |   XCTAssertEqual(msg.e, UnknownEnumsMyEnum_GPBUnrecognizedEnumeratorValue); | 
 |   XCTAssertEqual(UnknownEnumsMyMessage_E_RawValue(msg), UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |   XCTAssertEqual(msg.repeatedEArray.count, 1U); | 
 |   XCTAssertEqual([msg.repeatedEArray valueAtIndex:0], | 
 |                  UnknownEnumsMyEnum_GPBUnrecognizedEnumeratorValue); | 
 |   XCTAssertEqual([msg.repeatedEArray rawValueAtIndex:0], | 
 |                  (UnknownEnumsMyEnum)UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |   XCTAssertEqual(msg.repeatedPackedEArray.count, 1U); | 
 |   XCTAssertEqual([msg.repeatedPackedEArray valueAtIndex:0], | 
 |                  UnknownEnumsMyEnum_GPBUnrecognizedEnumeratorValue); | 
 |   XCTAssertEqual([msg.repeatedPackedEArray rawValueAtIndex:0], | 
 |                  (UnknownEnumsMyEnum)UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |   XCTAssertEqual(msg.oneofE1, UnknownEnumsMyEnum_GPBUnrecognizedEnumeratorValue); | 
 |   XCTAssertEqual(UnknownEnumsMyMessage_OneofE1_RawValue(msg), UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |  | 
 |   // Everything should go out and come back. | 
 |  | 
 |   data = [msg data]; | 
 |   orig = [UnknownEnumsMyMessagePlusExtra parseFromData:data error:NULL]; | 
 |  | 
 |   XCTAssertEqual(orig.e, UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |   XCTAssertEqual(orig.repeatedEArray.count, 1U); | 
 |   XCTAssertEqual([orig.repeatedEArray valueAtIndex:0], UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |   XCTAssertEqual(orig.repeatedPackedEArray.count, 1U); | 
 |   XCTAssertEqual([orig.repeatedPackedEArray valueAtIndex:0], UnknownEnumsMyEnumPlusExtra_EExtra); | 
 |   XCTAssertEqual(orig.oneofE1, UnknownEnumsMyEnumPlusExtra_EExtra); | 
 | } | 
 |  | 
 | // Disable clang-format for the macros. | 
 | // clang-format off | 
 |  | 
 | //%PDDM-DEFINE TEST_ROUNDTRIP_ONEOF(MESSAGE, FIELD, VALUE) | 
 | //%TEST_ROUNDTRIP_ONEOF_ADV(MESSAGE, FIELD, VALUE, ) | 
 | //%PDDM-DEFINE TEST_ROUNDTRIP_ONEOF_ADV(MESSAGE, FIELD, VALUE, EQ_SUFFIX) | 
 | //%  {  // oneof##FIELD | 
 | //%    MESSAGE *orig = [[MESSAGE alloc] init]; | 
 | //%    orig.oneof##FIELD = VALUE; | 
 | //%    XCTAssertEqual(orig.oOneOfCase, MESSAGE##_O_OneOfCase_Oneof##FIELD); | 
 | //%    NSData *data = [orig data]; | 
 | //%    XCTAssertNotNil(data); | 
 | //%    MESSAGE *msg = [MESSAGE parseFromData:data error:NULL]; | 
 | //%    XCTAssertEqual(msg.oOneOfCase, MESSAGE##_O_OneOfCase_Oneof##FIELD); | 
 | //%    XCTAssertEqual##EQ_SUFFIX(msg.oneof##FIELD, VALUE); | 
 | //%    [orig release]; | 
 | //%  } | 
 | //% | 
 | //%PDDM-DEFINE TEST_ROUNDTRIP_ONEOFS(SYNTAX, BOOL_NON_DEFAULT) | 
 | //%- (void)testProto##SYNTAX##RoundTripOneof { | 
 | //% | 
 | //%GROUP_INIT##SYNTAX()  Message##SYNTAX *subMessage = [[Message##SYNTAX alloc] init]; | 
 | //%  XCTAssertNotNil(subMessage); | 
 | //%  subMessage.optionalInt32 = 666; | 
 | //% | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Int32, 1) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Int64, 2) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Uint32, 3U) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Uint64, 4U) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Sint32, 5) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Sint64, 6) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Fixed32, 7U) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Fixed64, 8U) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Sfixed32, 9) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Sfixed64, 10) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Float, 11.0f) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Double, 12.0) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Bool, BOOL_NON_DEFAULT) | 
 | //%TEST_ROUNDTRIP_ONEOF_ADV(Message##SYNTAX, String, @"foo", Objects) | 
 | //%TEST_ROUNDTRIP_ONEOF_ADV(Message##SYNTAX, Bytes, [@"bar" dataUsingEncoding:NSUTF8StringEncoding], Objects) | 
 | //%GROUP_TEST##SYNTAX()TEST_ROUNDTRIP_ONEOF_ADV(Message##SYNTAX, Message, subMessage, Objects) | 
 | //%TEST_ROUNDTRIP_ONEOF(Message##SYNTAX, Enum, Message##SYNTAX##_Enum_Bar) | 
 | //%GROUP_CLEANUP##SYNTAX()  [subMessage release]; | 
 | //%} | 
 | //% | 
 | //%PDDM-DEFINE GROUP_INIT2() | 
 | //%  Message2_OneofGroup *group = [[Message2_OneofGroup alloc] init]; | 
 | //%  XCTAssertNotNil(group); | 
 | //%  group.a = 777; | 
 | //% | 
 | //%PDDM-DEFINE GROUP_CLEANUP2() | 
 | //%  [group release]; | 
 | //% | 
 | //%PDDM-DEFINE GROUP_TEST2() | 
 | //%TEST_ROUNDTRIP_ONEOF_ADV(Message2, Group, group, Objects) | 
 | //% | 
 | //%PDDM-DEFINE GROUP_INIT3() | 
 | // Empty | 
 | //%PDDM-DEFINE GROUP_CLEANUP3() | 
 | // Empty | 
 | //%PDDM-DEFINE GROUP_TEST3() | 
 | //%  // Not "group" in proto3. | 
 | //% | 
 | //% | 
 | //%PDDM-EXPAND TEST_ROUNDTRIP_ONEOFS(2, NO) | 
 | // This block of code is generated, do not edit it directly. | 
 |  | 
 | - (void)testProto2RoundTripOneof { | 
 |  | 
 |   Message2_OneofGroup *group = [[Message2_OneofGroup alloc] init]; | 
 |   XCTAssertNotNil(group); | 
 |   group.a = 777; | 
 |   Message2 *subMessage = [[Message2 alloc] init]; | 
 |   XCTAssertNotNil(subMessage); | 
 |   subMessage.optionalInt32 = 666; | 
 |  | 
 |   {  // oneofInt32 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofInt32 = 1; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofInt32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofInt32); | 
 |     XCTAssertEqual(msg.oneofInt32, 1); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofInt64 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofInt64 = 2; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofInt64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofInt64); | 
 |     XCTAssertEqual(msg.oneofInt64, 2); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofUint32 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofUint32 = 3U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofUint32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofUint32); | 
 |     XCTAssertEqual(msg.oneofUint32, 3U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofUint64 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofUint64 = 4U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofUint64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofUint64); | 
 |     XCTAssertEqual(msg.oneofUint64, 4U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSint32 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofSint32 = 5; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofSint32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofSint32); | 
 |     XCTAssertEqual(msg.oneofSint32, 5); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSint64 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofSint64 = 6; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofSint64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofSint64); | 
 |     XCTAssertEqual(msg.oneofSint64, 6); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofFixed32 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofFixed32 = 7U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofFixed32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofFixed32); | 
 |     XCTAssertEqual(msg.oneofFixed32, 7U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofFixed64 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofFixed64 = 8U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofFixed64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofFixed64); | 
 |     XCTAssertEqual(msg.oneofFixed64, 8U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSfixed32 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofSfixed32 = 9; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofSfixed32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofSfixed32); | 
 |     XCTAssertEqual(msg.oneofSfixed32, 9); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSfixed64 | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofSfixed64 = 10; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofSfixed64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofSfixed64); | 
 |     XCTAssertEqual(msg.oneofSfixed64, 10); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofFloat | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofFloat = 11.0f; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofFloat); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofFloat); | 
 |     XCTAssertEqual(msg.oneofFloat, 11.0f); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofDouble | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofDouble = 12.0; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofDouble); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofDouble); | 
 |     XCTAssertEqual(msg.oneofDouble, 12.0); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofBool | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofBool = NO; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofBool); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofBool); | 
 |     XCTAssertEqual(msg.oneofBool, NO); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofString | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofString = @"foo"; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofString); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofString); | 
 |     XCTAssertEqualObjects(msg.oneofString, @"foo"); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofBytes | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofBytes = [@"bar" dataUsingEncoding:NSUTF8StringEncoding]; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofBytes); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofBytes); | 
 |     XCTAssertEqualObjects(msg.oneofBytes, [@"bar" dataUsingEncoding:NSUTF8StringEncoding]); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofGroup | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofGroup = group; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofGroup); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofGroup); | 
 |     XCTAssertEqualObjects(msg.oneofGroup, group); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofMessage | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofMessage = subMessage; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofMessage); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofMessage); | 
 |     XCTAssertEqualObjects(msg.oneofMessage, subMessage); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofEnum | 
 |     Message2 *orig = [[Message2 alloc] init]; | 
 |     orig.oneofEnum = Message2_Enum_Bar; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message2_O_OneOfCase_OneofEnum); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message2 *msg = [Message2 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message2_O_OneOfCase_OneofEnum); | 
 |     XCTAssertEqual(msg.oneofEnum, Message2_Enum_Bar); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   [group release]; | 
 |   [subMessage release]; | 
 | } | 
 |  | 
 | //%PDDM-EXPAND TEST_ROUNDTRIP_ONEOFS(3, YES) | 
 | // This block of code is generated, do not edit it directly. | 
 |  | 
 | - (void)testProto3RoundTripOneof { | 
 |  | 
 |   Message3 *subMessage = [[Message3 alloc] init]; | 
 |   XCTAssertNotNil(subMessage); | 
 |   subMessage.optionalInt32 = 666; | 
 |  | 
 |   {  // oneofInt32 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofInt32 = 1; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofInt32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofInt32); | 
 |     XCTAssertEqual(msg.oneofInt32, 1); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofInt64 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofInt64 = 2; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofInt64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofInt64); | 
 |     XCTAssertEqual(msg.oneofInt64, 2); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofUint32 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofUint32 = 3U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofUint32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofUint32); | 
 |     XCTAssertEqual(msg.oneofUint32, 3U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofUint64 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofUint64 = 4U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofUint64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofUint64); | 
 |     XCTAssertEqual(msg.oneofUint64, 4U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSint32 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofSint32 = 5; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofSint32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofSint32); | 
 |     XCTAssertEqual(msg.oneofSint32, 5); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSint64 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofSint64 = 6; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofSint64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofSint64); | 
 |     XCTAssertEqual(msg.oneofSint64, 6); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofFixed32 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofFixed32 = 7U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofFixed32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofFixed32); | 
 |     XCTAssertEqual(msg.oneofFixed32, 7U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofFixed64 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofFixed64 = 8U; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofFixed64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofFixed64); | 
 |     XCTAssertEqual(msg.oneofFixed64, 8U); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSfixed32 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofSfixed32 = 9; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofSfixed32); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofSfixed32); | 
 |     XCTAssertEqual(msg.oneofSfixed32, 9); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofSfixed64 | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofSfixed64 = 10; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofSfixed64); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofSfixed64); | 
 |     XCTAssertEqual(msg.oneofSfixed64, 10); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofFloat | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofFloat = 11.0f; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofFloat); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofFloat); | 
 |     XCTAssertEqual(msg.oneofFloat, 11.0f); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofDouble | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofDouble = 12.0; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofDouble); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofDouble); | 
 |     XCTAssertEqual(msg.oneofDouble, 12.0); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofBool | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofBool = YES; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofBool); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofBool); | 
 |     XCTAssertEqual(msg.oneofBool, YES); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofString | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofString = @"foo"; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofString); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofString); | 
 |     XCTAssertEqualObjects(msg.oneofString, @"foo"); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofBytes | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofBytes = [@"bar" dataUsingEncoding:NSUTF8StringEncoding]; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofBytes); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofBytes); | 
 |     XCTAssertEqualObjects(msg.oneofBytes, [@"bar" dataUsingEncoding:NSUTF8StringEncoding]); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   // Not "group" in proto3. | 
 |  | 
 |   {  // oneofMessage | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofMessage = subMessage; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofMessage); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofMessage); | 
 |     XCTAssertEqualObjects(msg.oneofMessage, subMessage); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   {  // oneofEnum | 
 |     Message3 *orig = [[Message3 alloc] init]; | 
 |     orig.oneofEnum = Message3_Enum_Bar; | 
 |     XCTAssertEqual(orig.oOneOfCase, Message3_O_OneOfCase_OneofEnum); | 
 |     NSData *data = [orig data]; | 
 |     XCTAssertNotNil(data); | 
 |     Message3 *msg = [Message3 parseFromData:data error:NULL]; | 
 |     XCTAssertEqual(msg.oOneOfCase, Message3_O_OneOfCase_OneofEnum); | 
 |     XCTAssertEqual(msg.oneofEnum, Message3_Enum_Bar); | 
 |     [orig release]; | 
 |   } | 
 |  | 
 |   [subMessage release]; | 
 | } | 
 |  | 
 | //%PDDM-EXPAND-END (2 expansions) | 
 |  | 
 | // clang-format on | 
 |  | 
 | - (void)testPackedUnpackedMessageParsing { | 
 |   // packed is optional, a repeated field should parse when packed or unpacked. | 
 |  | 
 |   TestPackedTypes *packedOrig = [TestPackedTypes message]; | 
 |   TestUnpackedTypes *unpackedOrig = [TestUnpackedTypes message]; | 
 |   [self setPackedFields:packedOrig repeatedCount:4]; | 
 |   [self setUnpackedFields:unpackedOrig repeatedCount:4]; | 
 |  | 
 |   NSData *packedData = [packedOrig data]; | 
 |   NSData *unpackedData = [unpackedOrig data]; | 
 |   XCTAssertNotNil(packedData); | 
 |   XCTAssertNotNil(unpackedData); | 
 |   XCTAssertNotEqualObjects(packedData, unpackedData, | 
 |                            @"Data should differ (packed vs unpacked) use"); | 
 |  | 
 |   NSError *error = nil; | 
 |   TestPackedTypes *packedParse = [TestPackedTypes parseFromData:unpackedData error:&error]; | 
 |   XCTAssertNotNil(packedParse); | 
 |   XCTAssertNil(error); | 
 |   XCTAssertEqualObjects(packedParse, packedOrig); | 
 |  | 
 |   error = nil; | 
 |   TestUnpackedTypes *unpackedParsed = [TestUnpackedTypes parseFromData:packedData error:&error]; | 
 |   XCTAssertNotNil(unpackedParsed); | 
 |   XCTAssertNil(error); | 
 |   XCTAssertEqualObjects(unpackedParsed, unpackedOrig); | 
 | } | 
 |  | 
 | - (void)testPackedUnpackedExtensionParsing { | 
 |   // packed is optional, a repeated extension should parse when packed or | 
 |   // unpacked. | 
 |  | 
 |   TestPackedExtensions *packedOrig = [TestPackedExtensions message]; | 
 |   TestUnpackedExtensions *unpackedOrig = [TestUnpackedExtensions message]; | 
 |   [self setPackedExtensions:packedOrig repeatedCount:kGPBDefaultRepeatCount]; | 
 |   [self setUnpackedExtensions:unpackedOrig repeatedCount:kGPBDefaultRepeatCount]; | 
 |  | 
 |   NSData *packedData = [packedOrig data]; | 
 |   NSData *unpackedData = [unpackedOrig data]; | 
 |   XCTAssertNotNil(packedData); | 
 |   XCTAssertNotNil(unpackedData); | 
 |   XCTAssertNotEqualObjects(packedData, unpackedData, | 
 |                            @"Data should differ (packed vs unpacked) use"); | 
 |  | 
 |   NSError *error = nil; | 
 |   TestPackedExtensions *packedParse = | 
 |       [TestPackedExtensions parseFromData:unpackedData | 
 |                         extensionRegistry:[UnittestRoot extensionRegistry] | 
 |                                     error:&error]; | 
 |   XCTAssertNotNil(packedParse); | 
 |   XCTAssertNil(error); | 
 |   XCTAssertEqualObjects(packedParse, packedOrig); | 
 |  | 
 |   error = nil; | 
 |   TestUnpackedExtensions *unpackedParsed = | 
 |       [TestUnpackedExtensions parseFromData:packedData | 
 |                           extensionRegistry:[UnittestRoot extensionRegistry] | 
 |                                       error:&error]; | 
 |   XCTAssertNotNil(unpackedParsed); | 
 |   XCTAssertNil(error); | 
 |   XCTAssertEqualObjects(unpackedParsed, unpackedOrig); | 
 | } | 
 |  | 
 | - (void)testPackedExtensionVsFieldParsing { | 
 |   // Extensions and fields end up on the wire the same way, so they can parse | 
 |   // each other. | 
 |  | 
 |   TestPackedTypes *fieldsOrig = [TestPackedTypes message]; | 
 |   TestPackedExtensions *extsOrig = [TestPackedExtensions message]; | 
 |   [self setPackedFields:fieldsOrig repeatedCount:kGPBDefaultRepeatCount]; | 
 |   [self setPackedExtensions:extsOrig repeatedCount:kGPBDefaultRepeatCount]; | 
 |  | 
 |   NSData *fieldsData = [fieldsOrig data]; | 
 |   NSData *extsData = [extsOrig data]; | 
 |   XCTAssertNotNil(fieldsData); | 
 |   XCTAssertNotNil(extsData); | 
 |   XCTAssertEqualObjects(fieldsData, extsData); | 
 |  | 
 |   NSError *error = nil; | 
 |   TestPackedTypes *fieldsParse = [TestPackedTypes parseFromData:extsData error:&error]; | 
 |   XCTAssertNotNil(fieldsParse); | 
 |   XCTAssertNil(error); | 
 |   XCTAssertEqualObjects(fieldsParse, fieldsOrig); | 
 |  | 
 |   error = nil; | 
 |   TestPackedExtensions *extsParse = | 
 |       [TestPackedExtensions parseFromData:fieldsData | 
 |                         extensionRegistry:[UnittestRoot extensionRegistry] | 
 |                                     error:&error]; | 
 |   XCTAssertNotNil(extsParse); | 
 |   XCTAssertNil(error); | 
 |   XCTAssertEqualObjects(extsParse, extsOrig); | 
 | } | 
 |  | 
 | - (void)testUnpackedExtensionVsFieldParsing { | 
 |   // Extensions and fields end up on the wire the same way, so they can parse | 
 |   // each other. | 
 |  | 
 |   TestUnpackedTypes *fieldsOrig = [TestUnpackedTypes message]; | 
 |   TestUnpackedExtensions *extsOrig = [TestUnpackedExtensions message]; | 
 |   [self setUnpackedFields:fieldsOrig repeatedCount:3]; | 
 |   [self setUnpackedExtensions:extsOrig repeatedCount:3]; | 
 |  | 
 |   NSData *fieldsData = [fieldsOrig data]; | 
 |   NSData *extsData = [extsOrig data]; | 
 |   XCTAssertNotNil(fieldsData); | 
 |   XCTAssertNotNil(extsData); | 
 |   XCTAssertEqualObjects(fieldsData, extsData); | 
 |  | 
 |   TestUnpackedTypes *fieldsParse = [TestUnpackedTypes parseFromData:extsData error:NULL]; | 
 |   XCTAssertNotNil(fieldsParse); | 
 |   XCTAssertEqualObjects(fieldsParse, fieldsOrig); | 
 |  | 
 |   TestUnpackedExtensions *extsParse = | 
 |       [TestUnpackedExtensions parseFromData:fieldsData | 
 |                           extensionRegistry:[UnittestRoot extensionRegistry] | 
 |                                       error:NULL]; | 
 |   XCTAssertNotNil(extsParse); | 
 |   XCTAssertEqualObjects(extsParse, extsOrig); | 
 | } | 
 |  | 
 | - (void)testErrorSubsectionInvalidLimit { | 
 |   NSData *data = DataFromCStr("\x0A\x08\x0A\x07\x12\x04\x72\x02\x4B\x50\x12\x04\x72\x02\x4B\x50"); | 
 |   NSError *error = nil; | 
 |   NestedTestAllTypes *msg = [NestedTestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidSubsectionLimit); | 
 | } | 
 |  | 
 | - (void)testErrorSubsectionLimitReached { | 
 |   NSData *data = DataFromCStr("\x0A\x06\x12\x03\x72\x02\x4B\x50"); | 
 |   NSError *error = nil; | 
 |   NestedTestAllTypes *msg = [NestedTestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorSubsectionLimitReached); | 
 | } | 
 |  | 
 | - (void)testErrorInvalidVarint { | 
 |   NSData *data = DataFromCStr("\x72\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF"); | 
 |   NSError *error = nil; | 
 |   TestAllTypes *msg = [TestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidVarInt); | 
 | } | 
 |  | 
 | - (void)testErrorInvalidUTF8 { | 
 |   NSData *data = DataFromCStr("\x72\x04\xF4\xFF\xFF\xFF"); | 
 |   NSError *error = nil; | 
 |   TestAllTypes *msg = [TestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidUTF8); | 
 | } | 
 |  | 
 | - (void)testErrorInvalidSize { | 
 |   NSData *data = DataFromCStr("\x72\x03\x4B\x50"); | 
 |   NSError *error = nil; | 
 |   NestedTestAllTypes *msg = [NestedTestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidSize); | 
 | } | 
 |  | 
 | - (void)testErrorInvalidTag { | 
 |   NSData *data = DataFromCStr("\x0F"); | 
 |   NSError *error = nil; | 
 |   NestedTestAllTypes *msg = [NestedTestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidTag); | 
 | } | 
 |  | 
 | - (void)testZeroFieldNum { | 
 |   // These are ConformanceTestSuite::TestIllegalTags. | 
 |  | 
 |   const char *tests[] = {"\1DEADBEEF", "\2\1\1", "\3\4", "\5DEAD"}; | 
 |  | 
 |   for (size_t i = 0; i < GPBARRAYSIZE(tests); ++i) { | 
 |     NSData *data = DataFromCStr(tests[i]); | 
 |  | 
 |     { | 
 |       // Message from proto2 syntax file | 
 |       NSError *error = nil; | 
 |       Message2 *msg = [Message2 parseFromData:data error:&error]; | 
 |       XCTAssertNil(msg, @"i = %zd", i); | 
 |       XCTAssertNotNil(error, @"i = %zd", i); | 
 |       XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain, @"i = %zd", i); | 
 |       XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidTag, @"i = %zd", i); | 
 |     } | 
 |  | 
 |     { | 
 |       // Message from proto3 syntax file | 
 |       NSError *error = nil; | 
 |       Message3 *msg = [Message3 parseFromData:data error:&error]; | 
 |       XCTAssertNil(msg, @"i = %zd", i); | 
 |       XCTAssertNotNil(error, @"i = %zd", i); | 
 |       XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain, @"i = %zd", i); | 
 |       XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidTag, @"i = %zd", i); | 
 |     } | 
 |   } | 
 | } | 
 |  | 
 | - (void)testErrorRecursionDepthReached { | 
 |   NSData *data = DataFromCStr("\x0A\xF2\x01\x0A\xEF\x01\x0A\xEC\x01\x0A\xE9\x01\x0A\xE6\x01" | 
 |                               "\x0A\xE3\x01\x0A\xE0\x01\x0A\xDD\x01\x0A\xDA\x01\x0A\xD7\x01" | 
 |                               "\x0A\xD4\x01\x0A\xD1\x01\x0A\xCE\x01\x0A\xCB\x01\x0A\xC8\x01" | 
 |                               "\x0A\xC5\x01\x0A\xC2\x01\x0A\xBF\x01\x0A\xBC\x01\x0A\xB9\x01" | 
 |                               "\x0A\xB6\x01\x0A\xB3\x01\x0A\xB0\x01\x0A\xAD\x01\x0A\xAA\x01" | 
 |                               "\x0A\xA7\x01\x0A\xA4\x01\x0A\xA1\x01\x0A\x9E\x01\x0A\x9B\x01" | 
 |                               "\x0A\x98\x01\x0A\x95\x01\x0A\x92\x01\x0A\x8F\x01\x0A\x8C\x01" | 
 |                               "\x0A\x89\x01\x0A\x86\x01\x0A\x83\x01\x0A\x80\x01\x0A\x7E" | 
 |                               "\x0A\x7C\x0A\x7A\x0A\x78\x0A\x76\x0A\x74\x0A\x72\x0A\x70" | 
 |                               "\x0A\x6E\x0A\x6C\x0A\x6A\x0A\x68\x0A\x66\x0A\x64\x0A\x62" | 
 |                               "\x0A\x60\x0A\x5E\x0A\x5C\x0A\x5A\x0A\x58\x0A\x56\x0A\x54" | 
 |                               "\x0A\x52\x0A\x50\x0A\x4E\x0A\x4C\x0A\x4A\x0A\x48\x0A\x46" | 
 |                               "\x0A\x44\x0A\x42\x0A\x40\x0A\x3E\x0A\x3C\x0A\x3A\x0A\x38" | 
 |                               "\x0A\x36\x0A\x34\x0A\x32\x0A\x30\x0A\x2E\x0A\x2C\x0A\x2A" | 
 |                               "\x0A\x28\x0A\x26\x0A\x24\x0A\x22\x0A\x20\x0A\x1E\x0A\x1C" | 
 |                               "\x0A\x1A\x0A\x18\x0A\x16\x0A\x14\x0A\x12\x0A\x10\x0A\x0E" | 
 |                               "\x0A\x0C\x0A\x0A\x0A\x08\x0A\x06\x12\x04\x72\x02\x4B\x50"); | 
 |   NSError *error = nil; | 
 |   NestedTestAllTypes *msg = [NestedTestAllTypes parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorRecursionDepthExceeded); | 
 | } | 
 |  | 
 | - (void)testParseDelimitedDataOver2GB { | 
 |   NSData *data = DataFromCStr("\xFF\xFF\xFF\xFF\x0F\x01\x02\0x3");  // Don't need all the bytes | 
 |   GPBCodedInputStream *input = [GPBCodedInputStream streamWithData:data]; | 
 |   NSError *error; | 
 |   GPBMessage *result = [GPBMessage parseDelimitedFromCodedInputStream:input | 
 |                                                     extensionRegistry:nil | 
 |                                                                 error:&error]; | 
 |   XCTAssertNil(result); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidSize); | 
 | } | 
 |  | 
 | #ifdef DEBUG | 
 | - (void)testErrorMissingRequiredField { | 
 |   NSData *data = DataFromCStr(""); | 
 |   NSError *error = nil; | 
 |   TestRequired *msg = [TestRequired parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBMessageErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBMessageErrorCodeMissingRequiredField); | 
 | } | 
 | #endif | 
 |  | 
 | #pragma mark - Subset from from map_tests.cc | 
 |  | 
 | // TEST(GeneratedMapFieldTest, StandardWireFormat) | 
 | - (void)testMap_StandardWireFormat { | 
 |   NSData *data = DataFromCStr("\x0A\x04\x08\x01\x10\x01"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:1]); | 
 |   XCTAssertEqual(val, 1); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, UnorderedWireFormat) | 
 | - (void)testMap_UnorderedWireFormat { | 
 |   // put value before key in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x04\x10\x01\x08\x02"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:2]); | 
 |   XCTAssertEqual(val, 1); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, DuplicatedKeyWireFormat) | 
 | - (void)testMap_DuplicatedKeyWireFormat { | 
 |   // Two key fields in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x06\x08\x01\x08\x02\x10\x01"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:2]); | 
 |   XCTAssertEqual(val, 1); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, DuplicatedValueWireFormat) | 
 | - (void)testMap_DuplicatedValueWireFormat { | 
 |   // Two value fields in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x06\x08\x01\x10\x01\x10\x02"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:1]); | 
 |   XCTAssertEqual(val, 2); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, MissedKeyWireFormat) | 
 | - (void)testMap_MissedKeyWireFormat { | 
 |   // No key field in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x02\x10\x01"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:0]); | 
 |   XCTAssertEqual(val, 1); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, MissedValueWireFormat) | 
 | - (void)testMap_MissedValueWireFormat { | 
 |   // No value field in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x02\x08\x01"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:1]); | 
 |   XCTAssertEqual(val, 0); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, UnknownFieldWireFormat) | 
 | - (void)testMap_UnknownFieldWireFormat { | 
 |   // Unknown field in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x06\x08\x02\x10\x03\x18\x01"); | 
 |  | 
 |   TestMap *msg = [[TestMap alloc] initWithData:data error:NULL]; | 
 |   XCTAssertEqual(msg.mapInt32Int32.count, 1U); | 
 |   int32_t val = 666; | 
 |   XCTAssertTrue([msg.mapInt32Int32 getInt32:&val forKey:2]); | 
 |   XCTAssertEqual(val, 3); | 
 |  | 
 |   [msg release]; | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, CorruptedWireFormat) | 
 | - (void)testMap_CorruptedWireFormat { | 
 |   // corrupted data in wire format | 
 |   NSData *data = DataFromCStr("\x0A\x06\x08\x02\x11\x03"); | 
 |  | 
 |   NSError *error = nil; | 
 |   TestMap *msg = [TestMap parseFromData:data error:&error]; | 
 |   XCTAssertNil(msg); | 
 |   XCTAssertNotNil(error); | 
 |   XCTAssertEqualObjects(error.domain, GPBCodedInputStreamErrorDomain); | 
 |   XCTAssertEqual(error.code, GPBCodedInputStreamErrorInvalidSubsectionLimit); | 
 | } | 
 |  | 
 | // TEST(GeneratedMapFieldTest, Proto2UnknownEnum) | 
 | - (void)testMap_Proto2UnknownEnum { | 
 |   TestEnumMapPlusExtra *orig = [[TestEnumMapPlusExtra alloc] init]; | 
 |  | 
 |   orig.knownMapField = [[[GPBInt32EnumDictionary alloc] | 
 |       initWithValidationFunction:Proto2MapEnumPlusExtra_IsValidValue] autorelease]; | 
 |   orig.unknownMapField = [[[GPBInt32EnumDictionary alloc] | 
 |       initWithValidationFunction:Proto2MapEnumPlusExtra_IsValidValue] autorelease]; | 
 |   [orig.knownMapField setEnum:Proto2MapEnumPlusExtra_EProto2MapEnumFoo forKey:0]; | 
 |   [orig.unknownMapField setEnum:Proto2MapEnumPlusExtra_EProto2MapEnumExtra forKey:0]; | 
 |  | 
 |   NSData *data = [orig data]; | 
 |   XCTAssertNotNil(data); | 
 |   TestEnumMap *msg1 = [TestEnumMap parseFromData:data error:NULL]; | 
 |   XCTAssertEqual(msg1.knownMapField.count, 1U); | 
 |   int32_t val = -1; | 
 |   XCTAssertTrue([msg1.knownMapField getEnum:&val forKey:0]); | 
 |   XCTAssertEqual(val, Proto2MapEnum_Proto2MapEnumFoo); | 
 |   XCTAssertEqual(msg1.unknownFields.countOfFields, 1U); | 
 |  | 
 |   data = [msg1 data]; | 
 |   TestEnumMapPlusExtra *msg2 = [TestEnumMapPlusExtra parseFromData:data error:NULL]; | 
 |   val = -1; | 
 |   XCTAssertEqual(msg2.knownMapField.count, 1U); | 
 |   XCTAssertTrue([msg2.knownMapField getEnum:&val forKey:0]); | 
 |   XCTAssertEqual(val, Proto2MapEnumPlusExtra_EProto2MapEnumFoo); | 
 |   val = -1; | 
 |   XCTAssertEqual(msg2.unknownMapField.count, 1U); | 
 |   XCTAssertTrue([msg2.unknownMapField getEnum:&val forKey:0]); | 
 |   XCTAssertEqual(val, Proto2MapEnumPlusExtra_EProto2MapEnumExtra); | 
 |   XCTAssertEqual(msg2.unknownFields.countOfFields, 0U); | 
 |  | 
 |   XCTAssertEqualObjects(orig, msg2); | 
 |  | 
 |   [orig release]; | 
 | } | 
 |  | 
 | #pragma mark - Map Round Tripping | 
 |  | 
 | - (void)testProto2MapRoundTripping { | 
 |   Message2 *msg = [[Message2 alloc] init]; | 
 |  | 
 |   // Key/Value data should result in different byte lengths on wire to ensure | 
 |   // everything is right. | 
 |   [msg.mapInt32Int32 setInt32:1000 forKey:200]; | 
 |   [msg.mapInt32Int32 setInt32:101 forKey:2001]; | 
 |   [msg.mapInt64Int64 setInt64:1002 forKey:202]; | 
 |   [msg.mapInt64Int64 setInt64:103 forKey:2003]; | 
 |   [msg.mapInt64Int64 setInt64:4294967296 forKey:4294967297]; | 
 |   [msg.mapUint32Uint32 setUInt32:1004 forKey:204]; | 
 |   [msg.mapUint32Uint32 setUInt32:105 forKey:2005]; | 
 |   [msg.mapUint64Uint64 setUInt64:1006 forKey:206]; | 
 |   [msg.mapUint64Uint64 setUInt64:107 forKey:2007]; | 
 |   [msg.mapUint64Uint64 setUInt64:4294967298 forKey:4294967299]; | 
 |   [msg.mapSint32Sint32 setInt32:1008 forKey:208]; | 
 |   [msg.mapSint32Sint32 setInt32:109 forKey:2009]; | 
 |   [msg.mapSint64Sint64 setInt64:1010 forKey:210]; | 
 |   [msg.mapSint64Sint64 setInt64:111 forKey:2011]; | 
 |   [msg.mapSint64Sint64 setInt64:4294967300 forKey:4294967301]; | 
 |   [msg.mapFixed32Fixed32 setUInt32:1012 forKey:212]; | 
 |   [msg.mapFixed32Fixed32 setUInt32:113 forKey:2013]; | 
 |   [msg.mapFixed64Fixed64 setUInt64:1014 forKey:214]; | 
 |   [msg.mapFixed64Fixed64 setUInt64:115 forKey:2015]; | 
 |   [msg.mapFixed64Fixed64 setUInt64:4294967302 forKey:4294967303]; | 
 |   [msg.mapSfixed32Sfixed32 setInt32:1016 forKey:216]; | 
 |   [msg.mapSfixed32Sfixed32 setInt32:117 forKey:2017]; | 
 |   [msg.mapSfixed64Sfixed64 setInt64:1018 forKey:218]; | 
 |   [msg.mapSfixed64Sfixed64 setInt64:119 forKey:2019]; | 
 |   [msg.mapSfixed64Sfixed64 setInt64:4294967304 forKey:4294967305]; | 
 |   [msg.mapInt32Float setFloat:1020.f forKey:220]; | 
 |   [msg.mapInt32Float setFloat:121.f forKey:2021]; | 
 |   [msg.mapInt32Double setDouble:1022. forKey:222]; | 
 |   [msg.mapInt32Double setDouble:123. forKey:2023]; | 
 |   [msg.mapBoolBool setBool:false forKey:true]; | 
 |   [msg.mapBoolBool setBool:true forKey:false]; | 
 |   msg.mapStringString[@"224"] = @"1024"; | 
 |   msg.mapStringString[@"2025"] = @"125"; | 
 |   msg.mapStringBytes[@"226"] = DataFromCStr("1026"); | 
 |   msg.mapStringBytes[@"2027"] = DataFromCStr("127"); | 
 |   Message2 *val1 = [[Message2 alloc] init]; | 
 |   val1.optionalInt32 = 1028; | 
 |   Message2 *val2 = [[Message2 alloc] init]; | 
 |   val2.optionalInt32 = 129; | 
 |   [msg.mapStringMessage setObject:val1 forKey:@"228"]; | 
 |   [msg.mapStringMessage setObject:val2 forKey:@"2029"]; | 
 |   [msg.mapInt32Bytes setObject:DataFromCStr("1030 bytes") forKey:230]; | 
 |   [msg.mapInt32Bytes setObject:DataFromCStr("131") forKey:2031]; | 
 |   [msg.mapInt32Enum setEnum:Message2_Enum_Bar forKey:232]; | 
 |   [msg.mapInt32Enum setEnum:Message2_Enum_Baz forKey:2033]; | 
 |   Message2 *val3 = [[Message2 alloc] init]; | 
 |   val3.optionalInt32 = 1034; | 
 |   Message2 *val4 = [[Message2 alloc] init]; | 
 |   val4.optionalInt32 = 135; | 
 |   [msg.mapInt32Message setObject:val3 forKey:234]; | 
 |   [msg.mapInt32Message setObject:val4 forKey:2035]; | 
 |  | 
 |   NSData *data = [msg data]; | 
 |   XCTAssertNotNil(data); | 
 |   Message2 *msg2 = [[Message2 alloc] initWithData:data error:NULL]; | 
 |  | 
 |   XCTAssertNotEqual(msg2, msg);  // Pointer comparison | 
 |   XCTAssertEqualObjects(msg2, msg); | 
 |  | 
 |   [val4 release]; | 
 |   [val3 release]; | 
 |   [val2 release]; | 
 |   [val1 release]; | 
 |   [msg2 release]; | 
 |   [msg release]; | 
 | } | 
 |  | 
 | @end |