《Storm实时数据处理》一1.8 对Bolt进行单元测试

简介:

本节书摘来华章计算机《Storm实时数据处理》一书中的第1章 ,第1.8节,(澳)Quinton Anderson 著 卢誉声 译更多章节内容可以访问云栖社区“华章计算机”公众号查看。

1.8 对Bolt进行单元测试

对于任何产品交付来说,单元测试都是其重要组成部分,我们也必须对Bolt中实现的逻辑进行单元测试。

1.8.1 准备工作

单元测试中有一种很常用的技术叫做Mock,它允许你动态生成依赖对象的假实例,这样才能保证对一个特定类进行准确的单元测试。本书通过JUnit 4和JMock来演示单元测试。请花些时间阅读JMock使用方法,网址是 http://jmock.org/cookbook.html

1.8.2 实战

Step01 在src/test/java目录下创建storm.cookbook包,然后创建StormTestCase类。该类是一些初始化代码的抽象类:
image

Step02 创建TestRepeatVisitBolt类,并继承StormTestCase,然后使用参数化执行器注解来标记它:
image

Step03 execute方法中涵盖了类的测试用例逻辑:
image

Step04 接下来,我们还需要定义一些参数:
image

Step05 在使用Redis进行测试之前,必须初始化一些基本配置的值:
image

保留测试完成后栈中的数据总是有用的,这样便于复查和调试逻辑。我们只要在下一次测试执行时清理栈中的数据就好了。

1.8.3 解析

首先,单元测试是由一组测试数据驱动的测试。这就是说我们能在测试不同用例的时候免去许多无谓和重复的操作。在测试运行之前会将静态数据写入Redis 数据库中,保证了测试的正确运行。接着测试程序就会一行一行地执行参数化的测试数据,并验证许多不同的用例。
JMock负责Mock收集器及Bolt发送的Tuple。然后通过Mock的对象与对象之间的交互来定义我们预期执行的操作:
image

我们应该把Expectations对象内的代码当做描述性的语言来理解。比如方法体第一行的意思就是:希望Tuple的getStringByField方法被精确地调用一次(必须只被调用一次),而且必定会返回一个值给被测试的对象。
这种机制能够让我们准确地测试Bolt。
还有很多种不同的单元测试方法,我们通常会利用数据库来实现测试。除非万不得已,还是建议Mock所有类的依赖项,这样才能实现真正意义上的单元测试。对于“地理位置信息Bolt”的resolver抽象结构来说,我们完全可以Mock所有成员。

相关文章
|
16天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
66 11
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
69 3
|
3月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
82 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
4月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
278 7
Jmeter实现WebSocket协议的接口测试方法
|
4月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
289 3
快速上手|HTTP 接口功能自动化测试
|
4月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
60 5
|
3月前
|
JavaScript 前端开发 API
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
50 0