use of net.dempsy.utils.test.SystemPropertyManager in project Dempsy by Dempsy.
the class TestWordCount method testWordCountWithRank.
@Test
public void testWordCountWithRank() throws Throwable {
try (@SuppressWarnings("resource") final SystemPropertyManager props = new SystemPropertyManager().set("min_nodes", "1")) {
final String[][] ctxs = { { "classpath:/word-count/adaptor-kjv.xml", "classpath:/word-count/mp-word-count.xml", "classpath:/word-count/mp-word-rank.xml" } };
// need to make it wait.
WordProducer.latch = new CountDownLatch(1);
runCombos("testWordCountWithRank", ctxs, n -> {
final List<NodeManagerWithContext> nodes = n.nodes;
final NodeManager manager = nodes.get(0).manager;
// wait until I can reach the cluster from the adaptor.
assertTrue(poll(o -> manager.getRouter().allReachable("test-cluster1").size() == 1));
final ClassPathXmlApplicationContext ctx = nodes.get(0).ctx;
final WordProducer adaptor;
final ClusterMetricGetters stats;
WordProducer.latch.countDown();
adaptor = ctx.getBean(WordProducer.class);
stats = (ClusterMetricGetters) manager.getClusterStatsCollector(new ClusterId(currentAppName, "test-cluster1"));
assertTrue(poll(o -> adaptor.done.get()));
assertTrue(poll(o -> adaptor.numDispatched == stats.getProcessedMessageCount()));
// wait until all of the counts are also passed to WordRank
final ClusterMetricGetters wrStats = (ClusterMetricGetters) manager.getClusterStatsCollector(new ClusterId(currentAppName, "test-cluster2"));
assertTrue(poll(wrStats, s -> adaptor.numDispatched == s.getProcessedMessageCount()));
stopSystem();
// pull the Rank mp from the manager
final MessageProcessorLifecycle<?> mp = AccessUtil.getMp(manager, "test-cluster2");
@SuppressWarnings("unchecked") final WordRank prototype = ((MessageProcessor<WordRank>) mp).getPrototype();
final List<Rank> ranks = prototype.getPairs();
Collections.sort(ranks, (o1, o2) -> o2.rank.compareTo(o1.rank));
final List<Rank> top10 = ranks.subList(0, 10);
top10.forEach(r -> assertTrue(finalResults.contains(r.word)));
});
}
}
use of net.dempsy.utils.test.SystemPropertyManager in project Dempsy by Dempsy.
the class TestWordCount method runTestWithOutputCycle.
private void runTestWithOutputCycle(final String testName, final String outputSchedCtx) throws Exception {
final String[][] ctxs = { // adaptor only node
{ "classpath:/word-count/adaptor-kjv.xml" }, { "classpath:/word-count/mp-word-count.xml", "classpath:/word-count/mp-word-count-output.xml", outputSchedCtx }, { "classpath:/word-count/mp-word-count.xml", "classpath:/word-count/mp-word-count-output.xml", outputSchedCtx }, { "classpath:/word-count/mp-rank-catcher.xml" } };
// the adaptor is the first one, rank catcher the last.
final int NUM_WC = ctxs.length - 2;
try (@SuppressWarnings("resource") final SystemPropertyManager props = new SystemPropertyManager().set("min_nodes", Integer.toString(NUM_WC)).set("routing-group", ":group").set("send_threads", "1").set("receive_threads", "1").set("blocking-queue-size", "500000")) {
// need to make it wait.
WordProducer.latch = new CountDownLatch(1);
runCombos(testName, (r, c, s, t, ser) -> isElasticRoutingStrategy(r), ctxs, n -> {
final List<NodeManagerWithContext> nodes = n.nodes;
final NodeManager[] managers = nodes.stream().map(nm -> nm.manager).toArray(NodeManager[]::new);
// wait until I can reach the cluster from the adaptor.
assertTrue(poll(o -> managers[0].getRouter().allReachable("test-cluster1").size() == NUM_WC));
assertTrue(poll(o -> managers[0].getRouter().allReachable("test-cluster2").size() == NUM_WC));
assertTrue(poll(o -> managers[0].getRouter().allReachable("test-cluster3").size() == 1));
for (int i = 0; i < NUM_WC; i++) {
// the +1 is because the first (0th) manager is the adaptor
final int managerIndex = i + 1;
assertTrue(poll(o -> managers[managerIndex].getRouter().allReachable("test-cluster3").size() == 1));
}
WordProducer.latch.countDown();
final WordProducer adaptor = nodes.get(0).ctx.getBean(WordProducer.class);
waitForAllSent(adaptor);
// the last node has the RankCatcher
final NodeManager manager = nodes.get(nodes.size() - 1).manager;
final MessageProcessorLifecycle<?> mp = AccessUtil.getMp(manager, "test-cluster3");
@SuppressWarnings("unchecked") final RankCatcher prototype = ((MessageProcessor<RankCatcher>) mp).getPrototype();
final HashSet<String> expected = new HashSet<>(Arrays.asList("the", "that", "unto", "in", "and", "And", "of", "shall", "to", "he"));
assertTrue(() -> {
return "FAILURE:" + expected.toString() + " != " + prototype.topRef.get();
}, poll(prototype.topRef, tr -> {
final List<Rank> cur = tr.get();
final HashSet<String> topSet = new HashSet<>(cur.stream().map(r -> r.word).collect(Collectors.toSet()));
// once more than 1/2 of the list is there then we're done.
final int threshold = (expected.size() / 2) + 1;
int matches = 0;
for (final String exp : expected) if (topSet.contains(exp))
matches++;
return matches >= threshold;
}));
});
}
}
use of net.dempsy.utils.test.SystemPropertyManager in project Dempsy by Dempsy.
the class TestContainer method setUp.
@Before
public void setUp() throws Exception {
justThrowMe = null;
throwMeInActivation = null;
track(new SystemPropertyManager()).set("container-type", containerId);
context = track(new ClassPathXmlApplicationContext(ctx));
sessionFactory = new LocalClusterSessionFactory();
final Node node = context.getBean(Node.class);
manager = track(new NodeManager()).node(node).collaborator(track(sessionFactory.createSession())).start();
statsCollector = manager.getClusterStatsCollector(new ClusterId("test-app", "test-cluster"));
container = manager.getContainers().get(0);
assertTrue(poll(manager, m -> m.isReady()));
}
Aggregations