*/
public void testRecoveryWithTwoDurableSubsWithRestart() throws Exception
{
Connection conn1 = null;
XAConnection conn2 = null;
XAConnection conn3 = null;
try
{
conn1 = cf.createConnection();
conn1.setClientID("wib1");
Session sess1 = conn1.createSession(false, Session.AUTO_ACKNOWLEDGE);
MessageProducer prod1 = sess1.createProducer(topicTX);
MessageConsumer sub1 = sess1.createDurableSubscriber((Topic)topicTX, "sub1");
MessageConsumer sub2 = sess1.createDurableSubscriber((Topic)topicTX, "sub2");
//send four messages
TextMessage tm1 = sess1.createTextMessage("tm1");
TextMessage tm2 = sess1.createTextMessage("tm2");
TextMessage tm3 = sess1.createTextMessage("tm3");
TextMessage tm4 = sess1.createTextMessage("tm4");
prod1.send(tm1);
prod1.send(tm2);
prod1.send(tm3);
prod1.send(tm4);
conn1.close();
//The messages should now be in both durable subs
conn2 = cf.createXAConnection();
conn2.setClientID("wib1");
conn2.start();
XASession sess2 = conn2.createXASession();
XAResource res = sess2.getXAResource();
Xid xid1 = new MessagingXid("bq1".getBytes(), 42, "eemeli".getBytes());
res.start(xid1, XAResource.TMNOFLAGS);
//Now send four more messages in a global tx
MessageProducer prod2 = sess2.createProducer(topicTX);
TextMessage tm5 = sess2.createTextMessage("tm5");
TextMessage tm6 = sess2.createTextMessage("tm6");
TextMessage tm7 = sess2.createTextMessage("tm7");
TextMessage tm8 = sess2.createTextMessage("tm8");
prod2.send(tm5);
prod2.send(tm6);
prod2.send(tm7);
prod2.send(tm8);
//And consume the first four from each in the tx
sub1 = sess2.createDurableSubscriber((Topic)topicTX, "sub1");
sub2 = sess2.createDurableSubscriber((Topic)topicTX, "sub2");
TextMessage rm1 = (TextMessage)sub1.receive(1000);
assertNotNull(rm1);
assertEquals(tm1.getText(), rm1.getText());
TextMessage rm2 = (TextMessage)sub1.receive(1000);
assertNotNull(rm2);
assertEquals(tm2.getText(), rm2.getText());
TextMessage rm3 = (TextMessage)sub1.receive(1000);
assertNotNull(rm3);
assertEquals(tm3.getText(), rm3.getText());
TextMessage rm4 = (TextMessage)sub1.receive(1000);
assertNotNull(rm4);
assertEquals(tm4.getText(), rm4.getText());
Message m = sub1.receive(1000);
assertNull(m);
rm1 = (TextMessage)sub2.receive(1000);
assertNotNull(rm1);
assertEquals(tm1.getText(), rm1.getText());
rm2 = (TextMessage)sub2.receive(1000);
assertNotNull(rm2);
assertEquals(tm2.getText(), rm2.getText());
rm3 = (TextMessage)sub2.receive(1000);
assertNotNull(rm3);
assertEquals(tm3.getText(), rm3.getText());
rm4 = (TextMessage)sub2.receive(1000);
assertNotNull(rm4);
assertEquals(tm4.getText(), rm4.getText());
m = sub2.receive(1000);
assertNull(m);
res.end(xid1, XAResource.TMSUCCESS);
//prepare it
res.prepare(xid1);
conn1 = null;
conn2 = null;
// Now "crash" the server
ServerManagement.stopServerPeer();
ServerManagement.startServerPeer();
ServerManagement.deployTopic("TXTOPIC");
conn3 = cf.createXAConnection();
XASession sess3 = conn3.createXASession();
XAResource res3 = sess3.getXAResource();
//recover
Xid[] xids = res3.recover(XAResource.TMSTARTRSCAN);
assertEquals(1, xids.length);
Xid[] xids2 = res3.recover(XAResource.TMENDRSCAN);
assertEquals(0, xids2.length);
assertEquals(xid1, xids[0]);
log.trace("Committing the tx");
//Commit
res3.commit(xids[0], false);
log.trace("committed the tx");
conn1 = cf.createConnection();
conn1.setClientID("wib1");
conn1.start();
sess1 = conn1.createSession(false, Session.AUTO_ACKNOWLEDGE);
//Should now see the last 4 messages
sub1 = sess1.createDurableSubscriber((Topic)topicTX, "sub1");
sub2 = sess1.createDurableSubscriber((Topic)topicTX, "sub2");
TextMessage rm5 = (TextMessage)sub1.receive(1000);
assertNotNull(rm5);
assertEquals(tm5.getText(), rm5.getText());
TextMessage rm6 = (TextMessage)sub1.receive(1000);
assertNotNull(rm6);
assertEquals(tm6.getText(), rm6.getText());
TextMessage rm7 = (TextMessage)sub1.receive(1000);
assertNotNull(rm7);
assertEquals(tm7.getText(), rm7.getText());
TextMessage rm8 = (TextMessage)sub1.receive(1000);
assertNotNull(rm8);
assertEquals(tm8.getText(), rm8.getText());
m = sub1.receive(1000);
assertNull(m);
rm5 = (TextMessage)sub2.receive(1000);
assertNotNull(rm5);
assertEquals(tm5.getText(), rm5.getText());
rm6 = (TextMessage)sub2.receive(1000);
assertNotNull(rm6);
assertEquals(tm6.getText(), rm6.getText());
rm7 = (TextMessage)sub2.receive(1000);
assertNotNull(rm7);
assertEquals(tm7.getText(), rm7.getText());
rm8 = (TextMessage)sub2.receive(1000);
assertNotNull(rm8);
assertEquals(tm8.getText(), rm8.getText());
m = sub2.receive(1000);
assertNull(m);
if (checkNoMessageData())
{
fail("Data remains in database");
}
}
finally
{
if (conn1 != null)
{
try
{
conn1.close();
}
catch (Exception e)
{
//Ignore
}
}
if (conn2 != null)
{
try
{
conn2.close();
}
catch (Exception e)
{
//Ignore
}
}
if (conn3 != null)
{
try
{
conn3.close();
}
catch (Exception e)
{
//Ignore
}