Java 部署verticle时上下文问题的Vertx测试

Java 部署verticle时上下文问题的Vertx测试,java,vert.x,Java,Vert.x,所以这有点鬼鬼祟祟,并不是100%都会发生,但情况是这样的: 我创建了一个JUnit集成类,声明了一个规则在上下文中运行,然后从规则中提取vertx对象。然后我将新的垂直轴部署到vertx,如果尝试部署3-4个以上的垂直轴,我会为每个垂直轴提供以下信息: Jan 09, 2017 2:43:33 PM io.vertx.core.impl.ContextImpl SEVERE: Unhandled exception java.lang.IllegalStateException: Result

所以这有点鬼鬼祟祟,并不是100%都会发生,但情况是这样的:

我创建了一个
JUnit
集成类,声明了一个
规则
在上下文中运行,然后从规则中提取
vertx
对象。然后我将新的垂直轴部署到
vertx
,如果尝试部署3-4个以上的垂直轴,我会为每个垂直轴提供以下信息:

Jan 09, 2017 2:43:33 PM io.vertx.core.impl.ContextImpl
SEVERE: Unhandled exception
java.lang.IllegalStateException: Result is already complete: succeeded
    at io.vertx.core.impl.FutureImpl.checkComplete(FutureImpl.java:164)
    at io.vertx.core.impl.FutureImpl.complete(FutureImpl.java:108)
    at io.vertx.core.impl.FutureImpl.handle(FutureImpl.java:135)
    at io.vertx.core.impl.FutureImpl.handle(FutureImpl.java:23)
    at io.vertx.core.eventbus.impl.EventBusImpl.lambda$callCompletionHandlerAsync$2(EventBusImpl.java:340)
    at io.vertx.core.impl.ContextImpl.lambda$wrapTask$2(ContextImpl.java:316)
    at io.netty.util.concurrent.AbstractEventExecutor.safeExecute(AbstractEventExecutor.java:163)
    at io.netty.util.concurrent.SingleThreadEventExecutor.runAllTasks(SingleThreadEventExecutor.java:418)
    at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:440)
    at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:873)
    at java.lang.Thread.run(Thread.java:745)
导致此问题的代码如下所示:

@RunWith(VertxUnitRunner.class)
public class VertxTest {

    @Rule
    public RunTestOnContext rule = new RunTestOnContext(Vertx::vertx);

    @Test
    public void testLinearExecution(TestContext context) {
        Vertx vertx = rule.vertx();
        vertx.deployVerticle(new AbstractVerticle() {
            @Override
            public void start() throws Exception {
                this.vertx.eventBus().consumer("bla", event -> {});
            }
        });
        vertx.deployVerticle(new AbstractVerticle() {
            @Override
            public void start() throws Exception {
                this.vertx.eventBus().consumer("bla", event -> {});
            }
        });
        vertx.deployVerticle(new AbstractVerticle() {
            @Override
            public void start() throws Exception {
                this.vertx.eventBus().consumer("bla", event -> {});
            }
        });
        vertx.deployVerticle(new AbstractVerticle() {
            @Override
            public void start() throws Exception {
                this.vertx.eventBus().consumer("bla", event -> {});
            }
        });
        vertx.deployVerticle(new AbstractVerticle() {
            @Override
            public void start() throws Exception {
                this.vertx.eventBus().consumer("bla", event -> {});
            }
        });
        vertx.deployVerticle(new AbstractVerticle() {
            @Override
            public void start() throws Exception {
                this.vertx.eventBus().consumer("bla", event -> {});
            }
        });
    }

}
这可能取决于运行它的机器,但我的猜测是,如果它不能复制,请添加更多的人,使其更有可能:

vertx.deployVerticle(new AbstractVerticle() {
    @Override
    public void start() throws Exception {
        this.vertx.eventBus().consumer("bla", event -> {});
    }
});
另一件需要提及的事情是,如果我更改
Vertx Vertx=rule.Vertx()带有
Vertx Vertx=Vertx.Vertx(),我收到控制台的警告消息,但问题消失了


那么,我做错什么了吗?这是一个问题吗?

您使用的是3.3.3版吗。您可能遇到了这个问题:(已在master中修复)

此问题已在当前版本(3.4.1)或更早版本中修复。