Updated upb to fix JSON conformance issues. (#3206)
* Fixed a bunch of Ruby conformance errors. * Fixed some more Ruby conformance errors in JSON.
This commit is contained in:
parent
c2fdef05cf
commit
1325588982
5 changed files with 505 additions and 592 deletions
|
@ -1233,7 +1233,7 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
|
|||
"Int32FieldNegativeWithLeadingZero", REQUIRED,
|
||||
R"({"optionalInt32": -01})");
|
||||
// String values must follow the same syntax rule. Specifically leading
|
||||
// or traling spaces are not allowed.
|
||||
// or trailing spaces are not allowed.
|
||||
ExpectParseFailureForJson(
|
||||
"Int32FieldLeadingSpace", REQUIRED,
|
||||
R"({"optionalInt32": " 1"})");
|
||||
|
|
|
@ -1,21 +1,14 @@
|
|||
Recommended.FieldMaskNumbersDontRoundTrip.JsonOutput
|
||||
Recommended.FieldMaskPathsDontRoundTrip.JsonOutput
|
||||
Recommended.FieldMaskTooManyUnderscore.JsonOutput
|
||||
Recommended.JsonInput.BoolFieldIntegerOne
|
||||
Recommended.JsonInput.BoolFieldIntegerZero
|
||||
Recommended.JsonInput.DurationHas3FractionalDigits.Validator
|
||||
Recommended.JsonInput.DurationHas6FractionalDigits.Validator
|
||||
Recommended.JsonInput.DurationHas9FractionalDigits.Validator
|
||||
Recommended.JsonInput.DurationHasZeroFractionalDigit.Validator
|
||||
Recommended.JsonInput.Int64FieldBeString.Validator
|
||||
Recommended.JsonInput.OneofZeroDouble.JsonOutput
|
||||
Recommended.JsonInput.OneofZeroDouble.ProtobufOutput
|
||||
Recommended.JsonInput.OneofZeroFloat.JsonOutput
|
||||
Recommended.JsonInput.OneofZeroFloat.ProtobufOutput
|
||||
Recommended.JsonInput.OneofZeroUint32.JsonOutput
|
||||
Recommended.JsonInput.OneofZeroUint32.ProtobufOutput
|
||||
Recommended.JsonInput.OneofZeroUint64.JsonOutput
|
||||
Recommended.JsonInput.OneofZeroUint64.ProtobufOutput
|
||||
Recommended.JsonInput.MapFieldValueIsNull
|
||||
Recommended.JsonInput.RepeatedFieldMessageElementIsNull
|
||||
Recommended.JsonInput.RepeatedFieldPrimitiveElementIsNull
|
||||
Recommended.JsonInput.StringEndsWithEscapeChar
|
||||
Recommended.JsonInput.StringFieldSurrogateInWrongOrder
|
||||
Recommended.JsonInput.StringFieldUnpairedHighSurrogate
|
||||
|
@ -48,75 +41,25 @@ Required.JsonInput.AnyWithValueForInteger.JsonOutput
|
|||
Required.JsonInput.AnyWithValueForInteger.ProtobufOutput
|
||||
Required.JsonInput.AnyWithValueForJsonObject.JsonOutput
|
||||
Required.JsonInput.AnyWithValueForJsonObject.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldInfinity.JsonOutput
|
||||
Required.JsonInput.DoubleFieldInfinity.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldMaxNegativeValue.JsonOutput
|
||||
Required.JsonInput.DoubleFieldMaxNegativeValue.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldMaxPositiveValue.JsonOutput
|
||||
Required.JsonInput.DoubleFieldMaxPositiveValue.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldMinNegativeValue.JsonOutput
|
||||
Required.JsonInput.DoubleFieldMinNegativeValue.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldMinPositiveValue.JsonOutput
|
||||
Required.JsonInput.DoubleFieldMinPositiveValue.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldNan.JsonOutput
|
||||
Required.JsonInput.DoubleFieldNan.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldNegativeInfinity.JsonOutput
|
||||
Required.JsonInput.DoubleFieldNegativeInfinity.ProtobufOutput
|
||||
Required.JsonInput.DoubleFieldQuotedValue.JsonOutput
|
||||
Required.JsonInput.DoubleFieldQuotedValue.ProtobufOutput
|
||||
Required.JsonInput.DurationMaxValue.JsonOutput
|
||||
Required.JsonInput.DurationMaxValue.ProtobufOutput
|
||||
Required.JsonInput.DurationMinValue.JsonOutput
|
||||
Required.JsonInput.DurationMinValue.ProtobufOutput
|
||||
Required.JsonInput.DurationRepeatedValue.JsonOutput
|
||||
Required.JsonInput.DurationRepeatedValue.ProtobufOutput
|
||||
Required.JsonInput.EnumFieldNumericValueNonZero.JsonOutput
|
||||
Required.JsonInput.EnumFieldNumericValueNonZero.ProtobufOutput
|
||||
Required.JsonInput.EnumFieldNumericValueZero.JsonOutput
|
||||
Required.JsonInput.EnumFieldNumericValueZero.ProtobufOutput
|
||||
Required.JsonInput.EnumFieldUnknownValue.Validator
|
||||
Required.JsonInput.FieldMask.JsonOutput
|
||||
Required.JsonInput.FieldMask.ProtobufOutput
|
||||
Required.JsonInput.FloatFieldInfinity.JsonOutput
|
||||
Required.JsonInput.FloatFieldInfinity.ProtobufOutput
|
||||
Required.JsonInput.FloatFieldNan.JsonOutput
|
||||
Required.JsonInput.FloatFieldNan.ProtobufOutput
|
||||
Required.JsonInput.FloatFieldNegativeInfinity.JsonOutput
|
||||
Required.JsonInput.FloatFieldNegativeInfinity.ProtobufOutput
|
||||
Required.JsonInput.FloatFieldQuotedValue.JsonOutput
|
||||
Required.JsonInput.FloatFieldQuotedValue.ProtobufOutput
|
||||
Required.JsonInput.FloatFieldTooLarge
|
||||
Required.JsonInput.FloatFieldTooSmall
|
||||
Required.JsonInput.Int32FieldExponentialFormat.JsonOutput
|
||||
Required.JsonInput.Int32FieldExponentialFormat.ProtobufOutput
|
||||
Required.JsonInput.Int32FieldFloatTrailingZero.JsonOutput
|
||||
Required.JsonInput.Int32FieldFloatTrailingZero.ProtobufOutput
|
||||
Required.JsonInput.Int32FieldMaxFloatValue.JsonOutput
|
||||
Required.JsonInput.Int32FieldMaxFloatValue.ProtobufOutput
|
||||
Required.JsonInput.Int32FieldMinFloatValue.JsonOutput
|
||||
Required.JsonInput.Int32FieldMinFloatValue.ProtobufOutput
|
||||
Required.JsonInput.Int32FieldStringValue.JsonOutput
|
||||
Required.JsonInput.Int32FieldStringValue.ProtobufOutput
|
||||
Required.JsonInput.Int32FieldStringValueEscaped.JsonOutput
|
||||
Required.JsonInput.Int32FieldStringValueEscaped.ProtobufOutput
|
||||
Required.JsonInput.Int32MapEscapedKey.JsonOutput
|
||||
Required.JsonInput.Int32MapEscapedKey.ProtobufOutput
|
||||
Required.JsonInput.Int32MapField.JsonOutput
|
||||
Required.JsonInput.Int32MapField.ProtobufOutput
|
||||
Required.JsonInput.Int64FieldMaxValue.JsonOutput
|
||||
Required.JsonInput.Int64FieldMaxValue.ProtobufOutput
|
||||
Required.JsonInput.Int64FieldMinValue.JsonOutput
|
||||
Required.JsonInput.Int64FieldMinValue.ProtobufOutput
|
||||
Required.JsonInput.Int64MapEscapedKey.JsonOutput
|
||||
Required.JsonInput.Int64MapEscapedKey.ProtobufOutput
|
||||
Required.JsonInput.Int64MapField.JsonOutput
|
||||
Required.JsonInput.Int64MapField.ProtobufOutput
|
||||
Required.JsonInput.MessageField.JsonOutput
|
||||
Required.JsonInput.MessageField.ProtobufOutput
|
||||
Required.JsonInput.MessageMapField.JsonOutput
|
||||
Required.JsonInput.MessageMapField.ProtobufOutput
|
||||
Required.JsonInput.MessageRepeatedField.JsonOutput
|
||||
Required.JsonInput.MessageRepeatedField.ProtobufOutput
|
||||
Required.JsonInput.OneofFieldDuplicate
|
||||
Required.JsonInput.OptionalBoolWrapper.JsonOutput
|
||||
Required.JsonInput.OptionalBoolWrapper.ProtobufOutput
|
||||
Required.JsonInput.OptionalBytesWrapper.JsonOutput
|
||||
|
@ -137,15 +80,12 @@ Required.JsonInput.OptionalUint64Wrapper.JsonOutput
|
|||
Required.JsonInput.OptionalUint64Wrapper.ProtobufOutput
|
||||
Required.JsonInput.OptionalWrapperTypesWithNonDefaultValue.JsonOutput
|
||||
Required.JsonInput.OptionalWrapperTypesWithNonDefaultValue.ProtobufOutput
|
||||
Required.JsonInput.PrimitiveRepeatedField.JsonOutput
|
||||
Required.JsonInput.PrimitiveRepeatedField.ProtobufOutput
|
||||
Required.JsonInput.RepeatedBoolWrapper.JsonOutput
|
||||
Required.JsonInput.RepeatedBoolWrapper.ProtobufOutput
|
||||
Required.JsonInput.RepeatedBytesWrapper.JsonOutput
|
||||
Required.JsonInput.RepeatedBytesWrapper.ProtobufOutput
|
||||
Required.JsonInput.RepeatedDoubleWrapper.JsonOutput
|
||||
Required.JsonInput.RepeatedDoubleWrapper.ProtobufOutput
|
||||
Required.JsonInput.RepeatedFieldWrongElementTypeExpectingStringsGotInt
|
||||
Required.JsonInput.RepeatedFloatWrapper.JsonOutput
|
||||
Required.JsonInput.RepeatedFloatWrapper.ProtobufOutput
|
||||
Required.JsonInput.RepeatedInt32Wrapper.JsonOutput
|
||||
|
@ -158,7 +98,6 @@ Required.JsonInput.RepeatedUint32Wrapper.JsonOutput
|
|||
Required.JsonInput.RepeatedUint32Wrapper.ProtobufOutput
|
||||
Required.JsonInput.RepeatedUint64Wrapper.JsonOutput
|
||||
Required.JsonInput.RepeatedUint64Wrapper.ProtobufOutput
|
||||
Required.JsonInput.StringFieldNotAString
|
||||
Required.JsonInput.StringFieldSurrogatePair.JsonOutput
|
||||
Required.JsonInput.StringFieldSurrogatePair.ProtobufOutput
|
||||
Required.JsonInput.Struct.JsonOutput
|
||||
|
@ -173,14 +112,6 @@ Required.JsonInput.TimestampWithNegativeOffset.JsonOutput
|
|||
Required.JsonInput.TimestampWithNegativeOffset.ProtobufOutput
|
||||
Required.JsonInput.TimestampWithPositiveOffset.JsonOutput
|
||||
Required.JsonInput.TimestampWithPositiveOffset.ProtobufOutput
|
||||
Required.JsonInput.Uint32FieldMaxFloatValue.JsonOutput
|
||||
Required.JsonInput.Uint32FieldMaxFloatValue.ProtobufOutput
|
||||
Required.JsonInput.Uint32MapField.JsonOutput
|
||||
Required.JsonInput.Uint32MapField.ProtobufOutput
|
||||
Required.JsonInput.Uint64FieldMaxValue.JsonOutput
|
||||
Required.JsonInput.Uint64FieldMaxValue.ProtobufOutput
|
||||
Required.JsonInput.Uint64MapField.JsonOutput
|
||||
Required.JsonInput.Uint64MapField.ProtobufOutput
|
||||
Required.JsonInput.ValueAcceptBool.JsonOutput
|
||||
Required.JsonInput.ValueAcceptBool.ProtobufOutput
|
||||
Required.JsonInput.ValueAcceptFloat.JsonOutput
|
||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -2966,6 +2966,17 @@ class upb::FileDef {
|
|||
const char* package() const;
|
||||
bool set_package(const char* package, Status* s);
|
||||
|
||||
/* Sets the php class prefix which is prepended to all php generated classes
|
||||
* from this .proto. Default is empty. */
|
||||
const char* phpprefix() const;
|
||||
bool set_phpprefix(const char* phpprefix, Status* s);
|
||||
|
||||
/* Use this option to change the namespace of php generated classes. Default
|
||||
* is empty. When this option is empty, the package name will be used for
|
||||
* determining the namespace. */
|
||||
const char* phpnamespace() const;
|
||||
bool set_phpnamespace(const char* phpnamespace, Status* s);
|
||||
|
||||
/* Syntax for the file. Defaults to proto2. */
|
||||
upb_syntax_t syntax() const;
|
||||
void set_syntax(upb_syntax_t syntax);
|
||||
|
@ -3019,6 +3030,8 @@ UPB_REFCOUNTED_CMETHODS(upb_filedef, upb_filedef_upcast)
|
|||
|
||||
const char *upb_filedef_name(const upb_filedef *f);
|
||||
const char *upb_filedef_package(const upb_filedef *f);
|
||||
const char *upb_filedef_phpprefix(const upb_filedef *f);
|
||||
const char *upb_filedef_phpnamespace(const upb_filedef *f);
|
||||
upb_syntax_t upb_filedef_syntax(const upb_filedef *f);
|
||||
size_t upb_filedef_defcount(const upb_filedef *f);
|
||||
size_t upb_filedef_depcount(const upb_filedef *f);
|
||||
|
@ -3028,6 +3041,10 @@ const upb_filedef *upb_filedef_dep(const upb_filedef *f, size_t i);
|
|||
bool upb_filedef_freeze(upb_filedef *f, upb_status *s);
|
||||
bool upb_filedef_setname(upb_filedef *f, const char *name, upb_status *s);
|
||||
bool upb_filedef_setpackage(upb_filedef *f, const char *package, upb_status *s);
|
||||
bool upb_filedef_setphpprefix(upb_filedef *f, const char *phpprefix,
|
||||
upb_status *s);
|
||||
bool upb_filedef_setphpnamespace(upb_filedef *f, const char *phpnamespace,
|
||||
upb_status *s);
|
||||
bool upb_filedef_setsyntax(upb_filedef *f, upb_syntax_t syntax, upb_status *s);
|
||||
|
||||
bool upb_filedef_adddef(upb_filedef *f, upb_def *def, const void *ref_donor,
|
||||
|
@ -3786,6 +3803,18 @@ inline const char* FileDef::package() const {
|
|||
inline bool FileDef::set_package(const char* package, Status* s) {
|
||||
return upb_filedef_setpackage(this, package, s);
|
||||
}
|
||||
inline const char* FileDef::phpprefix() const {
|
||||
return upb_filedef_phpprefix(this);
|
||||
}
|
||||
inline bool FileDef::set_phpprefix(const char* phpprefix, Status* s) {
|
||||
return upb_filedef_setphpprefix(this, phpprefix, s);
|
||||
}
|
||||
inline const char* FileDef::phpnamespace() const {
|
||||
return upb_filedef_phpnamespace(this);
|
||||
}
|
||||
inline bool FileDef::set_phpnamespace(const char* phpnamespace, Status* s) {
|
||||
return upb_filedef_setphpnamespace(this, phpnamespace, s);
|
||||
}
|
||||
inline int FileDef::def_count() const {
|
||||
return upb_filedef_defcount(this);
|
||||
}
|
||||
|
@ -4000,6 +4029,8 @@ struct upb_filedef {
|
|||
|
||||
const char *name;
|
||||
const char *package;
|
||||
const char *phpprefix;
|
||||
const char *phpnamespace;
|
||||
upb_syntax_t syntax;
|
||||
|
||||
upb_inttable defs;
|
||||
|
@ -7206,6 +7237,8 @@ UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_java_string
|
|||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_javanano_use_deprecated_package(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 38); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_objc_class_prefix(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 36); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_optimize_for(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 9); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_php_class_prefix(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 40); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_php_namespace(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 41); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_py_generic_services(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 18); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_FileOptions_f_uninterpreted_option(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_FileOptions_is(m)); return upb_msgdef_itof(m, 999); }
|
||||
UPB_INLINE const upb_fielddef *upbdefs_google_protobuf_MessageOptions_f_deprecated(const upb_msgdef *m) { UPB_ASSERT(upbdefs_google_protobuf_MessageOptions_is(m)); return upb_msgdef_itof(m, 3); }
|
||||
|
@ -8304,16 +8337,8 @@ UPB_INLINE upb_decoderet upb_decoderet_make(const char *p, uint64_t val) {
|
|||
return ret;
|
||||
}
|
||||
|
||||
/* Four functions for decoding a varint of at most eight bytes. They are all
|
||||
* functionally identical, but are implemented in different ways and likely have
|
||||
* different performance profiles. We keep them around for performance testing.
|
||||
*
|
||||
* Note that these functions may not read byte-by-byte, so they must not be used
|
||||
* unless there are at least eight bytes left in the buffer! */
|
||||
upb_decoderet upb_vdecode_max8_branch32(upb_decoderet r);
|
||||
upb_decoderet upb_vdecode_max8_branch64(upb_decoderet r);
|
||||
upb_decoderet upb_vdecode_max8_wright(upb_decoderet r);
|
||||
upb_decoderet upb_vdecode_max8_massimino(upb_decoderet r);
|
||||
|
||||
/* Template for a function that checks the first two bytes with branching
|
||||
* and dispatches 2-10 bytes with a separate function. Note that this may read
|
||||
|
@ -8338,8 +8363,6 @@ UPB_INLINE upb_decoderet upb_vdecode_check2_ ## name(const char *_p) { \
|
|||
|
||||
UPB_VARINT_DECODER_CHECK2(branch32, upb_vdecode_max8_branch32)
|
||||
UPB_VARINT_DECODER_CHECK2(branch64, upb_vdecode_max8_branch64)
|
||||
UPB_VARINT_DECODER_CHECK2(wright, upb_vdecode_max8_wright)
|
||||
UPB_VARINT_DECODER_CHECK2(massimino, upb_vdecode_max8_massimino)
|
||||
#undef UPB_VARINT_DECODER_CHECK2
|
||||
|
||||
/* Our canonical functions for decoding varints, based on the currently
|
||||
|
@ -8351,10 +8374,6 @@ UPB_INLINE upb_decoderet upb_vdecode_fast(const char *p) {
|
|||
return upb_vdecode_check2_branch32(p);
|
||||
}
|
||||
|
||||
UPB_INLINE upb_decoderet upb_vdecode_max8_fast(upb_decoderet r) {
|
||||
return upb_vdecode_max8_massimino(r);
|
||||
}
|
||||
|
||||
|
||||
/* Encoding *******************************************************************/
|
||||
|
||||
|
|
|
@ -1174,6 +1174,8 @@ module BasicTest
|
|||
|
||||
json_text = TestMessage.encode_json(m)
|
||||
m2 = TestMessage.decode_json(json_text)
|
||||
puts m.inspect
|
||||
puts m2.inspect
|
||||
assert m == m2
|
||||
|
||||
# Crash case from GitHub issue 283.
|
||||
|
|
Loading…
Add table
Reference in a new issue