io.javalin.testtools.TestTool.kt Maven / Gradle / Ivy
package io.javalin.testtools
import io.javalin.Javalin
import io.javalin.config.Key
import io.javalin.util.JavalinLogger
import okhttp3.OkHttpClient
import java.io.ByteArrayOutputStream
import java.io.PrintStream
import java.util.*
object DefaultTestConfig {
@JvmStatic var clearCookies: Boolean = true
@JvmStatic var captureLogs: Boolean = true
@JvmStatic var okHttpClient: OkHttpClient = OkHttpClient()
}
data class TestConfig @JvmOverloads constructor(
val clearCookies: Boolean = DefaultTestConfig.clearCookies,
val captureLogs: Boolean = DefaultTestConfig.captureLogs,
val okHttpClient: OkHttpClient = DefaultTestConfig.okHttpClient
)
class TestTool(private val testConfig: TestConfig = TestConfig()) {
companion object {
@JvmField val TestLogsKey: Key = Key("testlogs")
}
class RunResult(val logs: String?, val exception: Throwable?)
@JvmOverloads
fun test(app: Javalin = Javalin.create(), config: TestConfig = this.testConfig, testCase: TestCase) {
val result: RunResult = runAndCaptureLogs(config) {
app.start(0)
val http = HttpClient(app, config.okHttpClient)
testCase.accept(app, http) // this is where the user's test happens
if (config.clearCookies) {
val endpointUrl = "/clear-cookies-${UUID.randomUUID()}"
app.delete(endpointUrl) { it.cookieMap().forEach { (k, _) -> it.removeCookie(k) } }
http.request(endpointUrl) { it.delete() }
}
app.stop()
}
app.unsafeConfig().appData(TestLogsKey, result.logs)
if (result.exception != null) {
JavalinLogger.error("JavalinTest#test failed - full log output below:\n" + result.logs)
throw result.exception
}
}
fun captureStdOut(runnable: Runnable): String? = runAndCaptureLogs(this.testConfig, runnable).logs
private fun runAndCaptureLogs(testConfig: TestConfig = this.testConfig, testCode: Runnable): RunResult {
var exception: Throwable? = null
val out = ByteArrayOutputStream()
val printStream = PrintStream(out)
val oldOut = System.out
val oldErr = System.err
if (testConfig.captureLogs) {
System.setOut(printStream)
System.setErr(printStream)
}
try {
testCode.run()
} catch (t: Throwable) {
exception = when (t) {
is Exception -> t
is AssertionError -> t
else -> Exception("Unexpected Throwable in test. Message: '${t.message}'", t)
}
} finally {
System.out.flush()
System.err.flush()
System.setOut(oldOut)
System.setErr(oldErr)
}
return RunResult(out.toString(), exception)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy