Amend the conformance tests to only use Int64/Uint64 non-wrapped values which (#1164)
can reasonably be expected to be interoperable. (The fact that not all Int64/Uint64 values *can* be exactly represented in IEEE-754 and thus interoperably amongst JSON implementations is precisely the reason for wrapping them when we serialize... it shouldn't be a surprise that we can't round-trip in unwrapped form for all values.)
This commit is contained in:
parent
6b3d120539
commit
00d5a7f099
2 changed files with 12 additions and 8 deletions
|
@ -814,18 +814,26 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
|
|||
"Uint64FieldMaxValue",
|
||||
R"({"optionalUint64": "18446744073709551615"})",
|
||||
"optional_uint64: 18446744073709551615");
|
||||
// While not the largest Int64, this is the largest
|
||||
// Int64 which can be exactly represented within an
|
||||
// IEEE-754 64-bit float, which is the expected level
|
||||
// of interoperability guarantee. Larger values may
|
||||
// work in some implementations, but should not be
|
||||
// relied upon.
|
||||
RunValidJsonTest(
|
||||
"Int64FieldMaxValueNotQuoted",
|
||||
R"({"optionalInt64": 9223372036854775807})",
|
||||
"optional_int64: 9223372036854775807");
|
||||
R"({"optionalInt64": 9223372036854774784})",
|
||||
"optional_int64: 9223372036854774784");
|
||||
RunValidJsonTest(
|
||||
"Int64FieldMinValueNotQuoted",
|
||||
R"({"optionalInt64": -9223372036854775808})",
|
||||
"optional_int64: -9223372036854775808");
|
||||
// Largest interoperable Uint64; see comment above
|
||||
// for Int64FieldMaxValueNotQuoted.
|
||||
RunValidJsonTest(
|
||||
"Uint64FieldMaxValueNotQuoted",
|
||||
R"({"optionalUint64": 18446744073709551615})",
|
||||
"optional_uint64: 18446744073709551615");
|
||||
R"({"optionalUint64": 18446744073709549568})",
|
||||
"optional_uint64: 18446744073709549568");
|
||||
// Values can be represented as JSON strings.
|
||||
RunValidJsonTest(
|
||||
"Int32FieldStringValue",
|
||||
|
|
|
@ -4,8 +4,4 @@ JsonInput.FieldNameInSnakeCase.ProtobufOutput
|
|||
JsonInput.FieldNameWithMixedCases.JsonOutput
|
||||
JsonInput.FieldNameWithMixedCases.ProtobufOutput
|
||||
JsonInput.FieldNameWithMixedCases.Validator
|
||||
JsonInput.Int64FieldMaxValueNotQuoted.JsonOutput
|
||||
JsonInput.Int64FieldMaxValueNotQuoted.ProtobufOutput
|
||||
JsonInput.OriginalProtoFieldName.JsonOutput
|
||||
JsonInput.Uint64FieldMaxValueNotQuoted.JsonOutput
|
||||
JsonInput.Uint64FieldMaxValueNotQuoted.ProtobufOutput
|
||||
|
|
Loading…
Add table
Reference in a new issue