Hello All,
I am trying to perform JUNIT testing for topologies but getting the below
error.
*java.lang.AssertionError: Test timed out (10000ms) (not (every? exhausted?
(spout-objects spouts)))*
*at org.apache.storm.testing$complete_topology.doInvoke(testing.clj:529)*
*at clojure.lang.RestFn.invoke(RestFn.java:1124)*
*at org.apache.storm.testing4j$_completeTopology.invoke(testing4j.clj:63)*
*at org.apache.storm.Testing.completeTopology(Unknown Source)*
*at
XXXXXXXX.LocationSummaryTopologyUnitTest.lambda$0(LocationSummaryTopologyUnitTest.java:124)*
*at
org.apache.storm.testing4j$_withTrackedCluster$fn__10274.invoke(testing4j.clj:120)*
*at
org.apache.storm.testing4j$_withTrackedCluster.invoke(testing4j.clj:120)*
*at org.apache.storm.Testing.withTrackedCluster(Unknown Source)*
*at
XXXXXXXX.LocationSummaryTopologyUnitTest.testLocationSummaryTopology(LocationSummaryTopologyUnitTest.java:103)*
*at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)*
*at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)*
*at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)*
*at java.lang.reflect.Method.invoke(Method.java:498)*
*at
org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)*
*at
org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)*
*at
org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)*
*at
org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)*
*at
org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)*
*at
org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27)*
*at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)*
*at
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)*
*at
org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)*
*at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)*
*at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)*
*at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)*
*at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)*
*at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)*
*at org.junit.runners.ParentRunner.run(ParentRunner.java:363)*
*at
org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)*
*at
org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)*
*at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)*
*at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678)*
*at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)*
*at
org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)*
Here's is my code:
*@Test*
*public void testLocationSummaryTopology()*
*{*
*TagMessage tagMessage;*
*List<TagSummary> actualTagSummaryList;*
*List<TagSummary> expectedTagSummaryList;*
*List<ZoneStatus> expectedZoneStatusList;*
*List<DeptRecountStatus> expectedDeptRecountStatusList;*
*try*
*{*
*if((tagMessageList != null) && !tagMessageList.isEmpty())*
*{*
*MkClusterParam clusterParam = new MkClusterParam();*
*clusterParam.setSupervisors(1);*
*stormConfig.put(Config.STORM_LOCAL_MODE_ZMQ, false);*
*clusterParam.setDaemonConf(stormConfig);*
*Testing.withTrackedCluster(clusterParam, cluster ->*
*{*
*TopologyBuilder topologyBuilder = new TopologyBuilder();*
*topologyBuilder.setSpout("TagSummaryFakeSpout", new FeederSpout());*
*topologyBuilder.setBolt("TagSummaryBolt", new
TagSummaryBolt()).shuffleGrouping("TagSummaryFakeSpout");*
*StormTopology topology = topologyBuilder.createTopology();*
*MockedSources mockedSources = new MockedSources();*
*for(TagMessage tagMessageUncompressed : tagMessageList)*
*{*
*mockedSources.addMockData("TagSummaryFakeSpout", new
Values(CompressionUtils.compressAndBase64Encode(tagMessageUncompressed)));*
*}*
*Config conf = new Config();*
*conf.setNumWorkers(2);*
*CompleteTopologyParam completeTopologyParam = new CompleteTopologyParam();*
*completeTopologyParam.setMockedSources(mockedSources);*
*completeTopologyParam.setStormConf(conf);*
*Map result = Testing.completeTopology(cluster, topology,
completeTopologyParam);*
*assertEquals(tagMessageList.size(), Testing.readTuples(result,
"TagSummaryFakeSpout").size());*
*});*
*}*
*}*
I am acking the message in the Bolts but still getting Timeout error.
Could someone let me know what the error means and the resolution for this?
Thanks,
Harish.