繁体   English   中英

如何在Vert.x中对事件处理程序进行单元测试(来自事件总线)?

[英]How do I unit test event handlers (from the event bus) in Vert.x?

我是Vert.x 3的新手,我正在尝试为简单的事件处理程序编写单元测试。 现在,我要做的就是检查被测Verticle是否委托了正确的组件,该组件是使用Mockito作为模拟创建的。

我的测试代码如下所示:

@Rule
public final RunTestOnContext vertxRule = new RunTestOnContext();

@Before
public void setUp(TestContext context) {
    vertx = vertxRule.vertx();
    //verticle is set up with mock delegate before deployment
    vertx.deployVerticle(verticle);
}

@After
public void tearDown(TestContext context) {
    vertx.close(context.asyncAssertSuccess());
}

@Test
public void testDelegate(TestContext context) {
    EventBus eventBus = vertx.eventBus();
    Event event = new Event("id", "description")
    eventBus.publish("event.channel", Json.encode(event));

    //Mockito.verify
    verify(delegate).invokeMethod(anyString(), anyString());
}

Veticle包含类似于以下内容的代码:

private Delegate delegate;

@Override
public void start(Future<Void> future) throws Exception {
    vertx.eventBus().consumer("event.channel", message -> {
        logger.info("received!");
        Event event = Json.decodeValue(message.body().toString(), Event.class);
        delegate.invokeMethod(event.getId(), event.getDescription());
    });
}

但是,每次运行测试时,我总是会收到一条错误消息,指出未调用该模拟程序。 我确信模拟对象已正确注入,因为如果我在事件总线构造外部调用它,则测试通过。 另外,代码记录了received! 信息,所以我确定测试执行到了这一点。 我只是不确定为什么在测试结束时,报告会说与模拟对象之间没有交互。

验证在调用Mock之前执行。 您应该在测试中有一个异步,然后等待验证。 像这样:

@Test
public void testDelegate(TestContext context) {
    EventBus eventBus = vertx.eventBus();
    Event event = new Event("id", "description")
    Async async = context.async();
    eventBus.publish("event.channel", Json.encode(event) ,done ->async.complete());


    async.await()

    //Mockito.verify
    verify(delegate).invokeMethod(anyString(), anyString());
}

然后,您的顶点必须在调用模拟之后通过执行message.reply(...)来回复收到的消息。

在您的评论后编辑,关于无回复

我尝试了以下代码,该代码使用全局变量(难看)进行同步(请注意,这是io.vertx.core.Future):

@RunWith(VertxUnitRunner.class)
public class StackTest {

    private Vertx vertx;
    public static Future<String> synchronisation = Future.future();

    @Before
    public void setUp(TestContext context) {
        vertx = Vertx.vertx();
        vertx.deployVerticle(new StackVerticle());
    }

    @Test
    public void testPublish(TestContext context){
        vertx.eventBus().publish("topic","message");
        Async async = context.async();
        synchronisation.setHandler(event -> async.complete());
        async.await();
    }
}  

和测试垂直线(必须由您的模拟物触发sync.complete):

public class StackVerticle extends AbstractVerticle {
    @Override
    public void start() throws Exception {
        vertx.eventBus().consumer("topic",received ->{
            System.out.println("received");
            StackTest.synchronisation.complete("done");
        });
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM