(给ImportNew加星标,提高Java技能)
编译:ImportNew/覃佑桦
dzone.com/articles/testing-spring-boot-asynchronous-application-using
本文介绍了使用 EmbeddedKafka 和 Awaitility 测试 Spring Boot 应用的不同方法。
测试同步调用程序时,主要工作是“调用并等待”。调用指定 API 或 endpoint,然后等待响应。测试代码会阻塞主线程执行,直到 API 返回响应结果。处理完成后,把得到的响应与预期结果进行比较。
与同步程序或阻塞式调用的程序相比,异步程序的测试方式有所不同,无需阻塞主线程执行。简单地说,异步程序不会等待 API 响应。我们需要手动处理测试代码让执行保持在某个执行节点,并等待所有非阻塞操作的执行结果。在这个阶段可以使用断言。
管理不同的线程与并发问题,编写简洁易读的单元测试并非易事。
可以通过几种方式为 Spring Boot 编写测试:用 Kafka 与 Spring Cloud Stream 的微服务连接。
让我们设计一个简单的例子。
示例
producer bean 向 Kafka topic 发送消息。
package com.techwording.scs;
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.messaging.Source;
@EnableBinding(Source.class)
public class Producer {
private Source mySource;
public Producer(Source mySource) {
super();
this.mySource = mySource;
}
public Source getMysource() {
return mySource;
}
public void setMysource(Source mysource) {
mySource = mysource;
}
}
consumer bean 会监听 Kafka topic 并接收消息。
@EnableBinding(Sink.class)
public class Consumer {
private String receivedMessage;
@StreamListener(target = Sink.INPUT)
public void consume(String message) {
receivedMessage = message;
latch.countDown();
}
public String getReceivedMessage() {