1228 lines
44 KiB
Objective-C
1228 lines
44 KiB
Objective-C
// 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 "google/protobuf/MapProto2Unittest.pbobjc.h"
|
|
#import "google/protobuf/MapUnittest.pbobjc.h"
|
|
#import "google/protobuf/Unittest.pbobjc.h"
|
|
#import "google/protobuf/UnittestDropUnknownFields.pbobjc.h"
|
|
#import "google/protobuf/UnittestPreserveUnknownEnum.pbobjc.h"
|
|
#import "google/protobuf/UnittestRuntimeProto2.pbobjc.h"
|
|
#import "google/protobuf/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)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);
|
|
}
|
|
|
|
//%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, Message2_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 = Message2_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, Message2_Enum_Bar);
|
|
[orig release];
|
|
}
|
|
|
|
[subMessage release];
|
|
}
|
|
|
|
//%PDDM-EXPAND-END (2 expansions)
|
|
|
|
- (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)testParseDelimitedDataWithNegativeSize {
|
|
NSData *data = DataFromCStr("\xFF\xFF\xFF\xFF\x0F");
|
|
GPBCodedInputStream *input = [GPBCodedInputStream streamWithData:data];
|
|
NSError *error;
|
|
[GPBMessage parseDelimitedFromCodedInputStream:input
|
|
extensionRegistry:nil
|
|
error:&error];
|
|
XCTAssertNil(error);
|
|
}
|
|
|
|
#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
|