-
-
Notifications
You must be signed in to change notification settings - Fork 175
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Deserialization fails for class with single private accessor property #753
Comments
Thank you for digging deeper. By the way, is this a bug in As a side note, if you are creating a |
Hello. In case of Java it succeeds. The test code is below. class JacksonJavaTest {
final ObjectMapper mapper = new ObjectMapper();
static class A {
private final String name;
@JsonCreator
public A(@JsonProperty("name") String name){
this.name = name;
}
}
static class B {
private final String name;
private final int age;
@JsonCreator
public B(
@JsonProperty("name")String name,
@JsonProperty("age")int age){
this.name = name;
this.age = age;
}
}
@Test
void success() throws JsonProcessingException {
final String json = "{\"name\" : \"hello\", \"age\": 12}";
mapper.readValue(json, B.class);
}
@Test // expected fail but success
void fail() throws JsonProcessingException {
final String json = "{\"name\" : \"hello\"}";
mapper.readValue(json, A.class);
}
} |
I'm having the same problem when deserializing the following class: class StringFromListGenerator(
val options: List<String> // Bug in Kotlin module: this cannot be private
) : ArgumentGenerator {
override fun generate(random: Random): String {
return options[random.nextInt(options.size)]
}
} When I try to deserialize this from JSON: {
"options": [
"ABC",
"DEF",
"123"
]
} I get a misleading error message:
|
I have been very busy for a while and do not have time to check this issue. Personally, I think the problem is related to The sample code you gave us uses I have a vague recollection that a similar issue was previously posted on Your help in a more in-depth investigation may speed up the resolution of the issue. |
Here is a possibly related example. I am not sure if the root cause is the same, perhaps I should open a new issue for this but this was similar enough to entice me to first post this as a comment here. The interesting part here is the behaviour of deser into class B, which has a single field that unconventionally starts with an uppercase data class A(
val foo: String,
)
data class B(
val Foo: String
)
data class C(
val Foo: String,
val Bar: String
)
data class D(
@JsonProperty("Foo")
val Foo: String,
)
fun main() {
val om = ObjectMapper().apply {
registerKotlinModule()
disable(DeserializationFeature.FAIL_ON_IGNORED_PROPERTIES)
disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES)
}
val json = """{"foo": "bar", "Foo": "Foo", "Bar": "Bar", "a": "b"} """
om.readValue<A>(json) // Works
om.readValue<B>(json) // Fails with Exception in thread "main" ... Cannot construct instance of B` (although at least one Creator exists): cannot deserialize from Object value (no delegate- or property-based Creator)
om.readValue<C>(json) // Works
om.readValue<D>(json) // Works
} |
This is my workaround for the issue:
|
@ahabel-wob Very good point -- this (or, one for Thank you for pointing this out. |
Search before asking
Describe the bug
Deserialization fails for class with single private accessor property.
When deserializing, a MismatchedInputException occurs.
To Reproduce
Expected behavior
A class with single private accessor property is properly deserialized.
Actual behavior
Versions
Kotlin: 1.8.0
Jackson-module-kotlin: 2.12.7
Jackson-databind: 2.12.7.1
Additional context
I tried to dig into this and discovered the flow below:
(Code has been simplified)
The text was updated successfully, but these errors were encountered: