diff options
author | Jan-Willem Maarse <maarse@google.com> | 2014-05-01 18:36:30 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-05-01 18:36:30 +0000 |
commit | 58eb8e98d17971273548930a7e8d45e69995a2c8 (patch) | |
tree | 4070a6563d0d3f3637a8f5dc6677e38da93f84ce /java/src | |
parent | ddeaf25683a5aa4d6e7ef784c7380c9332cdb3ce (diff) | |
parent | d20f0a4260763531acf5de677e4830afe0bfc53e (diff) | |
download | external_protobuf-58eb8e98d17971273548930a7e8d45e69995a2c8.zip external_protobuf-58eb8e98d17971273548930a7e8d45e69995a2c8.tar.gz external_protobuf-58eb8e98d17971273548930a7e8d45e69995a2c8.tar.bz2 |
am d20f0a42: Merge "Fix NPE when clearing an extension in nano protos"
* commit 'd20f0a4260763531acf5de677e4830afe0bfc53e':
Fix NPE when clearing an extension in nano protos
Diffstat (limited to 'java/src')
-rw-r--r-- | java/src/main/java/com/google/protobuf/nano/Extension.java | 2 | ||||
-rw-r--r-- | java/src/test/java/com/google/protobuf/NanoTest.java | 14 |
2 files changed, 15 insertions, 1 deletions
diff --git a/java/src/main/java/com/google/protobuf/nano/Extension.java b/java/src/main/java/com/google/protobuf/nano/Extension.java index 177a9cc..dfe4f87 100644 --- a/java/src/main/java/com/google/protobuf/nano/Extension.java +++ b/java/src/main/java/com/google/protobuf/nano/Extension.java @@ -268,7 +268,7 @@ public class Extension<M extends ExtendableMessageNano<M>, T> { // After deletion or no-op addition (due to 'value' being an array of empty or // null-only elements), unknownFields may be empty. Discard the ArrayList if so. - return (unknownFields.size() == 0) ? null : unknownFields; + return (unknownFields == null || unknownFields.isEmpty()) ? null : unknownFields; } protected UnknownFieldData writeData(Object value) { diff --git a/java/src/test/java/com/google/protobuf/NanoTest.java b/java/src/test/java/com/google/protobuf/NanoTest.java index 5f28647..00e2597 100644 --- a/java/src/test/java/com/google/protobuf/NanoTest.java +++ b/java/src/test/java/com/google/protobuf/NanoTest.java @@ -2910,6 +2910,20 @@ public class NanoTest extends TestCase { assertTrue(Arrays.equals(enums, message.getExtension(RepeatedExtensions.repeatedEnum))); } + public void testNullExtensions() throws Exception { + // Check that clearing the extension on an empty message is a no-op. + Extensions.ExtendableMessage message = new Extensions.ExtendableMessage(); + message.setExtension(SingularExtensions.someMessage, null); + assertEquals(0, MessageNano.toByteArray(message).length); + + // Check that the message is empty after setting and clearing an extension. + AnotherMessage another = new AnotherMessage(); + message.setExtension(SingularExtensions.someMessage, another); + assertTrue(MessageNano.toByteArray(message).length > 0); + message.setExtension(SingularExtensions.someMessage, null); + assertEquals(0, MessageNano.toByteArray(message).length); + } + public void testUnknownFields() throws Exception { // Check that we roundtrip (serialize and deserialize) unrecognized fields. AnotherMessage message = new AnotherMessage(); |