《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所有成员。

相关文章
|
6天前
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
6天前
|
存储 测试技术 数据库
接口测试工具攻略:轻松掌握测试技巧
在互联网快速发展的今天,软件系统的复杂性不断增加,接口测试工具成为确保系统稳定性的关键。它如同“翻译官”,模拟请求、解析响应、验证结果、测试性能并支持自动化测试,确保不同系统间信息传递的准确性和完整性。通过Apifox等工具,设计和执行测试用例更加便捷高效。接口测试是保障系统稳定运行的第一道防线。
|
6天前
|
Web App开发 JSON 测试技术
API测试工具集合:让接口测试更简单高效
在当今软件开发领域,接口测试工具如Postman、Apifox、Swagger等成为确保API正确性、性能和可靠性的关键。Postman全球闻名但高级功能需付费,Apifox则集成了API文档、调试、Mock与自动化测试,简化工作流并提高团队协作效率,特别适合国内用户。Swagger自动生成文档,YApi开源但功能逐渐落后,Insomnia界面简洁却缺乏团队协作支持,Paw仅限Mac系统。综合来看,Apifox是国内用户的理想选择,提供中文界面和免费高效的功能。
|
1月前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
106 11
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
83 3
|
3月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
95 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
4月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
296 7
Jmeter实现WebSocket协议的接口测试方法

热门文章

最新文章