@Override public Vote checkXid(Xid xid) { if(xid.getFormatId() != myFormatId) { return Vote.ABSTAIN; } return nodeNameFilter.checkXid(xid); } }
@Override public Vote checkXid(Xid xid) { if(xid.getFormatId() != myFormatId) { return Vote.ABSTAIN; } return nodeNameFilter.checkXid(xid); } }
@Override public Vote checkXid(Xid xid) { if(xid.getFormatId() != myFormatId) { return Vote.ABSTAIN; } return nodeNameFilter.checkXid(xid); } }
@Override public Vote checkXid(Xid xid) { if(xid.getFormatId() != myFormatId) { return Vote.ABSTAIN; } return nodeNameFilter.checkXid(xid); } }
@Override public Vote checkXid(Xid xid) { if(xid.getFormatId() != myFormatId) { return Vote.ABSTAIN; } return nodeNameFilter.checkXid(xid); } }
@Override public Vote checkXid(Xid xid) { if(xid.getFormatId() != myFormatId) { return Vote.ABSTAIN; } return nodeNameFilter.checkXid(xid); } }
XAResourceOrphanFilter.Vote vote = filter.checkXid(xid);
XAResourceOrphanFilter.Vote vote = filter.checkXid(xid);
XAResourceOrphanFilter.Vote vote = filter.checkXid(xid);
XAResourceOrphanFilter.Vote vote = filter.checkXid(xid);
XAResourceOrphanFilter.Vote vote = filter.checkXid(xid);
XAResourceOrphanFilter.Vote vote = filter.checkXid(xid);
@Test public void testJTATransactionLogOrphanFilter() { XAResourceOrphanFilter orphanFilter = new JTATransactionLogXAResourceOrphanFilter(); Xid notJTAFormatId = XATxConverter.getXid(new Uid(), false, 0); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(notJTAFormatId)); Xid jtaFormatId = XATxConverter.getXid(new Uid(), false, XATxConverter.FORMAT_ID); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(jtaFormatId)); }
@Test public void testJTANodeNameXAResourceOrphanFilter() { XAResourceOrphanFilter orphanFilter = new JTANodeNameXAResourceOrphanFilter(); Xid notJTAFormatId = XATxConverter.getXid(new Uid(), false, 0); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(notJTAFormatId)); List<String> recoveryNodes = new LinkedList<String>(); recoveryNodes.add("1"); jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(recoveryNodes); String notRecoverableNodeName ="2"; TxControl.setXANodeName(notRecoverableNodeName); Xid jtaNotRecoverableNodeName = XATxConverter.getXid(new Uid(), false, XATxConverter.FORMAT_ID); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(jtaNotRecoverableNodeName)); String recoverableNodeName ="1"; TxControl.setXANodeName(recoverableNodeName); Xid jtaRecoverableNodeName = XATxConverter.getXid(new Uid(), false, XATxConverter.FORMAT_ID); assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(jtaRecoverableNodeName)); recoveryNodes.clear(); recoveryNodes.add(NodeNameXAResourceOrphanFilter.RECOVER_ALL_NODES); jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(recoveryNodes); assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(jtaNotRecoverableNodeName)); assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(jtaRecoverableNodeName)); }
try { Xid xid = XATxConverter.getXid(Uid.nullUid(), false, XATxConverter.FORMAT_ID); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(xid)); SubordinateTransaction subordinateTransaction = SubordinationManager.getTransactionImporter().importTransaction(xid); final List<Xid> xids = new ArrayList<Xid>(); subordinateTransaction.enlistResource(xar); try { assertEquals(XAResourceOrphanFilter.Vote.LEAVE_ALONE, orphanFilter.checkXid(xids.get(0))); } finally { subordinateTransaction.doRollback(); assertEquals(XAResourceOrphanFilter.Vote.LEAVE_ALONE, orphanFilter.checkXid(xids.get(0))); SubordinationManager.getTransactionImporter().removeImportedTransaction(xid); assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(xids.get(0))); } finally { jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(xaRecoveryNodes);
@Test public void testJTAActionStatusServiceXAResourceOrphanFilter() { XAResourceOrphanFilter orphanFilter = new JTAActionStatusServiceXAResourceOrphanFilter(); List<String> xaRecoveryNodes = jtaPropertyManager.getJTAEnvironmentBean().getXaRecoveryNodes(); List<String> recoveryNodes = new LinkedList<String>(); recoveryNodes.add("1"); jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(recoveryNodes); try { Uid uid = new Uid(); Xid xid = XATxConverter.getXid(uid, false, XATxConverter.FORMAT_ID); assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(xid)); TwoPhaseCoordinator tpc = new TwoPhaseCoordinator(uid); try { tpc.start(); assertEquals(XAResourceOrphanFilter.Vote.LEAVE_ALONE, orphanFilter.checkXid(xid)); } finally { tpc.cancel(); } assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(xid)); jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(null); TwoPhaseCoordinator tpc2 = new TwoPhaseCoordinator(uid); tpc2.start(); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(xid)); tpc2.cancel(); } finally { jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(xaRecoveryNodes); } }
@Test public void testSubordinateJTAXAResourceOrphanFilter() throws HeuristicRollbackException, HeuristicMixedException, HeuristicCommitException, SystemException, RollbackException, XAException { XAResourceOrphanFilter orphanFilter = new SubordinateJTAXAResourceOrphanFilter(); XidImple xid = (XidImple) XATxConverter.getXid(Uid.nullUid(), false, XATxConverter.FORMAT_ID); XATxConverter.setSubordinateNodeName(xid.getXID(), TxControl.getXANodeName()); List<String> xaRecoveryNodes = jtaPropertyManager.getJTAEnvironmentBean().getXaRecoveryNodes(); try { jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(Arrays.asList("2")); assertEquals(XAResourceOrphanFilter.Vote.ABSTAIN, orphanFilter.checkXid(xid)); jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(Arrays.asList("1")); assertEquals(XAResourceOrphanFilter.Vote.ROLLBACK, orphanFilter.checkXid(xid)); } finally { jtaPropertyManager.getJTAEnvironmentBean().setXaRecoveryNodes(xaRecoveryNodes); } } }