Testing Kafka Streams Topologies
Learn how to write unit tests for Kafka Streams topologies using TopologyTestDriver.
We'll cover the following
Every time we add or change the logic in our Kafka Streams topology, we should verify that our changes have the correct outcomes. This verification can be done by:
Starting a Kafka cluster
Running the entire application
Publishing input messages using the producer CLI
Reading the output message using the consumer CLI
While we should do this at least once or twice to verify all the parts of the system are playing correctly together, performing this for every change we make will become very cumbersome. If we want to automatically ensure that our topology behaves as we intended it to, we should run unit tests that test the topology’s behavior.
Luckily, we can do it quite easily! Kafka Streams has a test utilities library which comes with a TopolgyTestDriver
class that allows us to quickly and conveniently test our topologies.
Adding the test utils dependency
Add the line below to the build.gradle
file in the dependencies
closure (under line 19, for example):
Get hands-on with 1400+ tech skills courses.