Nebula - Test ecosystems
Nebula is a DSL for quickly defining test ecosystems - a combination of docker images and associated behaviour.
Use Nebula when you want to spin up some containers, and prepare them with state or behaviour.
Nebula lets you define behaviour for your stacks using Kotlin.
For example:
stack {
// Start a Kafka broker which emits a message every 100ms
kafka {
producer("100ms".duration(), "stockQuotes") {
jsonMessage {
mapOf(
"symbol" to listOf("GBP/USD", "AUD/USD", "NZD/USD").random(),
"price" to Random.nextDouble(0.8, 0.95).toBigDecimal()
)
}
}
}
// start an HTTP server which responds on /hello
http {
get("/hello") { call ->
call.respondText("Hello, World!")
}
}
Under the hood, Nebular uses TestContainers to pull in and start the relevant containers, then scripts them.
Use Nebula to:
- Define a Kafka broker that emits a message periodically
- Deploy a test S3 instance on
localstack
with preconfigured content - Script the deployment of a full db, primed with data, which accepts writes
Nebula is part of the test and demo infrastructure at Orbital
Running as a docker container
This starts Nebula as in http server mode, listening on port 8099
docker run -v /var/run/docker.sock:/var/run/docker.sock --privileged --network host orbitalhq/nebula
- Because Nebula launches other docker images, we need
privileged
access, along with access to the docker daemon - Also, for you to be able to communicate with the downloaded images, the container runs within the
host
network
Getting code completion
Nebula is a Kotlin DSL wrapper, so when working in IntelliJ you can get full code completion for Nebula.
First, fetch the DSL JAR from the Orbital repository:
mvn dependency:get -Dartifact=com.orbitalhq.nebula:nebula-dsl:1.0-SNAPSHOT -DremoteRepositories=https://repo.orbitalhq.com/snapshot
Enabling Nebula support in IntelliJ settings
- Go to Preferences -> Build, Execution, Deployment -> Compiler -> Kotlin Compiler
- At the bottom you will find a section Kotlin Scripting
- Complete the field:
Script definition template classes to load explicitly
:com.orbitalhq.nebula.NebulaScript
- Complete the field:
Classpath required for loading script definition template classes
:<PATH_TO_YOUR_M2_REPO>/.m2/repository/com/orbitalhq/nebula/nebula-dsl/1.0-SNAPSHOT/nebula-dsl-1.0-SNAPSHOT.jar
Then:
- Go to Preferences -> Language & Frameworks -> Kotlin -> Kotlin Scripting
- Make sure the script template Nebula is active and above the default Kotlin Script
- Apply changes
Alternative: Enabling Nebula support via .idea files
In your project, add or edit a file at .idea/kotlinc.xml
:
<component name="KotlinCompilerSettings">
<option name="scriptTemplates" value="com.orbitalhq.nebula.NebulaScript" />
<option name="scriptTemplatesClasspath" value="$MAVEN_REPOSITORY$/com/orbitalhq/nebula-dsl/1.0-SNAPSHOT/nebula-dsl-1.0-SNAPSHOT.jar" />
</component>