From 1f4c2cd0d42a54bfd6afefbc417f4e176079afdb Mon Sep 17 00:00:00 2001 From: Tatu Saloranta Date: Sat, 13 Jun 2020 14:32:18 -0700 Subject: [PATCH] about to test float->int coercion settings --- .../std/PrimitiveArrayDeserializers.java | 10 ++- .../convert/CoerceFloatToIntTest.java | 66 +++++++++++++------ 2 files changed, 51 insertions(+), 25 deletions(-) diff --git a/src/main/java/com/fasterxml/jackson/databind/deser/std/PrimitiveArrayDeserializers.java b/src/main/java/com/fasterxml/jackson/databind/deser/std/PrimitiveArrayDeserializers.java index 657d2de749..1afa46aac4 100644 --- a/src/main/java/com/fasterxml/jackson/databind/deser/std/PrimitiveArrayDeserializers.java +++ b/src/main/java/com/fasterxml/jackson/databind/deser/std/PrimitiveArrayDeserializers.java @@ -495,9 +495,8 @@ public byte[] deserialize(JsonParser p, DeserializationContext ctxt) throws IOEx while ((t = p.nextToken()) != JsonToken.END_ARRAY) { // whether we should allow truncating conversions? byte value; - if (t == JsonToken.VALUE_NUMBER_INT || t == JsonToken.VALUE_NUMBER_FLOAT) { - // should we catch overflow exceptions? - value = p.getByteValue(); + if (t == JsonToken.VALUE_NUMBER_INT) { + value = p.getByteValue(); // note: may throw due to overflow } else { // should probably accept nulls as 0 if (t == JsonToken.VALUE_NULL) { @@ -529,9 +528,8 @@ protected byte[] handleSingleElementUnwrapped(JsonParser p, { byte value; JsonToken t = p.currentToken(); - if (t == JsonToken.VALUE_NUMBER_INT || t == JsonToken.VALUE_NUMBER_FLOAT) { - // should we catch overflow exceptions? - value = p.getByteValue(); + if (t == JsonToken.VALUE_NUMBER_INT) { + value = p.getByteValue(); // note: may throw due to overflow } else { // should probably accept nulls as 'false' if (t == JsonToken.VALUE_NULL) { diff --git a/src/test/java/com/fasterxml/jackson/databind/convert/CoerceFloatToIntTest.java b/src/test/java/com/fasterxml/jackson/databind/convert/CoerceFloatToIntTest.java index 40cfe7f7c2..606c5d9138 100644 --- a/src/test/java/com/fasterxml/jackson/databind/convert/CoerceFloatToIntTest.java +++ b/src/test/java/com/fasterxml/jackson/databind/convert/CoerceFloatToIntTest.java @@ -3,7 +3,10 @@ import java.math.BigInteger; import com.fasterxml.jackson.databind.*; +import com.fasterxml.jackson.databind.cfg.CoercionAction; +import com.fasterxml.jackson.databind.cfg.CoercionInputShape; import com.fasterxml.jackson.databind.exc.MismatchedInputException; +import com.fasterxml.jackson.databind.type.LogicalType; public class CoerceFloatToIntTest extends BaseMapTest { @@ -11,6 +14,30 @@ public class CoerceFloatToIntTest extends BaseMapTest private final ObjectReader READER_LEGACY_FAIL = DEFAULT_MAPPER.reader() .without(DeserializationFeature.ACCEPT_FLOAT_AS_INT); + private final ObjectMapper MAPPER_TO_EMPTY; { + MAPPER_TO_EMPTY = newJsonMapper(); + MAPPER_TO_EMPTY.coercionConfigFor(LogicalType.Integer) + .setCoercion(CoercionInputShape.Float, CoercionAction.AsEmpty); + } + + private final ObjectMapper MAPPER_TRY_CONVERT; { + MAPPER_TRY_CONVERT = newJsonMapper(); + MAPPER_TRY_CONVERT.coercionConfigFor(LogicalType.Integer) + .setCoercion(CoercionInputShape.Float, CoercionAction.TryConvert); + } + + private final ObjectMapper MAPPER_TO_NULL; { + MAPPER_TO_NULL = newJsonMapper(); + MAPPER_TO_NULL.coercionConfigFor(LogicalType.Integer) + .setCoercion(CoercionInputShape.Float, CoercionAction.AsNull); + } + + private final ObjectMapper MAPPER_TO_FAIL; { + MAPPER_TO_FAIL = newJsonMapper(); + MAPPER_TO_FAIL.coercionConfigFor(LogicalType.Integer) + .setCoercion(CoercionInputShape.Float, CoercionAction.Fail); + } + /* /******************************************************** /* Test methods, defaults (legacy) @@ -57,9 +84,13 @@ public void testLegacyFailDoubleToInt() throws Exception _verifyCoerceFail(READER_LEGACY_FAIL, LongWrapper.class, "{\"l\": 7.7 }"); _verifyCoerceFail(READER_LEGACY_FAIL, long[].class, "[ -1.35 ]"); - _verifyCoerceFailShort(READER_LEGACY_FAIL, Short.class, "0.5"); - _verifyCoerceFailShort(READER_LEGACY_FAIL, Short.TYPE, "-2.5"); - _verifyCoerceFailShort(READER_LEGACY_FAIL, short[].class, "[ -1.35 ]"); + _verifyCoerceFail(READER_LEGACY_FAIL, Short.class, "0.5"); + _verifyCoerceFail(READER_LEGACY_FAIL, Short.TYPE, "-2.5"); + _verifyCoerceFail(READER_LEGACY_FAIL, short[].class, "[ -1.35 ]"); + + _verifyCoerceFail(READER_LEGACY_FAIL, Byte.class, "0.5"); + _verifyCoerceFail(READER_LEGACY_FAIL, Byte.TYPE, "-2.5"); + _verifyCoerceFail(READER_LEGACY_FAIL, byte[].class, "[ -1.35 ]"); _verifyCoerceFail(READER_LEGACY_FAIL, BigInteger.class, "25236.256"); } @@ -71,24 +102,10 @@ private void _verifyCoerceFail(ObjectReader r, Class targetType, r.forType(targetType).readValue(doc); fail("Should not pass"); } catch (MismatchedInputException e) { - verifyException(e, "Cannot coerce a floating-point", - "Cannot coerce Floating-point"); + verifyException(e, "Cannot coerce Floating-point"); } } - private void _verifyCoerceFailShort(ObjectReader r, Class targetType, - String doc) throws Exception - { - try { - r.forType(targetType).readValue(doc); - fail("Should not pass"); - } catch (MismatchedInputException e) { - verifyException(e, - "Cannot deserialize value of type `short` from Floating-point value", - "Cannot coerce Floating-point"); - } - } - public void testDoubleToLong() throws Exception { @@ -96,8 +113,19 @@ public void testDoubleToLong() throws Exception /* /******************************************************** - /* Test methods, CoerceConfig + /* Test methods, CoerceConfig, to empty/null /******************************************************** */ + /* + /******************************************************** + /* Test methods, CoerceConfig, coerce + /******************************************************** + */ + + /* + /******************************************************** + /* Test methods, CoerceConfig, fail + /******************************************************** + */ }