我有这个测试,它在端口7000
和唯一的端点内启动服务,我做了一个失败的断言:
@Test
fun `javalin assertion should fail`() {
Javalin.create()
.get("/") { assertTrue(false) }
.start()
newHttpClient().send(
HttpRequest.newBuilder()
.uri(URI.create("http://localhost:7000/"))
.GET().build(),
discarding()
)
}
问题是测试总是通过(但它应该失败):
(运行时会发生相同的行为./gradlew test
)
...即使有一个控制台输出声称测试失败:
[Test worker] INFO io.javalin.Javalin - Listening on http://localhost:7000/
[Test worker] INFO io.javalin.Javalin - Javalin started in 356ms \o/
[qtp2100106358-22] ERROR io.javalin.Javalin - Exception occurred while servicing http-request
org.opentest4j.AssertionFailedError: expected: <true> but was: <false>
at org.junit.jupiter.api.AssertionUtils.fail(AssertionUtils.java:55)
..
可能它正在另一个线程中运行,但我想知道是否有办法将它附加到相同的上下文中。(奇怪的是,在我的应用程序的另一种情况下——我无法隔离——它正确地失败了。)