From fdaa6b05c4b418b567d33041c07f9d14b8e45dfe Mon Sep 17 00:00:00 2001 From: Inderjeet Singh Date: Wed, 10 Dec 2014 22:57:08 +0000 Subject: [PATCH] ensuring that the type field is written by runtime type adapter --- .../functional/RuntimeTypeAdapterFactoryFunctionalTest.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/gson/src/test/java/com/google/gson/functional/RuntimeTypeAdapterFactoryFunctionalTest.java b/gson/src/test/java/com/google/gson/functional/RuntimeTypeAdapterFactoryFunctionalTest.java index d525063bf3..c3b0898d55 100644 --- a/gson/src/test/java/com/google/gson/functional/RuntimeTypeAdapterFactoryFunctionalTest.java +++ b/gson/src/test/java/com/google/gson/functional/RuntimeTypeAdapterFactoryFunctionalTest.java @@ -55,6 +55,7 @@ public void testSubclassesAutomaticallySerialzed() throws Exception { json = gson.toJson(shape); shape = gson.fromJson(json, Shape.class); assertEquals(15, ((Square)shape).side); + assertEquals(ShapeType.SQUARE, shape.type); } @JsonAdapter(Shape.JsonAdapterFactory.class) @@ -163,7 +164,7 @@ public TypeAdapter create(Gson gson, TypeToken type) { return new TypeAdapter() { @Override public R read(JsonReader in) throws IOException { JsonElement jsonElement = Streams.parse(in); - JsonElement labelJsonElement = jsonElement.getAsJsonObject().remove(typeFieldName); + JsonElement labelJsonElement = jsonElement.getAsJsonObject().get(typeFieldName); if (labelJsonElement == null) { throw new JsonParseException("cannot deserialize " + baseType + " because it does not define a field named " + typeFieldName);