Skip to content

Commit

Permalink
review comments
Browse files Browse the repository at this point in the history
  • Loading branch information
rockoder committed Mar 9, 2019
1 parent b1834b6 commit 02fd91a
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 25 deletions.
36 changes: 28 additions & 8 deletions gson/src/main/java/org/baeldung/gson/entities/MyClass.java
Original file line number Diff line number Diff line change
@@ -1,14 +1,18 @@
package org.baeldung.gson.entities;

import java.util.Objects;

public class MyClass {
private int id;
private String[] strings;
private String name;

public MyClass() {
id = 1;
strings = new String[] { "a", "b" };
public MyClass(int id, String name) {
this.id = id;
this.name = name;
}

public MyClass() { }

public int getId() {
return id;
}
Expand All @@ -17,11 +21,27 @@ public void setId(int id) {
this.id = id;
}

public String[] getStrings() {
return strings;
public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

@Override public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
MyClass myClass = (MyClass) o;
return id == myClass.id && Objects.equals(name, myClass.name);
}

public void setStrings(String[] strings) {
this.strings = strings;
@Override public int hashCode() {

return Objects.hash(id, name);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import com.google.gson.reflect.TypeToken;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import org.baeldung.gson.entities.Animal;
import org.baeldung.gson.entities.Cow;
Expand All @@ -18,40 +19,42 @@

public class GsonAdvanceUnitTest {

@Test public void givenListOfMyClass_whenSerializing_thenCorrect() {
List<MyClass> list = new ArrayList<>();
list.add(new MyClass());
list.add(new MyClass());
@Test
public void givenListOfMyClass_whenSerializing_thenCorrect() {
List<MyClass> list = Arrays.asList(new MyClass(1, "name1"), new MyClass(2, "name2"));

Gson gson = new Gson();
String jsonString = gson.toJson(list);
String expectedString = "[{\"id\":1,\"strings\":[\"a\",\"b\"]},{\"id\":1,\"strings\":[\"a\",\"b\"]}]";
String expectedString = "[{\"id\":1,\"name\":\"name1\"},{\"id\":2,\"name\":\"name2\"}]";

assertEquals(expectedString, jsonString);
}

@Test(expected = ClassCastException.class)
public void givenJsonString_whenIncorrectDeserializing_thenThrowClassCastException() {
String inputString = "[{\"id\":1,\"strings\":[\"a\",\"b\"]},{\"id\":1,\"strings\":[\"a\",\"b\"]}]";
String inputString = "[{\"id\":1,\"name\":\"name1\"},{\"id\":2,\"name\":\"name2\"}]";

Gson gson = new Gson();
List<MyClass> list = gson.fromJson(inputString, ArrayList.class);
List<MyClass> outputList = gson.fromJson(inputString, ArrayList.class);

assertEquals(1, list.get(0).getId());
assertEquals(1, outputList.get(0).getId());
}

@Test public void givenJsonString_whenDeserializing_thenReturnListOfMyClass() {
String inputString = "[{\"id\":1,\"strings\":[\"a\",\"b\"]},{\"id\":1,\"strings\":[\"a\",\"b\"]}]";
@Test
public void givenJsonString_whenDeserializing_thenReturnListOfMyClass() {
String inputString = "[{\"id\":1,\"name\":\"name1\"},{\"id\":2,\"name\":\"name2\"}]";
List<MyClass> inputList = Arrays.asList(new MyClass(1, "name1"), new MyClass(2, "name2"));

Type listOfMyClassObject = new TypeToken<ArrayList<MyClass>>() {}.getType();

Gson gson = new Gson();
List<MyClass> list = gson.fromJson(inputString, listOfMyClassObject);
List<MyClass> outputList = gson.fromJson(inputString, listOfMyClassObject);

assertEquals(2, list.size());
assertEquals(1, list.get(0).getId());
assertEquals(inputList, outputList);
}

@Test public void givenPolymorphicList_whenSerializeWithTypeAdapter_thenCorrect() {
@Test
public void givenPolymorphicList_whenSerializeWithTypeAdapter_thenCorrect() {
String expectedString = "[{\"petName\":\"Milo\",\"type\":\"Dog\"},{\"breed\":\"Jersey\",\"type\":\"Cow\"}]";

List<Animal> inList = new ArrayList<>();
Expand All @@ -63,7 +66,8 @@ public void givenJsonString_whenIncorrectDeserializing_thenThrowClassCastExcepti
assertEquals(expectedString, jsonString);
}

@Test public void givenPolymorphicList_whenDeserializeWithTypeAdapter_thenCorrect() {
@Test
public void givenPolymorphicList_whenDeserializeWithTypeAdapter_thenCorrect() {
String inputString = "[{\"petName\":\"Milo\",\"type\":\"Dog\"},{\"breed\":\"Jersey\",\"type\":\"Cow\"}]";

AnimalDeserializer deserializer = new AnimalDeserializer("type");
Expand All @@ -79,7 +83,8 @@ public void givenJsonString_whenIncorrectDeserializing_thenThrowClassCastExcepti
assertTrue(outList.get(0) instanceof Dog);
}

@Test public void givenPolymorphicList_whenSerializeWithRuntimeTypeAdapter_thenCorrect() {
@Test
public void givenPolymorphicList_whenSerializeWithRuntimeTypeAdapter_thenCorrect() {
String expectedString = "[{\"petName\":\"Milo\",\"type\":\"Dog\"},{\"breed\":\"Jersey\",\"type\":\"Cow\"}]";

List<Animal> inList = new ArrayList<>();
Expand All @@ -90,7 +95,8 @@ public void givenJsonString_whenIncorrectDeserializing_thenThrowClassCastExcepti
assertEquals(expectedString, jsonString);
}

@Test public void givenPolymorphicList_whenDeserializeWithRuntimeTypeAdapter_thenCorrect() {
@Test
public void givenPolymorphicList_whenDeserializeWithRuntimeTypeAdapter_thenCorrect() {
String inputString = "[{\"petName\":\"Milo\",\"type\":\"Dog\"},{\"breed\":\"Jersey\",\"type\":\"Cow\"}]";

Type listOfAnimals = new TypeToken<ArrayList<Animal>>() {}.getType();
Expand Down

0 comments on commit 02fd91a

Please sign in to comment.