BAEL-2412
Add tests with all the primitive values. Remove those that weren't expected to work.
This commit is contained in:
parent
cdd6968c31
commit
e3b698620c
|
@ -12,8 +12,8 @@ public class PrimitiveBundle {
|
||||||
|
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "{" + "byte: " + byteValue + ", " + "short: " + shortValue + ", "
|
return "{" + "byte: " + byteValue + ", " + "short: " + shortValue + ", "
|
||||||
+ "int: " + intValue + ", " + "long: " + longValue + ", " + "float: "
|
+ "int: " + intValue + ", " + "long: " + longValue + ", "
|
||||||
+ floatValue + ", " + "double: " + doubleValue + ", " + "boolean: "
|
+ "float: " + floatValue + ", " + "double: " + doubleValue + ", "
|
||||||
+ booleanValue + ", " + "char: " + charValue + "}";
|
+ "boolean: " + booleanValue + ", " + "char: " + charValue + "}";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
package org.baeldung.gson.primitives.models;
|
||||||
|
|
||||||
|
public class PrimitiveBundleInitialized {
|
||||||
|
// @formatter:off
|
||||||
|
public byte byteValue = (byte) 1;
|
||||||
|
public short shortValue = (short) 1;
|
||||||
|
public int intValue = 1;
|
||||||
|
public long longValue = 1L;
|
||||||
|
public float floatValue = 1.0f;
|
||||||
|
public double doubleValue = 1;
|
||||||
|
public boolean booleanValue = true;
|
||||||
|
public char charValue = 'a';
|
||||||
|
// @formatter:on
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return "{" + "byte: " + byteValue + ", " + "short: " + shortValue + ", "
|
||||||
|
+ "int: " + intValue + ", " + "long: " + longValue + ", "
|
||||||
|
+ "float: " + floatValue + ", " + "double: " + doubleValue + ", "
|
||||||
|
+ "boolean: " + booleanValue + ", " + "char: " + charValue + "}";
|
||||||
|
}
|
||||||
|
}
|
|
@ -25,13 +25,17 @@ public class UnitTest {
|
||||||
|
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
|
|
||||||
String expected = "{\"byteValue\":17,\"shortValue\":3,\"intValue\":3," + "\"longValue\":3,\"floatValue\":3.5" + ",\"doubleValue\":3.5" + ",\"booleanValue\":true,\"charValue\":\"a\"}";
|
String expected = "{\"byteValue\":17,\"shortValue\":3,\"intValue\":3,"
|
||||||
|
+ "\"longValue\":3,\"floatValue\":3.5" + ",\"doubleValue\":3.5"
|
||||||
|
+ ",\"booleanValue\":true,\"charValue\":\"a\"}";
|
||||||
|
|
||||||
assertEquals(expected, gson.toJson(primitiveBundle));
|
assertEquals(expected, gson.toJson(primitiveBundle));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test public void fromJsonAllPrimitives() {
|
@Test public void fromJsonAllPrimitives() {
|
||||||
String json = "{\"byteValue\": 17, \"shortValue\": 3, \"intValue\": 3, " + "\"longValue\": 3, \"floatValue\": 3.5" + ", \"doubleValue\": 3.5" + ", \"booleanValue\": true, \"charValue\": \"a\"}";
|
String json = "{\"byteValue\": 17, \"shortValue\": 3, \"intValue\": 3, "
|
||||||
|
+ "\"longValue\": 3, \"floatValue\": 3.5" + ", \"doubleValue\": 3.5"
|
||||||
|
+ ", \"booleanValue\": true, \"charValue\": \"a\"}";
|
||||||
|
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
PrimitiveBundle model = gson.fromJson(json, PrimitiveBundle.class);
|
PrimitiveBundle model = gson.fromJson(json, PrimitiveBundle.class);
|
||||||
|
@ -50,7 +54,8 @@ public class UnitTest {
|
||||||
|
|
||||||
@Test public void toJsonByteToBitString() {
|
@Test public void toJsonByteToBitString() {
|
||||||
GsonBuilder builder = new GsonBuilder();
|
GsonBuilder builder = new GsonBuilder();
|
||||||
builder.registerTypeAdapter(ByteExample.class, new GsonBitStringSerializer());
|
builder.registerTypeAdapter(ByteExample.class,
|
||||||
|
new GsonBitStringSerializer());
|
||||||
|
|
||||||
Gson gson = builder.create();
|
Gson gson = builder.create();
|
||||||
ByteExample model = new ByteExample();
|
ByteExample model = new ByteExample();
|
||||||
|
@ -62,7 +67,8 @@ public class UnitTest {
|
||||||
@Test public void fromJsonByteFromBitString() {
|
@Test public void fromJsonByteFromBitString() {
|
||||||
String json = "{\"value\": \"1111\"}";
|
String json = "{\"value\": \"1111\"}";
|
||||||
GsonBuilder gsonBuilder = new GsonBuilder();
|
GsonBuilder gsonBuilder = new GsonBuilder();
|
||||||
gsonBuilder.registerTypeAdapter(ByteExample.class, new GsonBitStringDeserializer());
|
gsonBuilder.registerTypeAdapter(ByteExample.class,
|
||||||
|
new GsonBitStringDeserializer());
|
||||||
|
|
||||||
Gson gson = gsonBuilder.create();
|
Gson gson = gsonBuilder.create();
|
||||||
|
|
||||||
|
@ -110,36 +116,52 @@ public class UnitTest {
|
||||||
|
|
||||||
@Test public void fromJsonNull() {
|
@Test public void fromJsonNull() {
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
String json = "{\"value\": null}";
|
// @formatter:off
|
||||||
ByteExample model = gson.fromJson(json, ByteExample.class);
|
String json = "{\"byteValue\": null, \"shortValue\": null, "
|
||||||
|
+ "\"intValue\": null, " + "\"longValue\": null, \"floatValue\": null"
|
||||||
|
+ ", \"doubleValue\": null" + ", \"booleanValue\": null, \"charValue\": null}";
|
||||||
|
// @formatter:on
|
||||||
|
PrimitiveBundleInitialized model = gson.fromJson(json,
|
||||||
|
PrimitiveBundleInitialized.class);
|
||||||
|
|
||||||
assertEquals(1, model.value);
|
assertEquals(1, model.byteValue);
|
||||||
|
assertEquals(1, model.shortValue);
|
||||||
|
assertEquals(1, model.intValue);
|
||||||
|
assertEquals(1, model.longValue);
|
||||||
|
assertEquals(1, model.floatValue, 0.0001);
|
||||||
|
assertEquals(1, model.doubleValue, 0.0001);
|
||||||
|
assertTrue(model.booleanValue);
|
||||||
|
assertEquals('a', model.charValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = JsonSyntaxException.class) public void fromJsonEmptyString() {
|
@Test(expected = JsonSyntaxException.class) public void fromJsonEmptyString() {
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
String json = "{\"value\": \"\"}";
|
// @formatter:off
|
||||||
gson.fromJson(json, ByteExample.class);
|
String json = "{\"byteValue\": \"\", \"shortValue\": \"\", "
|
||||||
|
+ "\"intValue\": \"\", " + "\"longValue\": \"\", \"floatValue\": \"\""
|
||||||
|
+ ", \"doubleValue\": \"\"" + ", \"booleanValue\": \"\", \"charValue\": \"\"}";
|
||||||
|
// @formatter:on
|
||||||
|
gson.fromJson(json, PrimitiveBundleInitialized.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test public void fromJsonValidValueWithinString() {
|
@Test public void fromJsonValidValueWithinString() {
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
String json = "{\"value\": \"15\"}";
|
// @formatter:off
|
||||||
ByteExample model = gson.fromJson(json, ByteExample.class);
|
String json = "{\"byteValue\": \"15\", \"shortValue\": \"15\", "
|
||||||
|
+ "\"intValue\": \"15\", " + "\"longValue\": \"15\", \"floatValue\": \"15.0\""
|
||||||
|
+ ", \"doubleValue\": \"15.0\"" + ", \"booleanValue\": \"false\", \"charValue\": \"z\"}";
|
||||||
|
// @formatter:on
|
||||||
|
PrimitiveBundleInitialized model = gson.fromJson(json,
|
||||||
|
PrimitiveBundleInitialized.class);
|
||||||
|
|
||||||
assertEquals(15, model.value);
|
assertEquals(15, model.byteValue);
|
||||||
}
|
assertEquals(15, model.shortValue);
|
||||||
|
assertEquals(15, model.intValue);
|
||||||
@Test(expected = JsonSyntaxException.class) public void fromJsonInvalidValueWithinString() {
|
assertEquals(15, model.longValue);
|
||||||
Gson gson = new Gson();
|
assertEquals(15, model.floatValue, 0.0001);
|
||||||
String json = "{\"value\": \"15x\"}";
|
assertEquals(15, model.doubleValue, 0.0001);
|
||||||
gson.fromJson(json, ByteExample.class);
|
assertFalse(model.booleanValue);
|
||||||
}
|
assertEquals('z', model.charValue);
|
||||||
|
|
||||||
@Test(expected = JsonSyntaxException.class) public void fromJsonInvalidValueNotInAString() {
|
|
||||||
Gson gson = new Gson();
|
|
||||||
String json = "{\"value\": s15s}";
|
|
||||||
gson.fromJson(json, ByteExample.class);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test public void fromJsonBooleanFrom2ValueInteger() {
|
@Test public void fromJsonBooleanFrom2ValueInteger() {
|
||||||
|
@ -160,7 +182,8 @@ public class UnitTest {
|
||||||
@Test public void fromJsonBooleanFrom2ValueIntegerSolution() {
|
@Test public void fromJsonBooleanFrom2ValueIntegerSolution() {
|
||||||
String json = "{\"value\": 1}";
|
String json = "{\"value\": 1}";
|
||||||
GsonBuilder builder = new GsonBuilder();
|
GsonBuilder builder = new GsonBuilder();
|
||||||
builder.registerTypeAdapter(BooleanExample.class, new BooleanAs2ValueIntegerDeserializer());
|
builder.registerTypeAdapter(BooleanExample.class,
|
||||||
|
new BooleanAs2ValueIntegerDeserializer());
|
||||||
|
|
||||||
Gson gson = builder.create();
|
Gson gson = builder.create();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue