《测试驱动的嵌入式C语言开发》——2.3节CppUTest:一个用C++实现的自动化单元测试框架

简介: 本节书摘来自华章社区《测试驱动的嵌入式C语言开发》一书中的第2章,第2.3节CppUTest:一个用C++实现的自动化单元测试框架,作者:(美)James W. Grenning,更多章节内容可以访问云栖社区“华章社区”公众号查看

2.3 CppUTest:一个用C++实现的自动化单元测试框架
现在你已经见过了Unity,接下来我会快速介绍一下CppUTest,同时也是我更倾向于使用的对C和C++代码进行单元测试的自动化测试框架。事实上,不仅因为它是一个功能全面的测试框架,同时也因为我是CppUTest的作者之一。本书开始的几个例子会用Unity,在第8章之后会使用CppUTest。
CppUTest是为了支持在多种操作系统上开发嵌入式软件而特别设计的。CppUTest的宏被设计成不需要了解C++也可以写测试用例。这使得C程序员更容易用这个测试框架。
CppUTest只使用C++语言中主要的那部分子集,这种选择很好地适应了那些编译器不能完全支持全部C++语言特性的嵌入式开发。你会看到用Unity和CppUTest写出的单元测试几乎一模一样。你当然可以选择任意一个测试框架来进行你的产品开发。
用CppUTest、写sprintf测试用例
以下用CppUTest写的测试用例和在2.2节中用Unity写的sprintf()测试用例功能相当:


92a765aa89a6ec32a46527ea2df7f54dd852e5c1

除了那些宏的名字有些不同外,测试用例是一样的。
用CppUTest写的sprintf的测试夹具
让我们来看一下在2.2节中,Unity写的测试夹具的例子若用CppUTest写会是什么样子。


bbb760ffd3768e9a970becd712cf9b848b9d1562


26ce41a2ef91bfbcd78cab6ff61877aa55036bfb

还是非常相似,表达了相同的概念。格式上的一点不同是,CppUTest的TEST_GROUP紧接下来是用一组大括号来包起共享数据声明和函数。所有大括号包起来的东西都是TEST_GROUP的一部分,并且对于测试组中的每个TEST()来讲都是可以访问的。共享数据(output、expected和length)在一个叫做setup()的特殊辅助函数中进行初始化。正如你猜的那样,它在每个TEST()之前都会先被调用一下。另一个特别的函数teardown()会在每个TEST()之后调用。在本例中,没有使用teardown()函数。expect()和given()是自由格式的辅助函数,对于同个一TEST_GROUP中的所有TEST()用例都可以访问。
以下重构过的测试用例和我们的Unity测试用例相同:


be2e325d695ba1dbf1189316cf474de6abc88ae2

CppUTest的一个优势是,测试是自动安装的。它不需要任何额外的脚本来生成测试容器或者手工来写如RUN_TEST_CASE()、TEST_GROUP_RUNNER()和RUN_TEST_GROUP()这些东西。一点微小的区别是用来断言的宏不太一样。每个测试框架都有自己的一套宏,尽管功能上其实有重复。
你可能会发现Unity和CppUTest的宏和测试结构看上去很相似。这并不奇怪,它们都沿用了一种很不错的模式。我第一次是在JUnit中看到这种模式,JUnit是一种Java语言的测试框架。更细节的原因是我也曾为Unity项目中测试夹具宏的部分作出过贡献。
CppUTest的输出
正如在Unity部分就讲解过的,测试在这里被作为make自动化构建的一部分来运行。测试输出看起来是这样的:


a31e7c52e47f23ce5cb7c0fbbef779446e764c4a

失败信息会报告出错条件的行号、出错测试用例的名字和出错的原因。请注意在总结部分会包括失败的个数。
就算是你故意在测试用例中加入一个错误,记得一定要把它删掉,否则的话你将有催生一个bug的风险。

相关文章
|
9月前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
372 11
|
5月前
|
Linux C语言 iOS开发
C语言结合AWTK开发HTTP接口访问界面
这样,我们就实现了在C语言中使用libcurl和AWTK来访问HTTP接口并在界面上显示结果。这只是一个基础的示例,你可以根据需要添加更多的功能和优化。例如,你可以添加错误处理机制、支持更多HTTP方法(如POST、PUT等)、优化用户界面等。
334 82
|
7月前
|
数据可视化 关系型数据库 MySQL
嵌入式C++、STM32、MySQL、GPS、InfluxDB和MQTT协议数据可视化
通过本文的介绍,我们详细讲解了如何结合嵌入式C++、STM32、MySQL、GPS、InfluxDB和MQTT协议,实现数据的采集、传输、存储和可视化。这种架构在物联网项目中非常常见,可以有效地处理和展示实时数据。希望本文能帮助您更好地理解和应用这些技术,构建高效、可靠的数据处理和可视化系统。
362 82
|
6月前
|
机器学习/深度学习 设计模式 测试技术
Python 高级编程与实战:构建自动化测试框架
本文深入探讨了Python中的自动化测试框架,包括unittest、pytest和nose2,并通过实战项目帮助读者掌握这些技术。文中详细介绍了各框架的基本用法和示例代码,助力开发者快速验证代码正确性,减少手动测试工作量。学习资源推荐包括Python官方文档及Real Python等网站。
|
8月前
|
人工智能 运维 Prometheus
AIOpsLab:云服务自动化运维 AI,微软开源云服务 AI 框架,覆盖整个生命周期
AIOpsLab 是微软等机构推出的开源框架,支持云服务自动化运维,涵盖故障检测、根本原因分析等完整生命周期。
411 13
AIOpsLab:云服务自动化运维 AI,微软开源云服务 AI 框架,覆盖整个生命周期
|
8月前
|
人工智能 编解码 自然语言处理
AGUVIS:指导模型实现 GUI 自动化训练框架,结合视觉-语言模型进行训练,实现跨平台自主 GUI 交互
AGUVIS 是香港大学与 Salesforce 联合推出的纯视觉 GUI 自动化框架,能够在多种平台上实现自主 GUI 交互,结合显式规划和推理,提升复杂数字环境中的导航和交互能力。
339 8
AGUVIS:指导模型实现 GUI 自动化训练框架,结合视觉-语言模型进行训练,实现跨平台自主 GUI 交互
|
9月前
|
人工智能 Linux API
PromptWizard:微软开源 AI 提示词自动化优化框架,能够迭代优化提示指令和上下文示例,提升 LLMs 特定任务的表现
PromptWizard 是微软开源的 AI 提示词自动化优化框架,通过自我演变和自我适应机制,迭代优化提示指令和上下文示例,提升大型语言模型(LLMs)在特定任务中的表现。本文详细介绍了 PromptWizard 的主要功能、技术原理以及如何运行该框架。
732 8
PromptWizard:微软开源 AI 提示词自动化优化框架,能够迭代优化提示指令和上下文示例,提升 LLMs 特定任务的表现
|
9月前
|
IDE 测试技术 开发工具
10个必备Python调试技巧:从pdb到单元测试的开发效率提升指南
在Python开发中,调试是提升效率的关键技能。本文总结了10个实用的调试方法,涵盖内置调试器pdb、breakpoint()函数、断言机制、logging模块、列表推导式优化、IPython调试、警告机制、IDE调试工具、inspect模块和单元测试框架的应用。通过这些技巧,开发者可以更高效地定位和解决问题,提高代码质量。
952 8
10个必备Python调试技巧:从pdb到单元测试的开发效率提升指南
|
9月前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
2359 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
8月前
|
存储 测试技术 API
pytest接口自动化测试框架搭建
通过上述步骤,我们成功搭建了一个基于 `pytest`的接口自动化测试框架。这个框架具备良好的扩展性和可维护性,能够高效地管理和执行API测试。通过封装HTTP请求逻辑、使用 `conftest.py`定义共享资源和前置条件,并利用 `pytest.ini`进行配置管理,可以大幅提高测试的自动化程度和执行效率。希望本文能为您的测试工作提供实用的指导和帮助。
627 15