Test keys and values cannot be null.
This commit is contained in:
parent
0d52964597
commit
ca35a80303
1 changed files with 23 additions and 1 deletions
|
@ -3742,11 +3742,33 @@ public class NanoTest extends TestCase {
|
|||
byte[] output = MessageNano.toByteArray(origin);
|
||||
TestMap parsed = new TestMap();
|
||||
MessageNano.mergeFrom(parsed, output);
|
||||
// TODO(liujisi): Test null values in serialization.
|
||||
// TODO(liujisi): Test merging message type values.
|
||||
// TODO(liujisi): Test missing key/value in parsing.
|
||||
}
|
||||
|
||||
public void testMapSerializeRejectNull() throws Exception {
|
||||
TestMap primitiveMap = new TestMap();
|
||||
primitiveMap.int32ToInt32Field = new HashMap<Integer, Integer>();
|
||||
primitiveMap.int32ToInt32Field.put(null, 1);
|
||||
try {
|
||||
MessageNano.toByteArray(primitiveMap);
|
||||
fail("should reject null keys");
|
||||
} catch (IllegalStateException e) {
|
||||
// pass.
|
||||
}
|
||||
|
||||
TestMap messageMap = new TestMap();
|
||||
messageMap.int32ToMessageField =
|
||||
new HashMap<Integer, MapTestProto.TestMap.MessageValue>();
|
||||
messageMap.int32ToMessageField.put(0, null);
|
||||
try {
|
||||
MessageNano.toByteArray(messageMap);
|
||||
fail("should reject null values");
|
||||
} catch (IllegalStateException e) {
|
||||
// pass.
|
||||
}
|
||||
}
|
||||
|
||||
private static final Integer[] int32Values = new Integer[] {
|
||||
0, 1, -1, Integer.MAX_VALUE, Integer.MIN_VALUE,
|
||||
};
|
||||
|
|
Loading…
Add table
Reference in a new issue