ValidatorImpl mixes contexts between validations

Description

I am using the @UnwrapValidatedValue with a custom Guava OptionalUnwrapper and sometimes OptionalUnwrapper#getValidatedValueType() is called also for non-Optional<> fields.

The bug reproduction is sporadic and tricky.

If you say sporadic, does it mean validating one and the same POJ sometimes shows the issue and in some other cases it doesn't, withou altering any parts of the code?

I managed to pinpoint it to ValidatorImpl#setValidatedValueHandlerToValueContextIfPresent() that does not perform valueContext.setValidatedValueHandler( null ) when there is no need for an unwrapper. Since valueContext is re-used between fields, it is possible for the OptionalUnwrapper to be first called for Optional fields and then re-used for non-Optional fields with the same validatedValueHandler of the Optional field.

Interesting, this doesn't seem correct indeed. Without having a closer loo I'd say the un-wrapper should be reset on the context between validation of different properties.

Mailing list discussion:
https://www.mail-archive.com/hibernate-dev@lists.jboss.org/msg11303.html

Attached is the test reproduction (requires Guava)

Environment

Ubuntu

Attachments

1

Activity

Show:

Gunnar MorlingFebruary 17, 2015 at 12:15 PM

Turns out this issue has already been fixed in the course of which is part of the 5.2.0.Alpha1 release. I'm thus going to close this issue as "Out of Date". We'll release 5.2.0.Beta1 very soon, so this may be a good time to upgrade and get the fix.

Federico DonnarummaSeptember 30, 2014 at 2:38 PM

Same issue here. Would be a nice to have in next release.

Federico Gaule PalombaraniSeptember 30, 2014 at 2:25 PM

It should be pretty good to have this issue fixed. Same problem here

Out of Date

Details

Assignee

Reporter

Bug Testcase Reminder (view)

Bug reports should generally be accompanied by a test case!

Bug Testcase Reminder (edit)

Bug reports should generally be accompanied by a test case!

Participants

Federico Donnarumma
Federico Gaule Palombarani
Gunnar Morling
Itai Frenkel

Components

Affects versions

Priority

Created September 9, 2014 at 10:00 AM
Updated July 15, 2015 at 12:16 PM
Resolved February 17, 2015 at 12:15 PM