-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathKafkaClientTest.java
More file actions
65 lines (56 loc) · 2.38 KB
/
KafkaClientTest.java
File metadata and controls
65 lines (56 loc) · 2.38 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package com.example.testing.testcontainers;
import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.serialization.StringDeserializer;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Tag;
import org.junit.jupiter.api.Test;
import org.testcontainers.containers.KafkaContainer;
import org.testcontainers.utility.DockerImageName;
import java.time.Duration;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import static org.assertj.core.api.AssertionsForInterfaceTypes.assertThat;
import static org.awaitility.Awaitility.await;
@Tag("testcontainers")
class KafkaClientTest {
private static KafkaContainer kafka;
private static KafkaConsumer<String, String> consumer;
@BeforeAll
static void setup() {
kafka = new KafkaContainer(DockerImageName.parse("confluentinc/cp-kafka:6.2.1"))
.withEnv("KAFKA_AUTO_CREATE_TOPICS_ENABLE", "true")
.withEnv("KAFKA_CREATE_TOPICS", "kafka_topic");
kafka.start();
consumer = new KafkaConsumer<>(Map.of(
ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, kafka.getBootstrapServers(),
ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName(),
ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName(),
ConsumerConfig.GROUP_ID_CONFIG, UUID.randomUUID().toString(),
ConsumerConfig.AUTO_OFFSET_RESET_CONFIG, "earliest"
));
consumer.subscribe(List.of("test-topic"));
}
@Test
void test() {
new KafkaClient(kafka.getBootstrapServers())
.publishMessage("test-topic", "hello world");
await().atMost(Duration.ofSeconds(10L))
.pollInterval(Duration.ofSeconds(1L))
.pollDelay(Duration.ofSeconds(1L))
.ignoreExceptions()
.untilAsserted(() -> {
var pollResult = consumer.poll(Duration.ofMillis(100));
pollResult.forEach(r -> {
assertThat(r.topic()).isEqualTo("test-topic");
assertThat(r.value()).isEqualTo("hello world");
});
});
}
@AfterAll
static void tearDown() {
kafka.stop();
}
}