aboutsummaryrefslogtreecommitdiffstats
path: root/java/src
diff options
context:
space:
mode:
authorJan-Willem Maarse <maarse@google.com>2014-05-01 18:36:30 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2014-05-01 18:36:30 +0000
commit58eb8e98d17971273548930a7e8d45e69995a2c8 (patch)
tree4070a6563d0d3f3637a8f5dc6677e38da93f84ce /java/src
parentddeaf25683a5aa4d6e7ef784c7380c9332cdb3ce (diff)
parentd20f0a4260763531acf5de677e4830afe0bfc53e (diff)
downloadexternal_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.java2
-rw-r--r--java/src/test/java/com/google/protobuf/NanoTest.java14
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();