Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
91b6d04e
Commit
91b6d04e
authored
Aug 11, 2016
by
Thomas Van Lenten
Committed by
GitHub
Aug 11, 2016
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1942 from thomasvl/objc_fix_oneof_zeros
Objc fix oneof zeros and more oneof zero conformance tests
parents
ac3df39c
27c89625
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
357 additions
and
31 deletions
+357
-31
conformance.proto
conformance/conformance.proto
+5
-0
conformance_test.cc
conformance/conformance_test.cc
+30
-0
failure_list_csharp.txt
conformance/failure_list_csharp.txt
+20
-0
failure_list_objc.txt
conformance/failure_list_objc.txt
+3
-5
failure_list_ruby.txt
conformance/failure_list_ruby.txt
+6
-0
GPBUtilities.m
objectivec/GPBUtilities.m
+45
-26
GPBMessageTests+Runtime.m
objectivec/Tests/GPBMessageTests+Runtime.m
+248
-0
No files found.
conformance/conformance.proto
View file @
91b6d04e
...
@@ -210,6 +210,11 @@ message TestAllTypes {
...
@@ -210,6 +210,11 @@ message TestAllTypes {
NestedMessage
oneof_nested_message
=
112
;
NestedMessage
oneof_nested_message
=
112
;
string
oneof_string
=
113
;
string
oneof_string
=
113
;
bytes
oneof_bytes
=
114
;
bytes
oneof_bytes
=
114
;
bool
oneof_bool
=
115
;
uint64
oneof_uint64
=
116
;
float
oneof_float
=
117
;
double
oneof_double
=
118
;
NestedEnum
oneof_enum
=
119
;
}
}
// Well-known types
// Well-known types
...
...
conformance/conformance_test.cc
View file @
91b6d04e
...
@@ -1256,6 +1256,21 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -1256,6 +1256,21 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
message
.
set_oneof_bytes
(
""
);
message
.
set_oneof_bytes
(
""
);
RunValidProtobufTest
(
RunValidProtobufTest
(
"OneofZeroBytes"
,
message
,
"oneof_bytes:
\"\"
"
);
"OneofZeroBytes"
,
message
,
"oneof_bytes:
\"\"
"
);
message
.
set_oneof_bool
(
false
);
RunValidProtobufTest
(
"OneofZeroBool"
,
message
,
"oneof_bool: false"
);
message
.
set_oneof_uint64
(
0
);
RunValidProtobufTest
(
"OneofZeroUint64"
,
message
,
"oneof_uint64: 0"
);
message
.
set_oneof_float
(
0.0
f
);
RunValidProtobufTest
(
"OneofZeroFloat"
,
message
,
"oneof_float: 0"
);
message
.
set_oneof_double
(
0.0
);
RunValidProtobufTest
(
"OneofZeroDouble"
,
message
,
"oneof_double: 0"
);
message
.
set_oneof_enum
(
TestAllTypes
::
FOO
);
RunValidProtobufTest
(
"OneofZeroEnum"
,
message
,
"oneof_enum: FOO"
);
}
}
RunValidJsonTest
(
RunValidJsonTest
(
"OneofZeroUint32"
,
"OneofZeroUint32"
,
...
@@ -1269,6 +1284,21 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -1269,6 +1284,21 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
RunValidJsonTest
(
RunValidJsonTest
(
"OneofZeroBytes"
,
"OneofZeroBytes"
,
R"({"oneofBytes": ""})"
,
"oneof_bytes:
\"\"
"
);
R"({"oneofBytes": ""})"
,
"oneof_bytes:
\"\"
"
);
RunValidJsonTest
(
"OneofZeroBool"
,
R"({"oneofBool": false})"
,
"oneof_bool: false"
);
RunValidJsonTest
(
"OneofZeroUint64"
,
R"({"oneofUint64": 0})"
,
"oneof_uint64: 0"
);
RunValidJsonTest
(
"OneofZeroFloat"
,
R"({"oneofFloat": 0.0})"
,
"oneof_float: 0"
);
RunValidJsonTest
(
"OneofZeroDouble"
,
R"({"oneofDouble": 0.0})"
,
"oneof_double: 0"
);
RunValidJsonTest
(
"OneofZeroEnum"
,
R"({"oneofEnum":"FOO"})"
,
"oneof_enum: FOO"
);
// Repeated fields.
// Repeated fields.
RunValidJsonTest
(
RunValidJsonTest
(
...
...
conformance/failure_list_csharp.txt
View file @
91b6d04e
...
@@ -5,3 +5,23 @@ JsonInput.FieldNameWithMixedCases.JsonOutput
...
@@ -5,3 +5,23 @@ JsonInput.FieldNameWithMixedCases.JsonOutput
JsonInput.FieldNameWithMixedCases.ProtobufOutput
JsonInput.FieldNameWithMixedCases.ProtobufOutput
JsonInput.FieldNameWithMixedCases.Validator
JsonInput.FieldNameWithMixedCases.Validator
JsonInput.OriginalProtoFieldName.JsonOutput
JsonInput.OriginalProtoFieldName.JsonOutput
JsonInput.OneofZeroBool.JsonOutput
JsonInput.OneofZeroBool.ProtobufOutput
JsonInput.OneofZeroDouble.JsonOutput
JsonInput.OneofZeroDouble.ProtobufOutput
JsonInput.OneofZeroEnum.JsonOutput
JsonInput.OneofZeroEnum.ProtobufOutput
JsonInput.OneofZeroFloat.JsonOutput
JsonInput.OneofZeroFloat.ProtobufOutput
JsonInput.OneofZeroUint64.JsonOutput
JsonInput.OneofZeroUint64.ProtobufOutput
ProtobufInput.OneofZeroBool.JsonOutput
ProtobufInput.OneofZeroBool.ProtobufOutput
ProtobufInput.OneofZeroDouble.JsonOutput
ProtobufInput.OneofZeroDouble.ProtobufOutput
ProtobufInput.OneofZeroEnum.JsonOutput
ProtobufInput.OneofZeroEnum.ProtobufOutput
ProtobufInput.OneofZeroFloat.JsonOutput
ProtobufInput.OneofZeroFloat.ProtobufOutput
ProtobufInput.OneofZeroUint64.JsonOutput
ProtobufInput.OneofZeroUint64.ProtobufOutput
conformance/failure_list_objc.txt
View file @
91b6d04e
ProtobufInput.OneofZeroBytes.ProtobufOutput
# All tests currently passing.
ProtobufInput.OneofZeroString.ProtobufOutput
ProtobufInput.OneofZeroUint32.ProtobufOutput
#
#
#
json
input or output tests are skipped (in conformance_objc.m) as mobile
#
JSON
input or output tests are skipped (in conformance_objc.m) as mobile
# platforms don't support
json
wire format to avoid code bloat.
# platforms don't support
JSON
wire format to avoid code bloat.
conformance/failure_list_ruby.txt
View file @
91b6d04e
...
@@ -103,8 +103,14 @@ JsonInput.MessageMapField.JsonOutput
...
@@ -103,8 +103,14 @@ JsonInput.MessageMapField.JsonOutput
JsonInput.MessageMapField.ProtobufOutput
JsonInput.MessageMapField.ProtobufOutput
JsonInput.MessageRepeatedField.JsonOutput
JsonInput.MessageRepeatedField.JsonOutput
JsonInput.MessageRepeatedField.ProtobufOutput
JsonInput.MessageRepeatedField.ProtobufOutput
JsonInput.OneofZeroDouble.JsonOutput
JsonInput.OneofZeroDouble.ProtobufOutput
JsonInput.OneofZeroFloat.JsonOutput
JsonInput.OneofZeroFloat.ProtobufOutput
JsonInput.OneofZeroUint32.JsonOutput
JsonInput.OneofZeroUint32.JsonOutput
JsonInput.OneofZeroUint32.ProtobufOutput
JsonInput.OneofZeroUint32.ProtobufOutput
JsonInput.OneofZeroUint64.JsonOutput
JsonInput.OneofZeroUint64.ProtobufOutput
JsonInput.OptionalBoolWrapper.JsonOutput
JsonInput.OptionalBoolWrapper.JsonOutput
JsonInput.OptionalBoolWrapper.ProtobufOutput
JsonInput.OptionalBoolWrapper.ProtobufOutput
JsonInput.OptionalBytesWrapper.JsonOutput
JsonInput.OptionalBytesWrapper.JsonOutput
...
...
objectivec/GPBUtilities.m
View file @
91b6d04e
...
@@ -218,9 +218,10 @@ void GPBMaybeClearOneof(GPBMessage *self, GPBOneofDescriptor *oneof,
...
@@ -218,9 +218,10 @@ void GPBMaybeClearOneof(GPBMessage *self, GPBOneofDescriptor *oneof,
//% TYPE *typePtr = (TYPE *)&storage[field->description_->offset];
//% TYPE *typePtr = (TYPE *)&storage[field->description_->offset];
//% *typePtr = value;
//% *typePtr = value;
//% // proto2: any value counts as having been set; proto3, it
//% // proto2: any value counts as having been set; proto3, it
//% // has to be a non zero value.
//% // has to be a non zero value or be in a oneof.
//% BOOL hasValue =
//% BOOL hasValue = ((syntax == GPBFileSyntaxProto2)
//% (syntax == GPBFileSyntaxProto2) || (value != (TYPE)0);
//% || (value != (TYPE)0)
//% || (field->containingOneof_ != NULL));
//% GPBSetHasIvarField(self, field, hasValue);
//% GPBSetHasIvarField(self, field, hasValue);
//% GPBBecomeVisibleToAutocreator(self);
//% GPBBecomeVisibleToAutocreator(self);
//%}
//%}
...
@@ -337,8 +338,19 @@ void GPBSetRetainedObjectIvarWithFieldInternal(GPBMessage *self,
...
@@ -337,8 +338,19 @@ void GPBSetRetainedObjectIvarWithFieldInternal(GPBMessage *self,
// zero, they are being cleared.
// zero, they are being cleared.
if
((
syntax
==
GPBFileSyntaxProto3
)
&&
!
fieldIsMessage
&&
if
((
syntax
==
GPBFileSyntaxProto3
)
&&
!
fieldIsMessage
&&
([
value
length
]
==
0
))
{
([
value
length
]
==
0
))
{
setHasValue
=
NO
;
// Except, if the field was in a oneof, then it still gets recorded as
value
=
nil
;
// having been set so the state of the oneof can be serialized back out.
if
(
!
oneof
)
{
setHasValue
=
NO
;
}
if
(
setHasValue
)
{
NSCAssert
(
value
!=
nil
,
@"Should never be setting has for nil"
);
}
else
{
// The value passed in was retained, it must be released since we
// aren't saving anything in the field.
[
value
release
];
value
=
nil
;
}
}
}
GPBSetHasIvarField
(
self
,
field
,
setHasValue
);
GPBSetHasIvarField
(
self
,
field
,
setHasValue
);
}
}
...
@@ -524,9 +536,10 @@ void GPBSetBoolIvarWithFieldInternal(GPBMessage *self,
...
@@ -524,9 +536,10 @@ void GPBSetBoolIvarWithFieldInternal(GPBMessage *self,
GPBSetHasIvar
(
self
,
(
int32_t
)(
fieldDesc
->
offset
),
fieldDesc
->
number
,
value
);
GPBSetHasIvar
(
self
,
(
int32_t
)(
fieldDesc
->
offset
),
fieldDesc
->
number
,
value
);
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
BOOL
)
0
);
||
(
value
!=
(
BOOL
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
@@ -573,9 +586,10 @@ void GPBSetInt32IvarWithFieldInternal(GPBMessage *self,
...
@@ -573,9 +586,10 @@ void GPBSetInt32IvarWithFieldInternal(GPBMessage *self,
int32_t
*
typePtr
=
(
int32_t
*
)
&
storage
[
field
->
description_
->
offset
];
int32_t
*
typePtr
=
(
int32_t
*
)
&
storage
[
field
->
description_
->
offset
];
*
typePtr
=
value
;
*
typePtr
=
value
;
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
int32_t
)
0
);
||
(
value
!=
(
int32_t
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
@@ -622,9 +636,10 @@ void GPBSetUInt32IvarWithFieldInternal(GPBMessage *self,
...
@@ -622,9 +636,10 @@ void GPBSetUInt32IvarWithFieldInternal(GPBMessage *self,
uint32_t
*
typePtr
=
(
uint32_t
*
)
&
storage
[
field
->
description_
->
offset
];
uint32_t
*
typePtr
=
(
uint32_t
*
)
&
storage
[
field
->
description_
->
offset
];
*
typePtr
=
value
;
*
typePtr
=
value
;
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
uint32_t
)
0
);
||
(
value
!=
(
uint32_t
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
@@ -671,9 +686,10 @@ void GPBSetInt64IvarWithFieldInternal(GPBMessage *self,
...
@@ -671,9 +686,10 @@ void GPBSetInt64IvarWithFieldInternal(GPBMessage *self,
int64_t
*
typePtr
=
(
int64_t
*
)
&
storage
[
field
->
description_
->
offset
];
int64_t
*
typePtr
=
(
int64_t
*
)
&
storage
[
field
->
description_
->
offset
];
*
typePtr
=
value
;
*
typePtr
=
value
;
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
int64_t
)
0
);
||
(
value
!=
(
int64_t
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
@@ -720,9 +736,10 @@ void GPBSetUInt64IvarWithFieldInternal(GPBMessage *self,
...
@@ -720,9 +736,10 @@ void GPBSetUInt64IvarWithFieldInternal(GPBMessage *self,
uint64_t
*
typePtr
=
(
uint64_t
*
)
&
storage
[
field
->
description_
->
offset
];
uint64_t
*
typePtr
=
(
uint64_t
*
)
&
storage
[
field
->
description_
->
offset
];
*
typePtr
=
value
;
*
typePtr
=
value
;
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
uint64_t
)
0
);
||
(
value
!=
(
uint64_t
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
@@ -769,9 +786,10 @@ void GPBSetFloatIvarWithFieldInternal(GPBMessage *self,
...
@@ -769,9 +786,10 @@ void GPBSetFloatIvarWithFieldInternal(GPBMessage *self,
float
*
typePtr
=
(
float
*
)
&
storage
[
field
->
description_
->
offset
];
float
*
typePtr
=
(
float
*
)
&
storage
[
field
->
description_
->
offset
];
*
typePtr
=
value
;
*
typePtr
=
value
;
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
float
)
0
);
||
(
value
!=
(
float
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
@@ -818,9 +836,10 @@ void GPBSetDoubleIvarWithFieldInternal(GPBMessage *self,
...
@@ -818,9 +836,10 @@ void GPBSetDoubleIvarWithFieldInternal(GPBMessage *self,
double
*
typePtr
=
(
double
*
)
&
storage
[
field
->
description_
->
offset
];
double
*
typePtr
=
(
double
*
)
&
storage
[
field
->
description_
->
offset
];
*
typePtr
=
value
;
*
typePtr
=
value
;
// proto2: any value counts as having been set; proto3, it
// proto2: any value counts as having been set; proto3, it
// has to be a non zero value.
// has to be a non zero value or be in a oneof.
BOOL
hasValue
=
BOOL
hasValue
=
((
syntax
==
GPBFileSyntaxProto2
)
(
syntax
==
GPBFileSyntaxProto2
)
||
(
value
!=
(
double
)
0
);
||
(
value
!=
(
double
)
0
)
||
(
field
->
containingOneof_
!=
NULL
));
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBSetHasIvarField
(
self
,
field
,
hasValue
);
GPBBecomeVisibleToAutocreator
(
self
);
GPBBecomeVisibleToAutocreator
(
self
);
}
}
...
...
objectivec/Tests/GPBMessageTests+Runtime.m
View file @
91b6d04e
...
@@ -1972,6 +1972,254 @@
...
@@ -1972,6 +1972,254 @@
[
msg
release
];
[
msg
release
];
}
}
-
(
void
)
testProto2OneofSetToDefault
{
// proto3 doesn't normally write out zero (default) fields, but if they are
// in a oneof it does. proto2 doesn't have this special behavior, but we
// still confirm setting to the explicit default does set the case to be
// sure the runtime is working correctly.
NSString
*
oneofStringDefault
=
@"string"
;
NSData
*
oneofBytesDefault
=
[
@"data"
dataUsingEncoding
:
NSUTF8StringEncoding
];
Message2
*
msg
=
[[
Message2
alloc
]
init
];
uint32_t
values
[]
=
{
Message2_O_OneOfCase_OneofInt32
,
Message2_O_OneOfCase_OneofInt64
,
Message2_O_OneOfCase_OneofUint32
,
Message2_O_OneOfCase_OneofUint64
,
Message2_O_OneOfCase_OneofSint32
,
Message2_O_OneOfCase_OneofSint64
,
Message2_O_OneOfCase_OneofFixed32
,
Message2_O_OneOfCase_OneofFixed64
,
Message2_O_OneOfCase_OneofSfixed32
,
Message2_O_OneOfCase_OneofSfixed64
,
Message2_O_OneOfCase_OneofFloat
,
Message2_O_OneOfCase_OneofDouble
,
Message2_O_OneOfCase_OneofBool
,
Message2_O_OneOfCase_OneofString
,
Message2_O_OneOfCase_OneofBytes
,
// Skip group
// Skip message
Message2_O_OneOfCase_OneofEnum
,
};
for
(
size_t
i
=
0
;
i
<
GPBARRAYSIZE
(
values
);
++
i
)
{
switch
(
values
[
i
])
{
case
Message3_O_OneOfCase_OneofInt32
:
msg
.
oneofInt32
=
100
;
break
;
case
Message3_O_OneOfCase_OneofInt64
:
msg
.
oneofInt64
=
101
;
break
;
case
Message3_O_OneOfCase_OneofUint32
:
msg
.
oneofUint32
=
102
;
break
;
case
Message3_O_OneOfCase_OneofUint64
:
msg
.
oneofUint64
=
103
;
break
;
case
Message3_O_OneOfCase_OneofSint32
:
msg
.
oneofSint32
=
104
;
break
;
case
Message3_O_OneOfCase_OneofSint64
:
msg
.
oneofSint64
=
105
;
break
;
case
Message3_O_OneOfCase_OneofFixed32
:
msg
.
oneofFixed32
=
106
;
break
;
case
Message3_O_OneOfCase_OneofFixed64
:
msg
.
oneofFixed64
=
107
;
break
;
case
Message3_O_OneOfCase_OneofSfixed32
:
msg
.
oneofSfixed32
=
108
;
break
;
case
Message3_O_OneOfCase_OneofSfixed64
:
msg
.
oneofSfixed64
=
109
;
break
;
case
Message3_O_OneOfCase_OneofFloat
:
msg
.
oneofFloat
=
110
.
0
f
;
break
;
case
Message3_O_OneOfCase_OneofDouble
:
msg
.
oneofDouble
=
111
.
0
;
break
;
case
Message3_O_OneOfCase_OneofBool
:
msg
.
oneofBool
=
YES
;
break
;
case
Message3_O_OneOfCase_OneofString
:
msg
.
oneofString
=
oneofStringDefault
;
break
;
case
Message3_O_OneOfCase_OneofBytes
:
msg
.
oneofBytes
=
oneofBytesDefault
;
break
;
case
Message3_O_OneOfCase_OneofEnum
:
msg
.
oneofEnum
=
Message3_Enum_Baz
;
break
;
default
:
XCTFail
(
@"shouldn't happen, loop: %zd, value: %d"
,
i
,
values
[
i
]);
break
;
}
// Should be set to the correct case.
XCTAssertEqual
(
msg
.
oOneOfCase
,
values
[
i
],
"Loop: %zd"
,
i
);
// Confirm everything is back as the defaults.
XCTAssertEqual
(
msg
.
oneofInt32
,
100
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofInt64
,
101
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofUint32
,
102U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofUint64
,
103U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSint32
,
104
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSint64
,
105
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofFixed32
,
106U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofFixed64
,
107U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSfixed32
,
108
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSfixed64
,
109
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofFloat
,
110
.
0
f
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofDouble
,
111
.
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofBool
,
YES
,
"Loop: %zd"
,
i
);
XCTAssertEqualObjects
(
msg
.
oneofString
,
oneofStringDefault
,
"Loop: %zd"
,
i
);
XCTAssertEqualObjects
(
msg
.
oneofBytes
,
oneofBytesDefault
,
"Loop: %zd"
,
i
);
XCTAssertNotNil
(
msg
.
oneofGroup
,
"Loop: %zd"
,
i
);
// Skip group
// Skip message
XCTAssertEqual
(
msg
.
oneofEnum
,
Message2_Enum_Baz
,
"Loop: %zd"
,
i
);
}
// We special case nil on string, data, message, ensure they work as expected.
// i.e. - it clears the case.
msg
.
oneofString
=
nil
;
XCTAssertEqual
(
msg
.
oOneOfCase
,
Message3_O_OneOfCase_GPBUnsetOneOfCase
);
msg
.
oneofBytes
=
nil
;
XCTAssertEqual
(
msg
.
oOneOfCase
,
Message3_O_OneOfCase_GPBUnsetOneOfCase
);
msg
.
oneofMessage
=
nil
;
XCTAssertEqual
(
msg
.
oOneOfCase
,
Message3_O_OneOfCase_GPBUnsetOneOfCase
);
[
msg
release
];
}
-
(
void
)
testProto3OneofSetToZero
{
// Normally setting a proto3 field to the zero value should result in it being
// reset/cleared. But in a oneof, it still gets recored so it can go out
// over the wire and the other side can see what was set in the oneof.
NSString
*
oneofStringDefault
=
@""
;
NSData
*
oneofBytesDefault
=
[
NSData
data
];
Message3
*
msg
=
[[
Message3
alloc
]
init
];
uint32_t
values
[]
=
{
Message3_O_OneOfCase_OneofInt32
,
Message3_O_OneOfCase_OneofInt64
,
Message3_O_OneOfCase_OneofUint32
,
Message3_O_OneOfCase_OneofUint64
,
Message3_O_OneOfCase_OneofSint32
,
Message3_O_OneOfCase_OneofSint64
,
Message3_O_OneOfCase_OneofFixed32
,
Message3_O_OneOfCase_OneofFixed64
,
Message3_O_OneOfCase_OneofSfixed32
,
Message3_O_OneOfCase_OneofSfixed64
,
Message3_O_OneOfCase_OneofFloat
,
Message3_O_OneOfCase_OneofDouble
,
Message3_O_OneOfCase_OneofBool
,
Message3_O_OneOfCase_OneofString
,
Message3_O_OneOfCase_OneofBytes
,
Message3_O_OneOfCase_OneofMessage
,
Message3_O_OneOfCase_OneofEnum
,
};
for
(
size_t
i
=
0
;
i
<
GPBARRAYSIZE
(
values
);
++
i
)
{
switch
(
values
[
i
])
{
case
Message3_O_OneOfCase_OneofInt32
:
msg
.
oneofInt32
=
0
;
break
;
case
Message3_O_OneOfCase_OneofInt64
:
msg
.
oneofInt64
=
0
;
break
;
case
Message3_O_OneOfCase_OneofUint32
:
msg
.
oneofUint32
=
0
;
break
;
case
Message3_O_OneOfCase_OneofUint64
:
msg
.
oneofUint64
=
0
;
break
;
case
Message3_O_OneOfCase_OneofSint32
:
msg
.
oneofSint32
=
0
;
break
;
case
Message3_O_OneOfCase_OneofSint64
:
msg
.
oneofSint64
=
0
;
break
;
case
Message3_O_OneOfCase_OneofFixed32
:
msg
.
oneofFixed32
=
0
;
break
;
case
Message3_O_OneOfCase_OneofFixed64
:
msg
.
oneofFixed64
=
0
;
break
;
case
Message3_O_OneOfCase_OneofSfixed32
:
msg
.
oneofSfixed32
=
0
;
break
;
case
Message3_O_OneOfCase_OneofSfixed64
:
msg
.
oneofSfixed64
=
0
;
break
;
case
Message3_O_OneOfCase_OneofFloat
:
msg
.
oneofFloat
=
0
.
0
f
;
break
;
case
Message3_O_OneOfCase_OneofDouble
:
msg
.
oneofDouble
=
0
.
0
;
break
;
case
Message3_O_OneOfCase_OneofBool
:
msg
.
oneofBool
=
NO
;
break
;
case
Message3_O_OneOfCase_OneofString
:
msg
.
oneofString
=
oneofStringDefault
;
break
;
case
Message3_O_OneOfCase_OneofBytes
:
msg
.
oneofBytes
=
oneofBytesDefault
;
break
;
case
Message3_O_OneOfCase_OneofMessage
:
msg
.
oneofMessage
.
optionalInt32
=
0
;
break
;
case
Message3_O_OneOfCase_OneofEnum
:
msg
.
oneofEnum
=
Message3_Enum_Foo
;
break
;
default
:
XCTFail
(
@"shouldn't happen, loop: %zd, value: %d"
,
i
,
values
[
i
]);
break
;
}
// Should be set to the correct case.
XCTAssertEqual
(
msg
.
oOneOfCase
,
values
[
i
],
"Loop: %zd"
,
i
);
// Confirm everything is still zeros.
XCTAssertEqual
(
msg
.
oneofInt32
,
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofInt64
,
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofUint32
,
0U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofUint64
,
0U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSint32
,
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSint64
,
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofFixed32
,
0U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofFixed64
,
0U
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSfixed32
,
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofSfixed64
,
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofFloat
,
0
.
0
f
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofDouble
,
0
.
0
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofBool
,
NO
,
"Loop: %zd"
,
i
);
XCTAssertEqualObjects
(
msg
.
oneofString
,
oneofStringDefault
,
"Loop: %zd"
,
i
);
XCTAssertEqualObjects
(
msg
.
oneofBytes
,
oneofBytesDefault
,
"Loop: %zd"
,
i
);
XCTAssertNotNil
(
msg
.
oneofMessage
,
"Loop: %zd"
,
i
);
XCTAssertEqual
(
msg
.
oneofEnum
,
Message3_Enum_Foo
,
"Loop: %zd"
,
i
);
}
// We special case nil on string, data, message, ensure they work as expected.
msg
.
oneofString
=
nil
;
XCTAssertEqual
(
msg
.
oOneOfCase
,
Message3_O_OneOfCase_GPBUnsetOneOfCase
);
msg
.
oneofBytes
=
nil
;
XCTAssertEqual
(
msg
.
oOneOfCase
,
Message3_O_OneOfCase_GPBUnsetOneOfCase
);
msg
.
oneofMessage
=
nil
;
XCTAssertEqual
(
msg
.
oOneOfCase
,
Message3_O_OneOfCase_GPBUnsetOneOfCase
);
[
msg
release
];
}
-
(
void
)
testCopyingMakesUniqueObjects
{
-
(
void
)
testCopyingMakesUniqueObjects
{
const
int
repeatCount
=
5
;
const
int
repeatCount
=
5
;
TestAllTypes
*
msg1
=
[
TestAllTypes
message
];
TestAllTypes
*
msg1
=
[
TestAllTypes
message
];
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment