Details
-
Bug
-
Resolution: Done
-
Major
-
6.4.0.Final, 6.5.0.Final, 7.0.0.Final
-
None
-
2017 Week 26-27, 2017 Week 28-29
-
-
NEW
-
NEW
Description
We are defining our custom JPAPlaceHolderResolverStrategy, parametrizing the constructuctor with the persistence unit name it handles.
When we need two of them to handle different kind of Entities probably from different DataSources, the marshalling process works properly as calling to accept method before marshalling returns true for the correct ObjectMarshallingStrategy.
The problem occurs while unmarshalling the entities. As the class name is being used to find the correct ObjectMarshallingStrategy from the store, the class name matches two Object Marshalling Strategies, so the first one found is returned, making the environment work in a random space.
This problem could be solved adding to ObjectMarshallingStrategy interface a getName() method in order to be able to avoid the usage of the getClass().getName() approach is being used now.
Then PersisteHelper must use this method to store the ProtobufferHeader and then ObjectMarshallingStrategyStore must use the method to retrieve the appropiate implementation.
In order to enable backward compatibility a NamedObjectMarshallingStrategyInterface could be added to be invoked only for updated implementors.
Attachments
Issue Links
- relates to
-
JBPM-6175 JPAPlaceholderResolverStrategy accept() method accepts entities its EntityManager does not handle them
- Resolved