-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Concurrency issue in VersionSpecificWorkerContextWrapper #6554
Comments
Boereck
added a commit
to Boereck/hapi-fhir
that referenced
this issue
Dec 11, 2024
…fhir#6554) When validating if a code is valid against a ValueSet, a potentially cached (and therefore shared) result object was mutated. This mutation is now done on a copy of the result object.
Boereck
added a commit
to Boereck/hapi-fhir
that referenced
this issue
Dec 12, 2024
…fhir#6554) When validating if a code is valid against a ValueSet, a potentially cached (and therefore shared) result object was mutated. This mutation is now done on a copy of the result object.
Boereck
added a commit
to Boereck/hapi-fhir
that referenced
this issue
Dec 12, 2024
…fhir#6554) When validating if a code is valid against a ValueSet, a potentially cached (and therefore shared) result object was mutated. This mutation is now done on a copy of the result object.
Boereck
added a commit
to Boereck/hapi-fhir
that referenced
this issue
Dec 17, 2024
…fhir#6554) When validating if a code is valid against a ValueSet, a potentially cached (and therefore shared) result object was mutated. This mutation is now done on a copy of the result object.
Boereck
added a commit
to Boereck/hapi-fhir
that referenced
this issue
Dec 17, 2024
…fhir#6554) When validating if a code is valid against a ValueSet, a potentially cached (and therefore shared) result object was mutated. This mutation is now done on a copy of the result object.
# for free
to join this conversation on GitHub.
Already have an account?
# to comment
Hi,
after upgrading to HAPI 7.6.0 we got
ConcurrentModificationException
s in our validation test runs, which uses the sameFhirValidator
instance (which the documentation claims is thread safe) to validate many example resources in parallel. It was quite tricky to find the source of the error, due to the concurrent nature, but we are certain there is a problem in theVersionSpecificWorkerContextWrapper
.Describe the bug
The problematic function is
validateCodeInValueSet
:hapi-fhir/hapi-fhir-validation/src/main/java/org/hl7/fhir/common/hapi/validation/validator/VersionSpecificWorkerContextWrapper.java
Lines 803 to 834 in a999cb3
In this function
.getRootValidationSupport().validateCodeInValueSet(...)
is called to get aCodeValidationResult
. Since our root ValidationSupport is aCachingValidationSupport
, this may return a cached object. Later it is checked if the code is valid in the CodeSystem. If this is not the case, the issues will be added to the result from the ValueSet validation, which may be a cached object!In this case multiple parallel validations may write to the issues list of the result, causing
ConcurrentModificationException
s when reading the issue list later.In future versions the
ValidationSupportChain
will do the caching and provoke the same problem.Fortunately, the fix is pretty staight forward. Since the
validateCodeInValueSet
returns a result object, in theblock,
result
can be assigned to a copy ofresult
. This can be implemented inVersionSpecificWorkerContextWrapper
for the moment, but ideallyIValidationSupport.CodeValidationResult
could provide a copy constructor, or a copy instance method in future. However this class is in theorg.hl7.fhir.core
project, so this would have to be added upstream.Since all objects referenced from
IValidationSupport.CodeValidationResult
(apart from the list-fields) are immutable, it would suffice to do a shallow copy, and just create list copies of the list-fields.If wanted, we can provide a PR to fix this issue. We already tried the change and we did not face any
ConcurrentModificationException
after the change. We could also back-port this issue to the 7.6.0 stream, we just need to know against which branch the PR should go.To Reproduce
This behavior is extremely tricky to reproduce, due to the concurrent nature. However, when validating a resource using a code in a place with with binding to a value set, that is not actually included in any CodeSystem referenced in the ValueSet, and doing so over and over in parallel with the same validator object, this might be triggered.
Expected behavior
No
ConcurrentModificationException
and and no multiplying issues on code in VS validation failures.Environment (please complete the following information):
The text was updated successfully, but these errors were encountered: