@Test public void testTwoNodes() throws L2pSecurityException, EncodingFailedException, SerializationException, InterruptedException, AgentException { adam.unlockPrivateKey("adamspass"); eve.unlockPrivateKey("evespass"); // launch to nodes with one agent each LocalNode testee1 = LocalNode.launchAgent(adam); LocalNode.launchAgent(eve); assertTrue(LocalNode.findAllNodesWithAgent(adam.getId()).length > 0); assertTrue(LocalNode.findAllNodesWithAgent(eve.getId()).length > 0); MessageResultListener l = new MessageResultListener(10000); Message m = new Message(adam, eve, new PingPongContent()); testee1.sendMessage(m, l); l.waitForAllAnswers(); assertEquals(1, l.getNumberOfExpectedResults()); assertTrue(l.isFinished()); assertTrue(l.isSuccess()); }
@Test public void testBroadcast() throws EncodingFailedException, L2pSecurityException, SerializationException, InterruptedException, AgentException, AgentNotKnownException { adam.unlockPrivateKey("adamspass"); eve.unlockPrivateKey("evespass"); // launch three nodes with one agent each LocalNode testee1 = LocalNode.launchAgent(adam); LocalNode hosting1 = LocalNode.launchAgent(eve); assertEquals(1, LocalNode.findAllNodesWithAgent(eve.getId()).length); LocalNode hosting2 = LocalNode.launchAgent(eve); assertTrue(hosting1.hasLocalAgent(eve)); assertTrue(hosting2.hasLocalAgent(eve)); assertNotSame(hosting1.getAgent(eve.getId()), hosting2.getAgent(eve.getId())); assertEquals(2, LocalNode.findAllNodesWithAgent(eve.getId()).length); MessageResultListener l = new MessageResultListener(10000) { public void notifySuccess() { synchronized (this) { System.out.println("result retrieved"); LocalNodeTest.counter++; } } }; // l.addRecipient(); assertEquals(1, l.getNumberOfExpectedResults()); Message m = new Message(adam, eve, new PingPongContent()); testee1.sendMessage(m, l, Node.SendMode.BROADCAST); assertEquals(2, l.getNumberOfExpectedResults()); l.waitForAllAnswers(); assertEquals(2, l.getNumberOfResults()); assertEquals(counter, 2); assertTrue(l.isSuccess()); assertTrue(l.isFinished()); }