|
@@ -71,18 +71,18 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Uint64Field = 4
|
|
Uint64Field = 4
|
|
};
|
|
};
|
|
|
|
|
|
- var bytes = message.ToByteArray();
|
|
|
|
- var parsed = TestWellKnownTypes.Parser.ParseFrom(bytes);
|
|
|
|
-
|
|
|
|
- Assert.AreEqual("x", parsed.StringField);
|
|
|
|
- Assert.AreEqual(ByteString.CopyFrom(1, 2, 3), parsed.BytesField);
|
|
|
|
- Assert.AreEqual(true, parsed.BoolField);
|
|
|
|
- Assert.AreEqual(12.5f, parsed.FloatField);
|
|
|
|
- Assert.AreEqual(12.25d, parsed.DoubleField);
|
|
|
|
- Assert.AreEqual(1, parsed.Int32Field);
|
|
|
|
- Assert.AreEqual(2L, parsed.Int64Field);
|
|
|
|
- Assert.AreEqual(3U, parsed.Uint32Field);
|
|
|
|
- Assert.AreEqual(4UL, parsed.Uint64Field);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertRoundtrip(TestWellKnownTypes.Parser, message, parsed =>
|
|
|
|
+ {
|
|
|
|
+ Assert.AreEqual("x", parsed.StringField);
|
|
|
|
+ Assert.AreEqual(ByteString.CopyFrom(1, 2, 3), parsed.BytesField);
|
|
|
|
+ Assert.AreEqual(true, parsed.BoolField);
|
|
|
|
+ Assert.AreEqual(12.5f, parsed.FloatField);
|
|
|
|
+ Assert.AreEqual(12.25d, parsed.DoubleField);
|
|
|
|
+ Assert.AreEqual(1, parsed.Int32Field);
|
|
|
|
+ Assert.AreEqual(2L, parsed.Int64Field);
|
|
|
|
+ Assert.AreEqual(3U, parsed.Uint32Field);
|
|
|
|
+ Assert.AreEqual(4UL, parsed.Uint64Field);
|
|
|
|
+ });
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -101,18 +101,18 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Uint64Field = 0
|
|
Uint64Field = 0
|
|
};
|
|
};
|
|
|
|
|
|
- var bytes = message.ToByteArray();
|
|
|
|
- var parsed = TestWellKnownTypes.Parser.ParseFrom(bytes);
|
|
|
|
-
|
|
|
|
- Assert.AreEqual("", parsed.StringField);
|
|
|
|
- Assert.AreEqual(ByteString.Empty, parsed.BytesField);
|
|
|
|
- Assert.AreEqual(false, parsed.BoolField);
|
|
|
|
- Assert.AreEqual(0f, parsed.FloatField);
|
|
|
|
- Assert.AreEqual(0d, parsed.DoubleField);
|
|
|
|
- Assert.AreEqual(0, parsed.Int32Field);
|
|
|
|
- Assert.AreEqual(0L, parsed.Int64Field);
|
|
|
|
- Assert.AreEqual(0U, parsed.Uint32Field);
|
|
|
|
- Assert.AreEqual(0UL, parsed.Uint64Field);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertRoundtrip(TestWellKnownTypes.Parser, message, parsed =>
|
|
|
|
+ {
|
|
|
|
+ Assert.AreEqual("", parsed.StringField);
|
|
|
|
+ Assert.AreEqual(ByteString.Empty, parsed.BytesField);
|
|
|
|
+ Assert.AreEqual(false, parsed.BoolField);
|
|
|
|
+ Assert.AreEqual(0f, parsed.FloatField);
|
|
|
|
+ Assert.AreEqual(0d, parsed.DoubleField);
|
|
|
|
+ Assert.AreEqual(0, parsed.Int32Field);
|
|
|
|
+ Assert.AreEqual(0L, parsed.Int64Field);
|
|
|
|
+ Assert.AreEqual(0U, parsed.Uint32Field);
|
|
|
|
+ Assert.AreEqual(0UL, parsed.Uint64Field);
|
|
|
|
+ });
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -140,12 +140,11 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Uint32Field = { uint.MaxValue, uint.MinValue, 0U },
|
|
Uint32Field = { uint.MaxValue, uint.MinValue, 0U },
|
|
Uint64Field = { ulong.MaxValue, ulong.MinValue, 0UL },
|
|
Uint64Field = { ulong.MaxValue, ulong.MinValue, 0UL },
|
|
};
|
|
};
|
|
- var bytes = message.ToByteArray();
|
|
|
|
- var parsed = RepeatedWellKnownTypes.Parser.ParseFrom(bytes);
|
|
|
|
|
|
|
|
- Assert.AreEqual(message, parsed);
|
|
|
|
// Just to test a single value for sanity...
|
|
// Just to test a single value for sanity...
|
|
Assert.AreEqual("Second", message.StringField[1]);
|
|
Assert.AreEqual("Second", message.StringField[1]);
|
|
|
|
+
|
|
|
|
+ MessageParsingHelpers.AssertRoundtrip(RepeatedWellKnownTypes.Parser, message);
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -194,12 +193,10 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Uint64Field = { { 18, ulong.MaxValue }, { 19, ulong.MinValue }, { 20, 0UL } },
|
|
Uint64Field = { { 18, ulong.MaxValue }, { 19, ulong.MinValue }, { 20, 0UL } },
|
|
};
|
|
};
|
|
|
|
|
|
- var bytes = message.ToByteArray();
|
|
|
|
- var parsed = MapWellKnownTypes.Parser.ParseFrom(bytes);
|
|
|
|
-
|
|
|
|
- Assert.AreEqual(message, parsed);
|
|
|
|
// Just to test a single value for sanity...
|
|
// Just to test a single value for sanity...
|
|
Assert.AreEqual("Second", message.StringField[12]);
|
|
Assert.AreEqual("Second", message.StringField[12]);
|
|
|
|
+
|
|
|
|
+ MessageParsingHelpers.AssertRoundtrip(MapWellKnownTypes.Parser, message);
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -288,10 +285,10 @@ namespace Google.Protobuf.WellKnownTypes
|
|
private void AssertOneofRoundTrip(OneofWellKnownTypes message)
|
|
private void AssertOneofRoundTrip(OneofWellKnownTypes message)
|
|
{
|
|
{
|
|
// Normal roundtrip, but explicitly checking the case...
|
|
// Normal roundtrip, but explicitly checking the case...
|
|
- var bytes = message.ToByteArray();
|
|
|
|
- var parsed = OneofWellKnownTypes.Parser.ParseFrom(bytes);
|
|
|
|
- Assert.AreEqual(message, parsed);
|
|
|
|
- Assert.AreEqual(message.OneofFieldCase, parsed.OneofFieldCase);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertRoundtrip(OneofWellKnownTypes.Parser, message, parsed =>
|
|
|
|
+ {
|
|
|
|
+ Assert.AreEqual(message.OneofFieldCase, parsed.OneofFieldCase);
|
|
|
|
+ });
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -406,8 +403,10 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Assert.AreEqual(8, stream.Length); // tag (1 byte) + length (1 byte) + message (6 bytes)
|
|
Assert.AreEqual(8, stream.Length); // tag (1 byte) + length (1 byte) + message (6 bytes)
|
|
stream.Position = 0;
|
|
stream.Position = 0;
|
|
|
|
|
|
- var message = TestWellKnownTypes.Parser.ParseFrom(stream);
|
|
|
|
- Assert.AreEqual(65536, message.Int32Field);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertReadingMessage(
|
|
|
|
+ TestWellKnownTypes.Parser,
|
|
|
|
+ stream.ToArray(),
|
|
|
|
+ message => Assert.AreEqual(65536, message.Int32Field));
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -431,8 +430,10 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Assert.Less(stream.Length, 8); // tag (1 byte) + length (1 byte) + message
|
|
Assert.Less(stream.Length, 8); // tag (1 byte) + length (1 byte) + message
|
|
stream.Position = 0;
|
|
stream.Position = 0;
|
|
|
|
|
|
- var message = TestWellKnownTypes.Parser.ParseFrom(stream);
|
|
|
|
- Assert.AreEqual(6, message.Int32Field);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertReadingMessage(
|
|
|
|
+ TestWellKnownTypes.Parser,
|
|
|
|
+ stream.ToArray(),
|
|
|
|
+ message => Assert.AreEqual(6, message.Int32Field));
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -456,8 +457,10 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Assert.AreEqual(13, stream.Length); // tag (1 byte) + length (1 byte) + message (11 bytes)
|
|
Assert.AreEqual(13, stream.Length); // tag (1 byte) + length (1 byte) + message (11 bytes)
|
|
stream.Position = 0;
|
|
stream.Position = 0;
|
|
|
|
|
|
- var message = TestWellKnownTypes.Parser.ParseFrom(stream);
|
|
|
|
- Assert.AreEqual(0xfffffffffffffL, message.Int64Field);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertReadingMessage(
|
|
|
|
+ TestWellKnownTypes.Parser,
|
|
|
|
+ stream.ToArray(),
|
|
|
|
+ message => Assert.AreEqual(0xfffffffffffffL, message.Int64Field));
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|
|
@@ -481,8 +484,10 @@ namespace Google.Protobuf.WellKnownTypes
|
|
Assert.Less(stream.Length, 12); // tag (1 byte) + length (1 byte) + message
|
|
Assert.Less(stream.Length, 12); // tag (1 byte) + length (1 byte) + message
|
|
stream.Position = 0;
|
|
stream.Position = 0;
|
|
|
|
|
|
- var message = TestWellKnownTypes.Parser.ParseFrom(stream);
|
|
|
|
- Assert.AreEqual(6L, message.Int64Field);
|
|
|
|
|
|
+ MessageParsingHelpers.AssertReadingMessage(
|
|
|
|
+ TestWellKnownTypes.Parser,
|
|
|
|
+ stream.ToArray(),
|
|
|
|
+ message => Assert.AreEqual(6L, message.Int64Field));
|
|
}
|
|
}
|
|
|
|
|
|
[Test]
|
|
[Test]
|