springboot监听kafka的topic_用 Kafka 和 Awaitility 测试 Spring Boot 应用

(给ImportNew加星标,提高Java技能)

编译:ImportNew/覃佑桦

dzone.com/articles/testing-spring-boot-asynchronous-application-using

4a59e332e2c23ca06ffe81581bc125a6.png

本文介绍了使用 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() {
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值