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
2ad74e16
Commit
2ad74e16
authored
Jun 27, 2017
by
Yilun Chong
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add support for proto2
parent
4e67590e
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
143 additions
and
87 deletions
+143
-87
conformance.proto
conformance/conformance.proto
+2
-0
conformance_ruby.rb
conformance/conformance_ruby.rb
+13
-6
conformance_test.cc
conformance/conformance_test.cc
+109
-70
conformance_test.h
conformance/conformance_test.h
+14
-7
test_messages_proto2.proto
src/google/protobuf/test_messages_proto2.proto
+5
-4
No files found.
conformance/conformance.proto
View file @
2ad74e16
...
@@ -77,6 +77,8 @@ message ConformanceRequest {
...
@@ -77,6 +77,8 @@ message ConformanceRequest {
// Which format should the testee serialize its message to?
// Which format should the testee serialize its message to?
WireFormat
requested_output_format
=
3
;
WireFormat
requested_output_format
=
3
;
string
message_type
=
4
;
}
}
// Represents a single test case's output.
// Represents a single test case's output.
...
...
conformance/conformance_ruby.rb
View file @
2ad74e16
...
@@ -43,12 +43,19 @@ def do_test(request)
...
@@ -43,12 +43,19 @@ def do_test(request)
begin
begin
case
request
.
payload
case
request
.
payload
when
:protobuf_payload
when
:protobuf_payload
begin
if
request
.
message_type
.
eql?
(
'proto3'
)
test_message
=
ProtobufTestMessages
::
Proto3
::
TestAllTypes
.
decode
(
begin
request
.
protobuf_payload
)
test_message
=
ProtobufTestMessages
::
Proto3
::
TestAllTypes
.
decode
(
rescue
Google
::
Protobuf
::
ParseError
=>
err
request
.
protobuf_payload
)
response
.
parse_error
=
err
.
message
.
encode
(
'utf-8'
)
rescue
Google
::
Protobuf
::
ParseError
=>
err
return
response
response
.
parse_error
=
err
.
message
.
encode
(
'utf-8'
)
return
response
end
elsif
request
.
message_type
.
eql?
(
'proto2'
)
response
.
skipped
=
"Ruby doesn't support proto2"
return
respons
else
fail
"Protobuf request doesn't have specific type"
end
end
when
:json_payload
when
:json_payload
...
...
conformance/conformance_test.cc
View file @
2ad74e16
...
@@ -35,6 +35,7 @@
...
@@ -35,6 +35,7 @@
#include "conformance.pb.h"
#include "conformance.pb.h"
#include "conformance_test.h"
#include "conformance_test.h"
#include <google/protobuf/test_messages_proto3.pb.h>
#include <google/protobuf/test_messages_proto3.pb.h>
#include <google/protobuf/test_messages_proto2.pb.h>
#include <google/protobuf/stubs/common.h>
#include <google/protobuf/stubs/common.h>
#include <google/protobuf/stubs/stringprintf.h>
#include <google/protobuf/stubs/stringprintf.h>
...
@@ -60,6 +61,7 @@ using google::protobuf::util::MessageDifferencer;
...
@@ -60,6 +61,7 @@ using google::protobuf::util::MessageDifferencer;
using
google
::
protobuf
::
util
::
NewTypeResolverForDescriptorPool
;
using
google
::
protobuf
::
util
::
NewTypeResolverForDescriptorPool
;
using
google
::
protobuf
::
util
::
Status
;
using
google
::
protobuf
::
util
::
Status
;
using
protobuf_test_messages
::
proto3
::
TestAllTypes
;
using
protobuf_test_messages
::
proto3
::
TestAllTypes
;
using
protobuf_test_messages
::
proto2
::
TestAllTypesProto2
;
using
std
::
string
;
using
std
::
string
;
namespace
{
namespace
{
...
@@ -163,8 +165,10 @@ string submsg(uint32_t fn, const string& buf) {
...
@@ -163,8 +165,10 @@ string submsg(uint32_t fn, const string& buf) {
#define UNKNOWN_FIELD 666
#define UNKNOWN_FIELD 666
const
FieldDescriptor
*
GetFieldForType
(
FieldDescriptor
::
Type
type
,
const
FieldDescriptor
*
GetFieldForType
(
FieldDescriptor
::
Type
type
,
bool
repeated
)
{
bool
repeated
,
bool
isProto3
)
{
const
Descriptor
*
d
=
TestAllTypes
().
GetDescriptor
();
const
Descriptor
*
d
=
isProto3
?
TestAllTypes
().
GetDescriptor
()
:
TestAllTypesProto2
().
GetDescriptor
();
for
(
int
i
=
0
;
i
<
d
->
field_count
();
i
++
)
{
for
(
int
i
=
0
;
i
<
d
->
field_count
();
i
++
)
{
const
FieldDescriptor
*
f
=
d
->
field
(
i
);
const
FieldDescriptor
*
f
=
d
->
field
(
i
);
if
(
f
->
type
()
==
type
&&
f
->
is_repeated
()
==
repeated
)
{
if
(
f
->
type
()
==
type
&&
f
->
is_repeated
()
==
repeated
)
{
...
@@ -271,7 +275,7 @@ void ConformanceTestSuite::RunTest(const string& test_name,
...
@@ -271,7 +275,7 @@ void ConformanceTestSuite::RunTest(const string& test_name,
void
ConformanceTestSuite
::
RunValidInputTest
(
void
ConformanceTestSuite
::
RunValidInputTest
(
const
string
&
test_name
,
ConformanceLevel
level
,
const
string
&
input
,
const
string
&
test_name
,
ConformanceLevel
level
,
const
string
&
input
,
WireFormat
input_format
,
const
string
&
equivalent_text_format
,
WireFormat
input_format
,
const
string
&
equivalent_text_format
,
WireFormat
requested_output
)
{
WireFormat
requested_output
,
bool
isProto3
)
{
TestAllTypes
reference_message
;
TestAllTypes
reference_message
;
GOOGLE_CHECK
(
GOOGLE_CHECK
(
TextFormat
::
ParseFromString
(
equivalent_text_format
,
&
reference_message
))
TextFormat
::
ParseFromString
(
equivalent_text_format
,
&
reference_message
))
...
@@ -282,9 +286,15 @@ void ConformanceTestSuite::RunValidInputTest(
...
@@ -282,9 +286,15 @@ void ConformanceTestSuite::RunValidInputTest(
ConformanceResponse
response
;
ConformanceResponse
response
;
switch
(
input_format
)
{
switch
(
input_format
)
{
case
conformance
:
:
PROTOBUF
:
case
conformance
:
:
PROTOBUF
:
{
request
.
set_protobuf_payload
(
input
);
request
.
set_protobuf_payload
(
input
);
if
(
isProto3
)
{
request
.
set_message_type
(
"proto3"
);
}
else
{
request
.
set_message_type
(
"proto2"
);
}
break
;
break
;
}
case
conformance
:
:
JSON
:
case
conformance
:
:
JSON
:
request
.
set_json_payload
(
input
);
request
.
set_json_payload
(
input
);
...
@@ -299,6 +309,7 @@ void ConformanceTestSuite::RunValidInputTest(
...
@@ -299,6 +309,7 @@ void ConformanceTestSuite::RunValidInputTest(
RunTest
(
test_name
,
request
,
&
response
);
RunTest
(
test_name
,
request
,
&
response
);
TestAllTypes
test_message
;
TestAllTypes
test_message
;
TestAllTypesProto2
test_message_proto2
;
switch
(
response
.
result_case
())
{
switch
(
response
.
result_case
())
{
case
ConformanceResponse
:
:
RESULT_NOT_SET
:
case
ConformanceResponse
:
:
RESULT_NOT_SET
:
...
@@ -334,11 +345,20 @@ void ConformanceTestSuite::RunValidInputTest(
...
@@ -334,11 +345,20 @@ void ConformanceTestSuite::RunValidInputTest(
return
;
return
;
}
}
if
(
!
test_message
.
ParseFromString
(
binary_protobuf
))
{
if
(
isProto3
)
{
ReportFailure
(
test_name
,
level
,
request
,
response
,
if
(
!
test_message
.
ParseFromString
(
binary_protobuf
))
{
ReportFailure
(
test_name
,
level
,
request
,
response
,
"INTERNAL ERROR: internal JSON->protobuf transcode "
"INTERNAL ERROR: internal JSON->protobuf transcode "
"yielded unparseable proto."
);
"yielded unparseable proto."
);
return
;
return
;
}
}
else
{
if
(
!
test_message_proto2
.
ParseFromString
(
binary_protobuf
))
{
ReportFailure
(
test_name
,
level
,
request
,
response
,
"INTERNAL ERROR: internal JSON->protobuf transcode "
"yielded unparseable proto."
);
return
;
}
}
}
break
;
break
;
...
@@ -352,10 +372,18 @@ void ConformanceTestSuite::RunValidInputTest(
...
@@ -352,10 +372,18 @@ void ConformanceTestSuite::RunValidInputTest(
return
;
return
;
}
}
if
(
!
test_message
.
ParseFromString
(
response
.
protobuf_payload
()))
{
if
(
isProto3
)
{
ReportFailure
(
test_name
,
level
,
request
,
response
,
if
(
!
test_message
.
ParseFromString
(
response
.
protobuf_payload
()))
{
"Protobuf output we received from test was unparseable."
);
ReportFailure
(
test_name
,
level
,
request
,
response
,
return
;
"Protobuf output we received from test was unparseable."
);
return
;
}
}
else
{
if
(
!
test_message_proto2
.
ParseFromString
(
response
.
protobuf_payload
()))
{
ReportFailure
(
test_name
,
level
,
request
,
response
,
"Protobuf output we received from test was unparseable."
);
return
;
}
}
}
break
;
break
;
...
@@ -384,10 +412,16 @@ void ConformanceTestSuite::RunValidInputTest(
...
@@ -384,10 +412,16 @@ void ConformanceTestSuite::RunValidInputTest(
// Expect that this precise protobuf will cause a parse error.
// Expect that this precise protobuf will cause a parse error.
void
ConformanceTestSuite
::
ExpectParseFailureForProto
(
void
ConformanceTestSuite
::
ExpectParseFailureForProto
(
const
string
&
proto
,
const
string
&
test_name
,
ConformanceLevel
level
)
{
const
string
&
proto
,
const
string
&
test_name
,
ConformanceLevel
level
,
bool
isProto3
)
{
ConformanceRequest
request
;
ConformanceRequest
request
;
ConformanceResponse
response
;
ConformanceResponse
response
;
request
.
set_protobuf_payload
(
proto
);
request
.
set_protobuf_payload
(
proto
);
if
(
isProto3
)
{
request
.
set_message_type
(
"proto3"
);
}
else
{
request
.
set_message_type
(
"proto2"
);
}
string
effective_test_name
=
ConformanceLevelToString
(
level
)
+
string
effective_test_name
=
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
;
".ProtobufInput."
+
test_name
;
...
@@ -412,8 +446,9 @@ void ConformanceTestSuite::ExpectParseFailureForProto(
...
@@ -412,8 +446,9 @@ void ConformanceTestSuite::ExpectParseFailureForProto(
//
//
// TODO(haberman): implement the second of these.
// TODO(haberman): implement the second of these.
void
ConformanceTestSuite
::
ExpectHardParseFailureForProto
(
void
ConformanceTestSuite
::
ExpectHardParseFailureForProto
(
const
string
&
proto
,
const
string
&
test_name
,
ConformanceLevel
level
)
{
const
string
&
proto
,
const
string
&
test_name
,
ConformanceLevel
level
,
return
ExpectParseFailureForProto
(
proto
,
test_name
,
level
);
bool
isProto3
)
{
return
ExpectParseFailureForProto
(
proto
,
test_name
,
level
,
isProto3
);
}
}
void
ConformanceTestSuite
::
RunValidJsonTest
(
void
ConformanceTestSuite
::
RunValidJsonTest
(
...
@@ -422,39 +457,40 @@ void ConformanceTestSuite::RunValidJsonTest(
...
@@ -422,39 +457,40 @@ void ConformanceTestSuite::RunValidJsonTest(
RunValidInputTest
(
RunValidInputTest
(
ConformanceLevelToString
(
level
)
+
".JsonInput."
+
test_name
+
ConformanceLevelToString
(
level
)
+
".JsonInput."
+
test_name
+
".ProtobufOutput"
,
level
,
input_json
,
conformance
::
JSON
,
".ProtobufOutput"
,
level
,
input_json
,
conformance
::
JSON
,
equivalent_text_format
,
conformance
::
PROTOBUF
);
equivalent_text_format
,
conformance
::
PROTOBUF
,
true
);
RunValidInputTest
(
RunValidInputTest
(
ConformanceLevelToString
(
level
)
+
".JsonInput."
+
test_name
+
ConformanceLevelToString
(
level
)
+
".JsonInput."
+
test_name
+
".JsonOutput"
,
level
,
input_json
,
conformance
::
JSON
,
".JsonOutput"
,
level
,
input_json
,
conformance
::
JSON
,
equivalent_text_format
,
conformance
::
JSON
);
equivalent_text_format
,
conformance
::
JSON
,
true
);
}
}
void
ConformanceTestSuite
::
RunValidJsonTestWithProtobufInput
(
void
ConformanceTestSuite
::
RunValidJsonTestWithProtobufInput
(
const
string
&
test_name
,
ConformanceLevel
level
,
const
TestAllTypes
&
input
,
const
string
&
test_name
,
ConformanceLevel
level
,
const
TestAllTypes
&
input
,
const
string
&
equivalent_text_format
)
{
const
string
&
equivalent_text_format
,
bool
isProto3
)
{
RunValidInputTest
(
RunValidInputTest
(
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
+
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
+
".JsonOutput"
,
level
,
input
.
SerializeAsString
(),
conformance
::
PROTOBUF
,
".JsonOutput"
,
level
,
input
.
SerializeAsString
(),
conformance
::
PROTOBUF
,
equivalent_text_format
,
conformance
::
JSON
);
equivalent_text_format
,
conformance
::
JSON
,
isProto3
);
}
}
void
ConformanceTestSuite
::
RunValidProtobufTest
(
void
ConformanceTestSuite
::
RunValidProtobufTest
(
const
string
&
test_name
,
ConformanceLevel
level
,
const
string
&
test_name
,
ConformanceLevel
level
,
const
string
&
input_protobuf
,
const
string
&
equivalent_text_format
)
{
const
string
&
input_protobuf
,
const
string
&
equivalent_text_format
,
bool
isProto3
)
{
RunValidInputTest
(
RunValidInputTest
(
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
+
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
+
".ProtobufOutput"
,
level
,
input_protobuf
,
conformance
::
PROTOBUF
,
".ProtobufOutput"
,
level
,
input_protobuf
,
conformance
::
PROTOBUF
,
equivalent_text_format
,
conformance
::
PROTOBUF
);
equivalent_text_format
,
conformance
::
PROTOBUF
,
isProto3
);
RunValidInputTest
(
RunValidInputTest
(
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
+
ConformanceLevelToString
(
level
)
+
".ProtobufInput."
+
test_name
+
".JsonOutput"
,
level
,
input_protobuf
,
conformance
::
PROTOBUF
,
".JsonOutput"
,
level
,
input_protobuf
,
conformance
::
PROTOBUF
,
equivalent_text_format
,
conformance
::
JSON
);
equivalent_text_format
,
conformance
::
JSON
,
isProto3
);
}
}
void
ConformanceTestSuite
::
RunValidProtobufTestWithMessage
(
void
ConformanceTestSuite
::
RunValidProtobufTestWithMessage
(
const
string
&
test_name
,
ConformanceLevel
level
,
const
TestAllTypes
&
input
,
const
string
&
test_name
,
ConformanceLevel
level
,
const
TestAllTypes
&
input
,
const
string
&
equivalent_text_format
)
{
const
string
&
equivalent_text_format
,
bool
isProto3
)
{
RunValidProtobufTest
(
test_name
,
level
,
input
.
SerializeAsString
(),
equivalent_text_format
);
RunValidProtobufTest
(
test_name
,
level
,
input
.
SerializeAsString
(),
equivalent_text_format
,
isProto3
);
}
}
// According to proto3 JSON specification, JSON serializers follow more strict
// According to proto3 JSON specification, JSON serializers follow more strict
...
@@ -535,6 +571,7 @@ void ConformanceTestSuite::ExpectSerializeFailureForJson(
...
@@ -535,6 +571,7 @@ void ConformanceTestSuite::ExpectSerializeFailureForJson(
ConformanceRequest
request
;
ConformanceRequest
request
;
ConformanceResponse
response
;
ConformanceResponse
response
;
request
.
set_protobuf_payload
(
payload_message
.
SerializeAsString
());
request
.
set_protobuf_payload
(
payload_message
.
SerializeAsString
());
request
.
set_message_type
(
"proto3"
);
string
effective_test_name
=
string
effective_test_name
=
ConformanceLevelToString
(
level
)
+
"."
+
test_name
+
".JsonOutput"
;
ConformanceLevelToString
(
level
)
+
"."
+
test_name
+
".JsonOutput"
;
request
.
set_requested_output_format
(
conformance
::
JSON
);
request
.
set_requested_output_format
(
conformance
::
JSON
);
...
@@ -550,6 +587,7 @@ void ConformanceTestSuite::ExpectSerializeFailureForJson(
...
@@ -550,6 +587,7 @@ void ConformanceTestSuite::ExpectSerializeFailureForJson(
}
}
}
}
//TODO: proto2?
void
ConformanceTestSuite
::
TestPrematureEOFForType
(
FieldDescriptor
::
Type
type
)
{
void
ConformanceTestSuite
::
TestPrematureEOFForType
(
FieldDescriptor
::
Type
type
)
{
// Incomplete values for each wire type.
// Incomplete values for each wire type.
static
const
string
incompletes
[
6
]
=
{
static
const
string
incompletes
[
6
]
=
{
...
@@ -561,8 +599,8 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
...
@@ -561,8 +599,8 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
string
(
"abc"
)
// 32BIT
string
(
"abc"
)
// 32BIT
};
};
const
FieldDescriptor
*
field
=
GetFieldForType
(
type
,
false
);
const
FieldDescriptor
*
field
=
GetFieldForType
(
type
,
false
,
true
);
const
FieldDescriptor
*
rep_field
=
GetFieldForType
(
type
,
true
);
const
FieldDescriptor
*
rep_field
=
GetFieldForType
(
type
,
true
,
true
);
WireFormatLite
::
WireType
wire_type
=
WireFormatLite
::
WireTypeForFieldType
(
WireFormatLite
::
WireType
wire_type
=
WireFormatLite
::
WireTypeForFieldType
(
static_cast
<
WireFormatLite
::
FieldType
>
(
type
));
static_cast
<
WireFormatLite
::
FieldType
>
(
type
));
const
string
&
incomplete
=
incompletes
[
wire_type
];
const
string
&
incomplete
=
incompletes
[
wire_type
];
...
@@ -571,43 +609,43 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
...
@@ -571,43 +609,43 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
tag
(
field
->
number
(),
wire_type
),
tag
(
field
->
number
(),
wire_type
),
"PrematureEofBeforeKnownNonRepeatedValue"
+
type_name
,
REQUIRED
);
"PrematureEofBeforeKnownNonRepeatedValue"
+
type_name
,
REQUIRED
,
true
);
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
tag
(
rep_field
->
number
(),
wire_type
),
tag
(
rep_field
->
number
(),
wire_type
),
"PrematureEofBeforeKnownRepeatedValue"
+
type_name
,
REQUIRED
);
"PrematureEofBeforeKnownRepeatedValue"
+
type_name
,
REQUIRED
,
true
);
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
tag
(
UNKNOWN_FIELD
,
wire_type
),
tag
(
UNKNOWN_FIELD
,
wire_type
),
"PrematureEofBeforeUnknownValue"
+
type_name
,
REQUIRED
);
"PrematureEofBeforeUnknownValue"
+
type_name
,
REQUIRED
,
true
);
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
field
->
number
(),
wire_type
),
incomplete
),
cat
(
tag
(
field
->
number
(),
wire_type
),
incomplete
),
"PrematureEofInsideKnownNonRepeatedValue"
+
type_name
,
REQUIRED
);
"PrematureEofInsideKnownNonRepeatedValue"
+
type_name
,
REQUIRED
,
true
);
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
rep_field
->
number
(),
wire_type
),
incomplete
),
cat
(
tag
(
rep_field
->
number
(),
wire_type
),
incomplete
),
"PrematureEofInsideKnownRepeatedValue"
+
type_name
,
REQUIRED
);
"PrematureEofInsideKnownRepeatedValue"
+
type_name
,
REQUIRED
,
true
);
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
UNKNOWN_FIELD
,
wire_type
),
incomplete
),
cat
(
tag
(
UNKNOWN_FIELD
,
wire_type
),
incomplete
),
"PrematureEofInsideUnknownValue"
+
type_name
,
REQUIRED
);
"PrematureEofInsideUnknownValue"
+
type_name
,
REQUIRED
,
true
);
if
(
wire_type
==
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
)
{
if
(
wire_type
==
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
)
{
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
field
->
number
(),
wire_type
),
varint
(
1
)
),
cat
(
tag
(
field
->
number
(),
wire_type
),
varint
(
1
)
),
"PrematureEofInDelimitedDataForKnownNonRepeatedValue"
+
type_name
,
"PrematureEofInDelimitedDataForKnownNonRepeatedValue"
+
type_name
,
REQUIRED
);
REQUIRED
,
true
);
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
rep_field
->
number
(),
wire_type
),
varint
(
1
)
),
cat
(
tag
(
rep_field
->
number
(),
wire_type
),
varint
(
1
)
),
"PrematureEofInDelimitedDataForKnownRepeatedValue"
+
type_name
,
"PrematureEofInDelimitedDataForKnownRepeatedValue"
+
type_name
,
REQUIRED
);
REQUIRED
,
true
);
// EOF in the middle of delimited data for unknown value.
// EOF in the middle of delimited data for unknown value.
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
UNKNOWN_FIELD
,
wire_type
),
varint
(
1
)
),
cat
(
tag
(
UNKNOWN_FIELD
,
wire_type
),
varint
(
1
)
),
"PrematureEofInDelimitedDataForUnknownValue"
+
type_name
,
REQUIRED
);
"PrematureEofInDelimitedDataForUnknownValue"
+
type_name
,
REQUIRED
,
true
);
if
(
type
==
FieldDescriptor
::
TYPE_MESSAGE
)
{
if
(
type
==
FieldDescriptor
::
TYPE_MESSAGE
)
{
// Submessage ends in the middle of a value.
// Submessage ends in the middle of a value.
...
@@ -618,7 +656,7 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
...
@@ -618,7 +656,7 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
cat
(
tag
(
field
->
number
(),
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
),
cat
(
tag
(
field
->
number
(),
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
),
varint
(
incomplete_submsg
.
size
()),
varint
(
incomplete_submsg
.
size
()),
incomplete_submsg
),
incomplete_submsg
),
"PrematureEofInSubmessageValue"
+
type_name
,
REQUIRED
);
"PrematureEofInSubmessageValue"
+
type_name
,
REQUIRED
,
true
);
}
}
}
else
if
(
type
!=
FieldDescriptor
::
TYPE_GROUP
)
{
}
else
if
(
type
!=
FieldDescriptor
::
TYPE_GROUP
)
{
// Non-delimited, non-group: eligible for packing.
// Non-delimited, non-group: eligible for packing.
...
@@ -627,29 +665,29 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
...
@@ -627,29 +665,29 @@ void ConformanceTestSuite::TestPrematureEOFForType(FieldDescriptor::Type type) {
ExpectHardParseFailureForProto
(
ExpectHardParseFailureForProto
(
cat
(
tag
(
rep_field
->
number
(),
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
),
cat
(
tag
(
rep_field
->
number
(),
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
),
varint
(
incomplete
.
size
()),
incomplete
),
varint
(
incomplete
.
size
()),
incomplete
),
"PrematureEofInPackedFieldValue"
+
type_name
,
REQUIRED
);
"PrematureEofInPackedFieldValue"
+
type_name
,
REQUIRED
,
true
);
// EOF in the middle of packed region.
// EOF in the middle of packed region.
ExpectParseFailureForProto
(
ExpectParseFailureForProto
(
cat
(
tag
(
rep_field
->
number
(),
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
),
cat
(
tag
(
rep_field
->
number
(),
WireFormatLite
::
WIRETYPE_LENGTH_DELIMITED
),
varint
(
1
)),
varint
(
1
)),
"PrematureEofInPackedField"
+
type_name
,
REQUIRED
);
"PrematureEofInPackedField"
+
type_name
,
REQUIRED
,
true
);
}
}
}
}
void
ConformanceTestSuite
::
TestValidDataForType
(
void
ConformanceTestSuite
::
TestValidDataForType
(
FieldDescriptor
::
Type
type
,
FieldDescriptor
::
Type
type
,
std
::
vector
<
std
::
pair
<
std
::
string
,
std
::
string
>>
values
)
{
std
::
vector
<
std
::
pair
<
std
::
string
,
std
::
string
>>
values
,
bool
isProto3
)
{
const
string
type_name
=
const
string
type_name
=
UpperCase
(
string
(
"."
)
+
FieldDescriptor
::
TypeName
(
type
));
UpperCase
(
string
(
"."
)
+
FieldDescriptor
::
TypeName
(
type
));
WireFormatLite
::
WireType
wire_type
=
WireFormatLite
::
WireTypeForFieldType
(
WireFormatLite
::
WireType
wire_type
=
WireFormatLite
::
WireTypeForFieldType
(
static_cast
<
WireFormatLite
::
FieldType
>
(
type
));
static_cast
<
WireFormatLite
::
FieldType
>
(
type
));
const
FieldDescriptor
*
field
=
GetFieldForType
(
type
,
false
);
const
FieldDescriptor
*
field
=
GetFieldForType
(
type
,
false
,
isProto3
);
const
FieldDescriptor
*
rep_field
=
GetFieldForType
(
type
,
true
);
const
FieldDescriptor
*
rep_field
=
GetFieldForType
(
type
,
true
,
isProto3
);
RunValidProtobufTest
(
"ValidDataScalar"
+
type_name
,
REQUIRED
,
RunValidProtobufTest
(
"ValidDataScalar"
+
type_name
,
REQUIRED
,
cat
(
tag
(
field
->
number
(),
wire_type
),
values
[
0
].
first
),
cat
(
tag
(
field
->
number
(),
wire_type
),
values
[
0
].
first
),
field
->
name
()
+
": "
+
values
[
0
].
second
);
field
->
name
()
+
": "
+
values
[
0
].
second
,
isProto3
);
string
proto
;
string
proto
;
string
text
=
field
->
name
()
+
": "
+
values
.
back
().
second
;
string
text
=
field
->
name
()
+
": "
+
values
.
back
().
second
;
...
@@ -657,7 +695,7 @@ void ConformanceTestSuite::TestValidDataForType(
...
@@ -657,7 +695,7 @@ void ConformanceTestSuite::TestValidDataForType(
proto
+=
cat
(
tag
(
field
->
number
(),
wire_type
),
values
[
i
].
first
);
proto
+=
cat
(
tag
(
field
->
number
(),
wire_type
),
values
[
i
].
first
);
}
}
RunValidProtobufTest
(
"RepeatedScalarSelectsLast"
+
type_name
,
REQUIRED
,
RunValidProtobufTest
(
"RepeatedScalarSelectsLast"
+
type_name
,
REQUIRED
,
proto
,
text
);
proto
,
text
,
isProto3
);
proto
.
clear
();
proto
.
clear
();
text
.
clear
();
text
.
clear
();
...
@@ -666,7 +704,7 @@ void ConformanceTestSuite::TestValidDataForType(
...
@@ -666,7 +704,7 @@ void ConformanceTestSuite::TestValidDataForType(
proto
+=
cat
(
tag
(
rep_field
->
number
(),
wire_type
),
values
[
i
].
first
);
proto
+=
cat
(
tag
(
rep_field
->
number
(),
wire_type
),
values
[
i
].
first
);
text
+=
rep_field
->
name
()
+
": "
+
values
[
i
].
second
+
" "
;
text
+=
rep_field
->
name
()
+
": "
+
values
[
i
].
second
+
" "
;
}
}
RunValidProtobufTest
(
"ValidDataRepeated"
+
type_name
,
REQUIRED
,
proto
,
text
);
RunValidProtobufTest
(
"ValidDataRepeated"
+
type_name
,
REQUIRED
,
proto
,
text
,
true
);
}
}
void
ConformanceTestSuite
::
SetFailureList
(
const
string
&
filename
,
void
ConformanceTestSuite
::
SetFailureList
(
const
string
&
filename
,
...
@@ -708,6 +746,7 @@ bool ConformanceTestSuite::CheckSetEmpty(const set<string>& set_to_check,
...
@@ -708,6 +746,7 @@ bool ConformanceTestSuite::CheckSetEmpty(const set<string>& set_to_check,
}
}
}
}
// TODO: proto2?
void
ConformanceTestSuite
::
TestIllegalTags
()
{
void
ConformanceTestSuite
::
TestIllegalTags
()
{
// field num 0 is illegal
// field num 0 is illegal
string
nullfield
[]
=
{
string
nullfield
[]
=
{
...
@@ -719,7 +758,7 @@ void ConformanceTestSuite::TestIllegalTags() {
...
@@ -719,7 +758,7 @@ void ConformanceTestSuite::TestIllegalTags() {
for
(
int
i
=
0
;
i
<
4
;
i
++
)
{
for
(
int
i
=
0
;
i
<
4
;
i
++
)
{
string
name
=
"IllegalZeroFieldNum_Case_0"
;
string
name
=
"IllegalZeroFieldNum_Case_0"
;
name
.
back
()
+=
i
;
name
.
back
()
+=
i
;
ExpectParseFailureForProto
(
nullfield
[
i
],
name
,
REQUIRED
);
ExpectParseFailureForProto
(
nullfield
[
i
],
name
,
REQUIRED
,
true
);
}
}
}
}
...
@@ -756,23 +795,23 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -756,23 +795,23 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
{
dbl
(
0.1
),
"0.1"
},
{
dbl
(
0.1
),
"0.1"
},
{
dbl
(
1.7976931348623157e+308
),
"1.7976931348623157e+308"
},
{
dbl
(
1.7976931348623157e+308
),
"1.7976931348623157e+308"
},
{
dbl
(
2.22507385850720138309e-308
),
"2.22507385850720138309e-308"
}
{
dbl
(
2.22507385850720138309e-308
),
"2.22507385850720138309e-308"
}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_FLOAT
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_FLOAT
,
{
{
flt
(
0.1
),
"0.1"
},
{
flt
(
0.1
),
"0.1"
},
{
flt
(
1.00000075e-36
),
"1.00000075e-36"
},
{
flt
(
1.00000075e-36
),
"1.00000075e-36"
},
{
flt
(
3.402823e+38
),
"3.402823e+38"
},
// 3.40282347e+38
{
flt
(
3.402823e+38
),
"3.402823e+38"
},
// 3.40282347e+38
{
flt
(
1.17549435e-38
f
),
"1.17549435e-38"
}
{
flt
(
1.17549435e-38
f
),
"1.17549435e-38"
}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_INT64
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_INT64
,
{
{
varint
(
12345
),
"12345"
},
{
varint
(
12345
),
"12345"
},
{
varint
(
kInt64Max
),
std
::
to_string
(
kInt64Max
)},
{
varint
(
kInt64Max
),
std
::
to_string
(
kInt64Max
)},
{
varint
(
kInt64Min
),
std
::
to_string
(
kInt64Min
)}
{
varint
(
kInt64Min
),
std
::
to_string
(
kInt64Min
)}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_UINT64
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_UINT64
,
{
{
varint
(
12345
),
"12345"
},
{
varint
(
12345
),
"12345"
},
{
varint
(
kUint64Max
),
std
::
to_string
(
kUint64Max
)},
{
varint
(
kUint64Max
),
std
::
to_string
(
kUint64Max
)},
{
varint
(
0
),
"0"
}
{
varint
(
0
),
"0"
}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_INT32
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_INT32
,
{
{
varint
(
12345
),
"12345"
},
{
varint
(
12345
),
"12345"
},
{
longvarint
(
12345
,
2
),
"12345"
},
{
longvarint
(
12345
,
2
),
"12345"
},
...
@@ -782,7 +821,7 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -782,7 +821,7 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
{
varint
(
1LL
<<
33
),
std
::
to_string
(
static_cast
<
int32
>
(
1LL
<<
33
))},
{
varint
(
1LL
<<
33
),
std
::
to_string
(
static_cast
<
int32
>
(
1LL
<<
33
))},
{
varint
((
1LL
<<
33
)
-
1
),
{
varint
((
1LL
<<
33
)
-
1
),
std
::
to_string
(
static_cast
<
int32
>
((
1LL
<<
33
)
-
1
))},
std
::
to_string
(
static_cast
<
int32
>
((
1LL
<<
33
)
-
1
))},
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_UINT32
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_UINT32
,
{
{
varint
(
12345
),
"12345"
},
{
varint
(
12345
),
"12345"
},
{
longvarint
(
12345
,
2
),
"12345"
},
{
longvarint
(
12345
,
2
),
"12345"
},
...
@@ -792,42 +831,42 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -792,42 +831,42 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
{
varint
(
1LL
<<
33
),
std
::
to_string
(
static_cast
<
uint32
>
(
1LL
<<
33
))},
{
varint
(
1LL
<<
33
),
std
::
to_string
(
static_cast
<
uint32
>
(
1LL
<<
33
))},
{
varint
((
1LL
<<
33
)
-
1
),
{
varint
((
1LL
<<
33
)
-
1
),
std
::
to_string
(
static_cast
<
uint32
>
((
1LL
<<
33
)
-
1
))},
std
::
to_string
(
static_cast
<
uint32
>
((
1LL
<<
33
)
-
1
))},
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_FIXED64
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_FIXED64
,
{
{
u64
(
12345
),
"12345"
},
{
u64
(
12345
),
"12345"
},
{
u64
(
kUint64Max
),
std
::
to_string
(
kUint64Max
)},
{
u64
(
kUint64Max
),
std
::
to_string
(
kUint64Max
)},
{
u64
(
0
),
"0"
}
{
u64
(
0
),
"0"
}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_FIXED32
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_FIXED32
,
{
{
u32
(
12345
),
"12345"
},
{
u32
(
12345
),
"12345"
},
{
u32
(
kUint32Max
),
std
::
to_string
(
kUint32Max
)},
// UINT32_MAX
{
u32
(
kUint32Max
),
std
::
to_string
(
kUint32Max
)},
// UINT32_MAX
{
u32
(
0
),
"0"
}
{
u32
(
0
),
"0"
}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_SFIXED64
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_SFIXED64
,
{
{
u64
(
12345
),
"12345"
},
{
u64
(
12345
),
"12345"
},
{
u64
(
kInt64Max
),
std
::
to_string
(
kInt64Max
)},
{
u64
(
kInt64Max
),
std
::
to_string
(
kInt64Max
)},
{
u64
(
kInt64Min
),
std
::
to_string
(
kInt64Min
)}
{
u64
(
kInt64Min
),
std
::
to_string
(
kInt64Min
)}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_SFIXED32
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_SFIXED32
,
{
{
u32
(
12345
),
"12345"
},
{
u32
(
12345
),
"12345"
},
{
u32
(
kInt32Max
),
std
::
to_string
(
kInt32Max
)},
{
u32
(
kInt32Max
),
std
::
to_string
(
kInt32Max
)},
{
u32
(
kInt32Min
),
std
::
to_string
(
kInt32Min
)}
{
u32
(
kInt32Min
),
std
::
to_string
(
kInt32Min
)}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_BOOL
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_BOOL
,
{
{
varint
(
1
),
"true"
},
{
varint
(
1
),
"true"
},
{
varint
(
0
),
"false"
},
{
varint
(
0
),
"false"
},
{
varint
(
12345678
),
"true"
}
{
varint
(
12345678
),
"true"
}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_SINT32
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_SINT32
,
{
{
zz32
(
12345
),
"12345"
},
{
zz32
(
12345
),
"12345"
},
{
zz32
(
kInt32Max
),
std
::
to_string
(
kInt32Max
)},
{
zz32
(
kInt32Max
),
std
::
to_string
(
kInt32Max
)},
{
zz32
(
kInt32Min
),
std
::
to_string
(
kInt32Min
)}
{
zz32
(
kInt32Min
),
std
::
to_string
(
kInt32Min
)}
});
}
,
true
);
TestValidDataForType
(
FieldDescriptor
::
TYPE_SINT64
,
{
TestValidDataForType
(
FieldDescriptor
::
TYPE_SINT64
,
{
{
zz64
(
12345
),
"12345"
},
{
zz64
(
12345
),
"12345"
},
{
zz64
(
kInt64Max
),
std
::
to_string
(
kInt64Max
)},
{
zz64
(
kInt64Max
),
std
::
to_string
(
kInt64Max
)},
{
zz64
(
kInt64Min
),
std
::
to_string
(
kInt64Min
)}
{
zz64
(
kInt64Min
),
std
::
to_string
(
kInt64Min
)}
});
}
,
true
);
// TODO(haberman):
// TODO(haberman):
// TestValidDataForType(FieldDescriptor::TYPE_STRING
// TestValidDataForType(FieldDescriptor::TYPE_STRING
...
@@ -1337,14 +1376,14 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -1337,14 +1376,14 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
WireFormatLite
::
DecodeFloat
(
0x7FA12345
));
WireFormatLite
::
DecodeFloat
(
0x7FA12345
));
RunValidJsonTestWithProtobufInput
(
RunValidJsonTestWithProtobufInput
(
"FloatFieldNormalizeQuietNan"
,
REQUIRED
,
message
,
"FloatFieldNormalizeQuietNan"
,
REQUIRED
,
message
,
"optional_float: nan"
);
"optional_float: nan"
,
true
);
// IEEE floating-point standard 64-bit signaling NaN:
// IEEE floating-point standard 64-bit signaling NaN:
// 1111 1111 1xxx xxxx xxxx xxxx xxxx xxxx
// 1111 1111 1xxx xxxx xxxx xxxx xxxx xxxx
message
.
set_optional_float
(
message
.
set_optional_float
(
WireFormatLite
::
DecodeFloat
(
0xFFB54321
));
WireFormatLite
::
DecodeFloat
(
0xFFB54321
));
RunValidJsonTestWithProtobufInput
(
RunValidJsonTestWithProtobufInput
(
"FloatFieldNormalizeSignalingNan"
,
REQUIRED
,
message
,
"FloatFieldNormalizeSignalingNan"
,
REQUIRED
,
message
,
"optional_float: nan"
);
"optional_float: nan"
,
true
);
}
}
// Special values must be quoted.
// Special values must be quoted.
...
@@ -1407,12 +1446,12 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -1407,12 +1446,12 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
WireFormatLite
::
DecodeDouble
(
0x7FFA123456789ABCLL
));
WireFormatLite
::
DecodeDouble
(
0x7FFA123456789ABCLL
));
RunValidJsonTestWithProtobufInput
(
RunValidJsonTestWithProtobufInput
(
"DoubleFieldNormalizeQuietNan"
,
REQUIRED
,
message
,
"DoubleFieldNormalizeQuietNan"
,
REQUIRED
,
message
,
"optional_double: nan"
);
"optional_double: nan"
,
true
);
message
.
set_optional_double
(
message
.
set_optional_double
(
WireFormatLite
::
DecodeDouble
(
0xFFFBCBA987654321LL
));
WireFormatLite
::
DecodeDouble
(
0xFFFBCBA987654321LL
));
RunValidJsonTestWithProtobufInput
(
RunValidJsonTestWithProtobufInput
(
"DoubleFieldNormalizeSignalingNan"
,
REQUIRED
,
message
,
"DoubleFieldNormalizeSignalingNan"
,
REQUIRED
,
message
,
"optional_double: nan"
);
"optional_double: nan"
,
true
);
}
}
// Special values must be quoted.
// Special values must be quoted.
...
@@ -1536,31 +1575,31 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
...
@@ -1536,31 +1575,31 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
TestAllTypes
message
;
TestAllTypes
message
;
message
.
set_oneof_uint32
(
0
);
message
.
set_oneof_uint32
(
0
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroUint32"
,
RECOMMENDED
,
message
,
"oneof_uint32: 0"
);
"OneofZeroUint32"
,
RECOMMENDED
,
message
,
"oneof_uint32: 0"
,
true
);
message
.
mutable_oneof_nested_message
()
->
set_a
(
0
);
message
.
mutable_oneof_nested_message
()
->
set_a
(
0
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroMessage"
,
RECOMMENDED
,
message
,
"oneof_nested_message: {}"
);
"OneofZeroMessage"
,
RECOMMENDED
,
message
,
"oneof_nested_message: {}"
,
true
);
message
.
set_oneof_string
(
""
);
message
.
set_oneof_string
(
""
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroString"
,
RECOMMENDED
,
message
,
"oneof_string:
\"\"
"
);
"OneofZeroString"
,
RECOMMENDED
,
message
,
"oneof_string:
\"\"
"
,
true
);
message
.
set_oneof_bytes
(
""
);
message
.
set_oneof_bytes
(
""
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroBytes"
,
RECOMMENDED
,
message
,
"oneof_bytes:
\"\"
"
);
"OneofZeroBytes"
,
RECOMMENDED
,
message
,
"oneof_bytes:
\"\"
"
,
true
);
message
.
set_oneof_bool
(
false
);
message
.
set_oneof_bool
(
false
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroBool"
,
RECOMMENDED
,
message
,
"oneof_bool: false"
);
"OneofZeroBool"
,
RECOMMENDED
,
message
,
"oneof_bool: false"
,
true
);
message
.
set_oneof_uint64
(
0
);
message
.
set_oneof_uint64
(
0
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroUint64"
,
RECOMMENDED
,
message
,
"oneof_uint64: 0"
);
"OneofZeroUint64"
,
RECOMMENDED
,
message
,
"oneof_uint64: 0"
,
true
);
message
.
set_oneof_float
(
0.0
f
);
message
.
set_oneof_float
(
0.0
f
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroFloat"
,
RECOMMENDED
,
message
,
"oneof_float: 0"
);
"OneofZeroFloat"
,
RECOMMENDED
,
message
,
"oneof_float: 0"
,
true
);
message
.
set_oneof_double
(
0.0
);
message
.
set_oneof_double
(
0.0
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroDouble"
,
RECOMMENDED
,
message
,
"oneof_double: 0"
);
"OneofZeroDouble"
,
RECOMMENDED
,
message
,
"oneof_double: 0"
,
true
);
message
.
set_oneof_enum
(
TestAllTypes
::
FOO
);
message
.
set_oneof_enum
(
TestAllTypes
::
FOO
);
RunValidProtobufTestWithMessage
(
RunValidProtobufTestWithMessage
(
"OneofZeroEnum"
,
RECOMMENDED
,
message
,
"oneof_enum: FOO"
);
"OneofZeroEnum"
,
RECOMMENDED
,
message
,
"oneof_enum: FOO"
,
true
);
}
}
RunValidJsonTest
(
RunValidJsonTest
(
"OneofZeroUint32"
,
RECOMMENDED
,
"OneofZeroUint32"
,
RECOMMENDED
,
...
...
conformance/conformance_test.h
View file @
2ad74e16
...
@@ -165,7 +165,8 @@ class ConformanceTestSuite {
...
@@ -165,7 +165,8 @@ class ConformanceTestSuite {
const
string
&
input
,
const
string
&
input
,
conformance
::
WireFormat
input_format
,
conformance
::
WireFormat
input_format
,
const
string
&
equivalent_text_format
,
const
string
&
equivalent_text_format
,
conformance
::
WireFormat
requested_output
);
conformance
::
WireFormat
requested_output
,
bool
isProto3
);
void
RunValidJsonTest
(
const
string
&
test_name
,
void
RunValidJsonTest
(
const
string
&
test_name
,
ConformanceLevel
level
,
ConformanceLevel
level
,
const
string
&
input_json
,
const
string
&
input_json
,
...
@@ -174,14 +175,17 @@ class ConformanceTestSuite {
...
@@ -174,14 +175,17 @@ class ConformanceTestSuite {
const
string
&
test_name
,
const
string
&
test_name
,
ConformanceLevel
level
,
ConformanceLevel
level
,
const
protobuf_test_messages
::
proto3
::
TestAllTypes
&
input
,
const
protobuf_test_messages
::
proto3
::
TestAllTypes
&
input
,
const
string
&
equivalent_text_format
);
const
string
&
equivalent_text_format
,
bool
isProto3
);
void
RunValidProtobufTest
(
const
string
&
test_name
,
ConformanceLevel
level
,
void
RunValidProtobufTest
(
const
string
&
test_name
,
ConformanceLevel
level
,
const
string
&
input_protobuf
,
const
string
&
input_protobuf
,
const
string
&
equivalent_text_format
);
const
string
&
equivalent_text_format
,
bool
isProto3
);
void
RunValidProtobufTestWithMessage
(
void
RunValidProtobufTestWithMessage
(
const
string
&
test_name
,
ConformanceLevel
level
,
const
string
&
test_name
,
ConformanceLevel
level
,
const
protobuf_test_messages
::
proto3
::
TestAllTypes
&
input
,
const
protobuf_test_messages
::
proto3
::
TestAllTypes
&
input
,
const
string
&
equivalent_text_format
);
const
string
&
equivalent_text_format
,
bool
isProto3
);
typedef
std
::
function
<
bool
(
const
Json
::
Value
&
)
>
Validator
;
typedef
std
::
function
<
bool
(
const
Json
::
Value
&
)
>
Validator
;
void
RunValidJsonTestWithValidator
(
const
string
&
test_name
,
void
RunValidJsonTestWithValidator
(
const
string
&
test_name
,
...
@@ -196,15 +200,18 @@ class ConformanceTestSuite {
...
@@ -196,15 +200,18 @@ class ConformanceTestSuite {
const
string
&
text_format
);
const
string
&
text_format
);
void
ExpectParseFailureForProto
(
const
std
::
string
&
proto
,
void
ExpectParseFailureForProto
(
const
std
::
string
&
proto
,
const
std
::
string
&
test_name
,
const
std
::
string
&
test_name
,
ConformanceLevel
level
);
ConformanceLevel
level
,
bool
isProto3
);
void
ExpectHardParseFailureForProto
(
const
std
::
string
&
proto
,
void
ExpectHardParseFailureForProto
(
const
std
::
string
&
proto
,
const
std
::
string
&
test_name
,
const
std
::
string
&
test_name
,
ConformanceLevel
level
);
ConformanceLevel
level
,
bool
isProto3
);
void
TestPrematureEOFForType
(
google
::
protobuf
::
FieldDescriptor
::
Type
type
);
void
TestPrematureEOFForType
(
google
::
protobuf
::
FieldDescriptor
::
Type
type
);
void
TestIllegalTags
();
void
TestIllegalTags
();
void
TestValidDataForType
(
void
TestValidDataForType
(
google
::
protobuf
::
FieldDescriptor
::
Type
,
google
::
protobuf
::
FieldDescriptor
::
Type
,
std
::
vector
<
std
::
pair
<
std
::
string
,
std
::
string
>>
values
);
std
::
vector
<
std
::
pair
<
std
::
string
,
std
::
string
>>
values
,
bool
isProto3
);
bool
CheckSetEmpty
(
const
set
<
string
>&
set_to_check
,
bool
CheckSetEmpty
(
const
set
<
string
>&
set_to_check
,
const
std
::
string
&
write_to_file
,
const
std
::
string
&
msg
);
const
std
::
string
&
write_to_file
,
const
std
::
string
&
msg
);
ConformanceTestRunner
*
runner_
;
ConformanceTestRunner
*
runner_
;
...
...
src/google/protobuf/test_messages_proto2.proto
View file @
2ad74e16
...
@@ -50,10 +50,10 @@ option cc_enable_arenas = true;
...
@@ -50,10 +50,10 @@ option cc_enable_arenas = true;
// submessages of this message. So for example, a fuzz test of TestAllTypes
// submessages of this message. So for example, a fuzz test of TestAllTypes
// could trigger bugs that occur in any message type in this file. We verify
// could trigger bugs that occur in any message type in this file. We verify
// this stays true in a unit test.
// this stays true in a unit test.
message
TestAllTypes
{
message
TestAllTypes
Proto2
{
message
NestedMessage
{
message
NestedMessage
{
optional
int32
a
=
1
;
optional
int32
a
=
1
;
optional
TestAllTypes
corecursive
=
2
;
optional
TestAllTypes
Proto2
corecursive
=
2
;
}
}
enum
NestedEnum
{
enum
NestedEnum
{
...
@@ -89,7 +89,7 @@ message TestAllTypes {
...
@@ -89,7 +89,7 @@ message TestAllTypes {
optional
string
optional_string_piece
=
24
[
ctype
=
STRING_PIECE
];
optional
string
optional_string_piece
=
24
[
ctype
=
STRING_PIECE
];
optional
string
optional_cord
=
25
[
ctype
=
CORD
];
optional
string
optional_cord
=
25
[
ctype
=
CORD
];
optional
TestAllTypes
recursive_message
=
27
;
optional
TestAllTypes
Proto2
recursive_message
=
27
;
// Repeated
// Repeated
repeated
int32
repeated_int32
=
31
;
repeated
int32
repeated_int32
=
31
;
...
@@ -191,6 +191,6 @@ enum ForeignEnum {
...
@@ -191,6 +191,6 @@ enum ForeignEnum {
FOREIGN_BAZ
=
2
;
FOREIGN_BAZ
=
2
;
}
}
extend
TestAllTypes
{
extend
TestAllTypes
Proto2
{
optional
int32
extension_int32
=
120
;
optional
int32
extension_int32
=
120
;
}
}
\ No newline at end of file
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