Skip to content

Commit d6d8c50

Browse files
committed
Avoid manually handling additional primitive elements in collection merging for PATCHes.
Fixes #2261.
1 parent e9c43f1 commit d6d8c50

File tree

2 files changed

+47
-4
lines changed

2 files changed

+47
-4
lines changed

spring-data-rest-webmvc/src/main/java/org/springframework/data/rest/webmvc/json/DomainObjectReader.java

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -352,10 +352,7 @@ private boolean handleArrayNode(ArrayNode array, Collection<Object> collection,
352352
for (JsonNode jsonNode : array) {
353353

354354
if (!value.hasNext()) {
355-
356-
collection.add(mapper.treeToValue(jsonNode, getTypeToMap(null, componentType).getType()));
357-
358-
continue;
355+
break;
359356
}
360357

361358
Object next = value.next();

spring-data-rest-webmvc/src/test/java/org/springframework/data/rest/webmvc/json/DomainObjectReaderUnitTests.java

Lines changed: 46 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,7 @@
5858
import com.fasterxml.jackson.annotation.JsonSubTypes;
5959
import com.fasterxml.jackson.annotation.JsonTypeInfo;
6060
import com.fasterxml.jackson.annotation.JsonTypeInfo.As;
61+
import com.fasterxml.jackson.core.JacksonException;
6162
import com.fasterxml.jackson.core.JsonParser;
6263
import com.fasterxml.jackson.core.JsonProcessingException;
6364
import com.fasterxml.jackson.databind.DeserializationContext;
@@ -66,6 +67,8 @@
6667
import com.fasterxml.jackson.databind.JsonNode;
6768
import com.fasterxml.jackson.databind.ObjectMapper;
6869
import com.fasterxml.jackson.databind.PropertyNamingStrategy;
70+
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
71+
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
6972
import com.fasterxml.jackson.databind.module.SimpleModule;
7073
import com.fasterxml.jackson.databind.node.ObjectNode;
7174

@@ -109,6 +112,7 @@ void setUp() {
109112
mappingContext.getPersistentEntity(ArrayHolder.class);
110113
mappingContext.getPersistentEntity(Apple.class);
111114
mappingContext.getPersistentEntity(Pear.class);
115+
mappingContext.getPersistentEntity(WithCustomMappedPrimitiveCollection.class);
112116
mappingContext.afterPropertiesSet();
113117

114118
this.entities = new PersistentEntities(Collections.singleton(mappingContext));
@@ -645,6 +649,21 @@ void nestedEntitiesWithReadonlyFieldAreKeptForPut() throws Exception {
645649
assertThat(result.inner).isSameAs(inner);
646650
}
647651

652+
@Test // GH-2261
653+
void deserializesCustomCollectionOfPrimitives() throws Exception {
654+
655+
var node = new ObjectMapper().readTree("""
656+
{ "longs" : [ "foo:1", "bar:2" ] }
657+
""");
658+
659+
var collection = new WithCustomMappedPrimitiveCollection();
660+
collection.longs = List.of(3L);
661+
662+
var result = reader.doMerge((ObjectNode) node, collection, new ObjectMapper());
663+
664+
assertThat(result.longs).isEqualTo(List.of(1L, 2L));
665+
}
666+
648667
@SuppressWarnings("unchecked")
649668
private static <T> T as(Object source, Class<T> type) {
650669

@@ -900,4 +919,31 @@ static class Apple extends Fruit {
900919
static class Pear extends Fruit {
901920
String pear;
902921
}
922+
923+
// GH-2261
924+
static class WithCustomMappedPrimitiveCollection {
925+
926+
@JsonDeserialize(contentUsing = CustomDeserializer.class) //
927+
List<Long> longs;
928+
929+
@SuppressWarnings("serial")
930+
static class CustomDeserializer extends StdDeserializer<Long> {
931+
932+
protected CustomDeserializer() {
933+
super(Long.class);
934+
}
935+
936+
/*
937+
* (non-Javadoc)
938+
* @see com.fasterxml.jackson.databind.JsonDeserializer#deserialize(com.fasterxml.jackson.core.JsonParser, com.fasterxml.jackson.databind.DeserializationContext)
939+
*/
940+
@Override
941+
public Long deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JacksonException {
942+
943+
var elements = p.getText().split(":");
944+
945+
return Long.valueOf(elements[elements.length - 1]);
946+
}
947+
}
948+
}
903949
}

0 commit comments

Comments
 (0)