[英]How to test Storm using Spock when emitting large output Tuples
So I have the following test: 所以我有以下测试:
def "test execute(inputTuple) method emits an outputTuple containing a member ObjectType
retrieved using the entity_id in inputTuple"() {
given:
Tuple inputTuple = Mock(Tuple);
List<String> objectTypeIDsEmittedByPreviousBolt = new ArrayList<String>();
objectTypeIDsEmittedByPreviousBolt.add("member");
objectTypeIDsEmittedByPreviousBolt.add("1196");
1 * inputTuple.getValues() >> objectTypeIDsEmittedByPreviousBolt;
when:
this.bolt.execute(inputTuple);
then:
1 * this.collector.emit(inputTuple, THE_OUTPUT_TUPLE);
1 * this.collector.ack(inputTuple);
}
And I getting the following error which I don't understand. 我收到以下我不明白的错误。 Is the inputTuple not matching or the outputTuple not matching?:
inputTuple不匹配或outputTuple不匹配?:
Too few invocations for:
1 * this.collector.emit( inputTuple, [['response':['status':'OK', ... 'member']]]]) (0 invocations)
Unmatched invocations (ordered by similarity):
1 * <OutputCollector>.emit(Mock for type 'Tuple' named 'inputTuple', [['response':['status':'OK', ...'member']]]])
at org.spockframework.mock.runtime.InteractionScope.verifyInteractions(InteractionScope.java:78)
at org.spockframework.mock.runtime.MockController.leaveScope(MockController.java:76)
at member.bolt.CallConsoleAPIToGetAllObjectTypeInfoBoltTest.test execute(inputTuple) method emits an outputTuple containing a member ObjectType retrieved using the entity_id in inputTuple(CallConsoleAPIToGetAllObjectTypeInfoBoltTest.groovy:63)
This is how this test should probably be written (groovyConsole working example): 这可能是应该编写此测试的方式(groovyConsole工作示例):
@Grab('org.spockframework:spock-core:0.7-groovy-2.0')
@Grab('cglib:cglib-nodep:3.1')
import spock.lang.*
class Test extends Specification {
def "test execute(inputTuple) method emits an outputTuple containing a member ObjectType retrieved using the entity_id in inputTuple"() {
given:
List<String> objectTypeIDsEmittedByPreviousBolt = new ArrayList<String>();
objectTypeIDsEmittedByPreviousBolt.add("member");
objectTypeIDsEmittedByPreviousBolt.add("1196");
Tuple inputTuple = new Tuple(objectTypeIDsEmittedByPreviousBolt);
Bolt bolt = new Bolt()
Collector collector = GroovyMock(Collector)
bolt.collector = collector
when:
bolt.execute(inputTuple);
then:
1 * collector.ack(inputTuple);
}
}
class Bolt {
Collector collector = new Collector()
def execute(o) {
collector.ack(o)
}
}
class Collector {
def ack(o) {
println o
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.