// Login user1
final CountDownLatch loginLatch1 = new CountDownLatch(1);
Map<String, Object> login1 = new HashMap<>();
String userId1 = "user1";
login1.put("user", userId1);
ClientSessionChannel loginChannel1 = client1.getChannel("/service/login");
loginChannel1.publish(login1, new ClientSessionChannel.MessageListener()
{
public void onMessage(ClientSessionChannel channel, Message message)
{
loginLatch1.countDown();
}
});
Assert.assertTrue(loginLatch1.await(5, TimeUnit.SECONDS));
Assert.assertTrue(presenceAddedLatch.await(5, TimeUnit.SECONDS));
int switches = 2;
for (int i = 0; i < switches; ++i)
{
// Simulate network crash
oortComet12.disconnect();
oortComet12.waitFor(5000, BayeuxClient.State.DISCONNECTED);
// The other OortComet is automatically disconnected
oortComet21.waitFor(5000, BayeuxClient.State.DISCONNECTED);
// Stop node1
int port1 = ((NetworkConnector)server1.getConnectors()[0]).getLocalPort();
stopSeti(seti1);
stopOort(oort1);
stopServer(server1);
// Disconnect user and login it to node2
client1.disconnect();
Assert.assertTrue(client1.waitFor(5000, BayeuxClient.State.DISCONNECTED));
client1 = startClient(oort2, null);
final CountDownLatch loginLatch2 = new CountDownLatch(1);
loginChannel1 = client1.getChannel("/service/login");
loginChannel1.publish(login1, new ClientSessionChannel.MessageListener()
{
public void onMessage(ClientSessionChannel channel, Message message)
{
loginLatch2.countDown();
}
});
Assert.assertTrue(loginLatch2.await(5, TimeUnit.SECONDS));
// Bring node1 back online
server1 = startServer(port1);
oort1 = startOort(server1);
oortLatch = new CountDownLatch(1);
oort2.addCometListener(new CometJoinedListener(oortLatch));
oortComet12 = oort1.observeComet(oort2.getURL());
Assert.assertTrue(oortComet12.waitFor(5000, BayeuxClient.State.CONNECTED));
Assert.assertTrue(oortLatch.await(5, TimeUnit.SECONDS));
oortComet21 = oort2.findComet(oort1.getURL());
Assert.assertTrue(oortComet21.waitFor(5000, BayeuxClient.State.CONNECTED));
seti1 = startSeti(oort1);
new SetiService(seti1);
// Wait for cloud/seti notifications to happen
Thread.sleep(1000);
System.err.println(seti1.dump());
System.err.println(seti2.dump());
Assert.assertFalse(seti1.isAssociated(userId1));
Assert.assertTrue(seti1.isPresent(userId1));
Assert.assertTrue(seti2.isAssociated(userId1));
Assert.assertTrue(seti2.isPresent(userId1));
// Simulate network crash
oortComet12.disconnect();
oortComet12.waitFor(5000, BayeuxClient.State.DISCONNECTED);
// The other OortComet is automatically disconnected
oortComet21.waitFor(5000, BayeuxClient.State.DISCONNECTED);
// Stop node2
int port2 = ((NetworkConnector)server2.getConnectors()[0]).getLocalPort();
stopSeti(seti2);
stopOort(oort2);
stopServer(server2);
// Disconnect user and login it to node1
client1.disconnect();
Assert.assertTrue(client1.waitFor(5000, BayeuxClient.State.DISCONNECTED));
client1 = startClient(oort1, null);
final CountDownLatch loginLatch3 = new CountDownLatch(1);
loginChannel1 = client1.getChannel("/service/login");
loginChannel1.publish(login1, new ClientSessionChannel.MessageListener()
{
public void onMessage(ClientSessionChannel channel, Message message)
{
loginLatch3.countDown();
}