Skip to content

Commit

Permalink
Fix discarded ObjectMapper configuration
Browse files Browse the repository at this point in the history
  • Loading branch information
torbsto committed Nov 9, 2023
1 parent d4c91a3 commit 9bf3e46
Show file tree
Hide file tree
Showing 2 changed files with 123 additions and 5 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
package io.quarkus.resteasy.reactive.jackson.deployment.test;

import java.io.IOException;
import java.time.OffsetDateTime;

import java.util.Comparator;
import org.assertj.core.api.Assertions;
import org.jboss.resteasy.reactive.RestResponse.StatusCode;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.RegisterExtension;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;

import io.quarkus.arc.Unremovable;
import io.quarkus.test.QuarkusUnitTest;
import io.restassured.RestAssured;
import io.restassured.internal.mapping.Jackson2Mapper;
import io.restassured.response.Response;
import jakarta.ws.rs.GET;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.Produces;
import jakarta.ws.rs.core.MediaType;
import jakarta.ws.rs.ext.ContextResolver;
import jakarta.ws.rs.ext.Provider;

public class CustomSerializerTest {
private static final OffsetDateTime FIXED_TIME = OffsetDateTime.now();
private static final Jackson2Mapper MAPPER = new Jackson2Mapper((type, charset) -> {
final ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(new JavaTimeModule());
return mapper;
});

@RegisterExtension
static QuarkusUnitTest test = new QuarkusUnitTest().withEmptyApplication();

@Test
void shouldUseModulesInCustomSerializer() {
final Response response = RestAssured.given().get("custom-serializer");
Assertions.assertThat(response.statusCode()).isEqualTo(StatusCode.OK);

final CustomData actual = response.as(CustomData.class, MAPPER);
final CustomData expected = new CustomData("test-data", FIXED_TIME);
Assertions.assertThat(actual)
.usingComparatorForType(Comparator.comparing(OffsetDateTime::toInstant), OffsetDateTime.class)
.usingRecursiveComparison()
.isEqualTo(expected);
}

@Path("custom-serializer")
@Produces(MediaType.APPLICATION_JSON)
static class CustomJacksonEndpoint {

@GET
public CustomData getCustom() {
return new CustomData("test-data", FIXED_TIME);
}
}

static class CustomData {
private final String name;
private final OffsetDateTime time;

@JsonCreator
CustomData(@JsonProperty("name") final String name, @JsonProperty("time") final OffsetDateTime time) {
this.name = name;
this.time = time;
}

public String getName() {
return this.name;
}

public OffsetDateTime getTime() {
return this.time;
}
}

static class CustomDataSerializer extends StdSerializer<CustomData> {
CustomDataSerializer() {
super(CustomData.class);
}

@Override
public void serialize(final CustomData customData, final JsonGenerator jsonGenerator,
final SerializerProvider serializerProvider)
throws IOException {
jsonGenerator.writeStartObject();
jsonGenerator.writeStringField("name", customData.getName());
if (customData.getTime() != null) {
jsonGenerator.writeObjectField("time", customData.getTime());
}
jsonGenerator.writeEndObject();
}
}

@Provider
@Unremovable
public static class CustomObjectMapperContextResolver implements ContextResolver<ObjectMapper> {

@Override
public ObjectMapper getContext(final Class<?> type) {
final ObjectMapper objectMapper = new ObjectMapper();
final SimpleModule simpleModule = new SimpleModule("custom-data");
simpleModule.addSerializer(new CustomDataSerializer());
objectMapper.registerModule(simpleModule);
objectMapper.registerModule(new JavaTimeModule());
return objectMapper;
}
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,10 @@ private JacksonMessageBodyWriterUtil() {

public static ObjectWriter createDefaultWriter(ObjectMapper mapper) {
// we don't want the ObjectWriter to close the stream automatically, as we want to handle closing manually at the proper points
JsonFactory jsonFactory = mapper.getFactory();
if (JacksonMessageBodyWriterUtil.needsNewFactory(jsonFactory)) {
jsonFactory = jsonFactory.copy();
JacksonMessageBodyWriterUtil.setNecessaryJsonFactoryConfig(jsonFactory);
return mapper.writer().with(jsonFactory);
if (JacksonMessageBodyWriterUtil.needsNewFactory(mapper.getFactory())) {
ObjectMapper copy = mapper.copy();
JacksonMessageBodyWriterUtil.setNecessaryJsonFactoryConfig(copy.getFactory());
return copy.writer();
} else {
return mapper.writer();
}
Expand Down

0 comments on commit 9bf3e46

Please sign in to comment.