Commit 00d5a7f0 authored by Jon Skeet's avatar Jon Skeet Committed by GitHub

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.)
parent 6b3d1205
...@@ -814,18 +814,26 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner, ...@@ -814,18 +814,26 @@ bool ConformanceTestSuite::RunSuite(ConformanceTestRunner* runner,
"Uint64FieldMaxValue", "Uint64FieldMaxValue",
R"({"optionalUint64": "18446744073709551615"})", R"({"optionalUint64": "18446744073709551615"})",
"optional_uint64: 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( RunValidJsonTest(
"Int64FieldMaxValueNotQuoted", "Int64FieldMaxValueNotQuoted",
R"({"optionalInt64": 9223372036854775807})", R"({"optionalInt64": 9223372036854774784})",
"optional_int64: 9223372036854775807"); "optional_int64: 9223372036854774784");
RunValidJsonTest( RunValidJsonTest(
"Int64FieldMinValueNotQuoted", "Int64FieldMinValueNotQuoted",
R"({"optionalInt64": -9223372036854775808})", R"({"optionalInt64": -9223372036854775808})",
"optional_int64: -9223372036854775808"); "optional_int64: -9223372036854775808");
// Largest interoperable Uint64; see comment above
// for Int64FieldMaxValueNotQuoted.
RunValidJsonTest( RunValidJsonTest(
"Uint64FieldMaxValueNotQuoted", "Uint64FieldMaxValueNotQuoted",
R"({"optionalUint64": 18446744073709551615})", R"({"optionalUint64": 18446744073709549568})",
"optional_uint64: 18446744073709551615"); "optional_uint64: 18446744073709549568");
// Values can be represented as JSON strings. // Values can be represented as JSON strings.
RunValidJsonTest( RunValidJsonTest(
"Int32FieldStringValue", "Int32FieldStringValue",
......
...@@ -4,8 +4,4 @@ JsonInput.FieldNameInSnakeCase.ProtobufOutput ...@@ -4,8 +4,4 @@ JsonInput.FieldNameInSnakeCase.ProtobufOutput
JsonInput.FieldNameWithMixedCases.JsonOutput JsonInput.FieldNameWithMixedCases.JsonOutput
JsonInput.FieldNameWithMixedCases.ProtobufOutput JsonInput.FieldNameWithMixedCases.ProtobufOutput
JsonInput.FieldNameWithMixedCases.Validator JsonInput.FieldNameWithMixedCases.Validator
JsonInput.Int64FieldMaxValueNotQuoted.JsonOutput
JsonInput.Int64FieldMaxValueNotQuoted.ProtobufOutput
JsonInput.OriginalProtoFieldName.JsonOutput JsonInput.OriginalProtoFieldName.JsonOutput
JsonInput.Uint64FieldMaxValueNotQuoted.JsonOutput
JsonInput.Uint64FieldMaxValueNotQuoted.ProtobufOutput
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment