]
Tom Jenkinson updated JBTM-2649:
--------------------------------
Fix Version/s: 5.2.15.Final
Inconsistent behavior of journal object store for heuristic state
-----------------------------------------------------------------
Key: JBTM-2649
URL:
https://issues.jboss.org/browse/JBTM-2649
Project: JBoss Transaction Manager
Issue Type: Bug
Components: Transaction Core
Reporter: Tom Jenkinson
Assignee: Michael Musgrove
Priority: Blocker
Fix For: 5.2.15.Final, 5.next
We do experience inconsistent behavior of journal object store (amq) against shadow
store. This starts to happen from EAP7/Narayana 5.2.14.Final.
Our test case:
* enlist activemq JMS resource
* enlist test XA resource
* prepare JMS resource
* prepare test XA resource
* commit JMS resource
* commit test XA resource
** byteman force {{topLevelCommit}} to return {{XAException.XA_HEURRB}}
2PC result for XA resource is {{TwoPhaseOutcome.HEURISTIC_HAZARD}} and client gets
{{javax.transaction.HeuristicMixedException}}
* probing log and showing state of transactions
{{/subsystem=transactions/log-store=log-store:probe}}
** expecting one indoubt participant in HEURISTIC state
* calling operation {{recovery}} on all transaction's participants
* do recovery
This works fine when Shadow log store or jdbc object store is used. For AMQ object log
store the participant is first not in HEURISTIC state but is in state PREPARED. And second
there is not only one participant of transaction in-doubt but they're returned two
participants.
Then during recovery process the periodic recovery also can see two participants for
recovery (that's my feeling from log). Not only one as expected as first resource was
already correctly committed (that's how shadow log store works).