0

0

c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架

穿越時空

穿越時空

发布时间:2025-12-01 13:39:06

|

526人浏览过

|

来源于php中文网

原创

c++kquote>Catch2是C++的轻量级单头文件测试框架,支持TDD与BDD风格,通过包含catch_amalgamated.hpp并定义CATCH_CONFIG_MAIN即可使用;TEST_CASE定义测试用例,REQUIRE进行断言,支持标签分类如[vector];SCENARIO、GIVEN、WHEN、THEN实现自然语言描述的BDD测试,提升可读性;编译为可执行文件后可运行所有或按标签筛选测试,如./run_tests [bdd],合理使用标签和场景划分增强维护性。

c++如何使用catch2编写单元测试_c++简洁易用的bdd风格测试框架

C++中使用Catch2编写单元测试非常直观,尤其适合偏好BDD(行为驱动开发)风格的开发者。Catch2是一个单头文件的测试框架,无需复杂配置,只需包含头文件即可开始写测试。它支持TDD和BDD两种风格,语法简洁,输出清晰。

安装与引入 Catch2

最简单的方式是下载单头文件版本:catch_amalgamated.hpp,将其放入项目 include 目录中。

从官方 GitHub 仓库获取:

在项目中引入:

立即学习C++免费学习笔记(深入)”;

#define CATCH_CONFIG_MAIN
#include "catch_amalgamated.hpp"

编写第一个测试用例(TDD 风格)

使用 TEST_CASE 定义测试,用 REQUIRE 断言结果:

TEST_CASE("Vector can be sized and resized", "[vector]") {
    std::vector v(5);

    REQUIRE(v.size() == 5);
    REQUIRE(v.capacity() >= 5);

    v.resize(10);

    REQUIRE(v.size() == 10);
    REQUIRE(v.capacity() >= 10);
}

[vector] 是标签,用于分类和筛选测试。

使用 BDD 风格编写测试

Catch2 支持 Given/When/Then 的 BDD 写法,让测试更贴近自然语言描述。

AItools.fyi
AItools.fyi

找到让生活变得更轻松的最佳AI工具!

下载

示例:模拟一个银行账户取款行为

SCENARIO("Account withdrawal behavior", "[bank][bdd]") {
    GIVEN("an account with balance of 100") {
        int balance = 100;

        WHEN("the user withdraws 30") {
            int withdrawal = 30;
            balance -= withdrawal;

            THEN("the balance should be 70") {
                REQUIRE(balance == 70);
            }
        }

        WHEN("the user withdraws 150") {
            int withdrawal = 150;

            THEN("the balance should go negative") {
                balance -= withdrawal;
                REQUIRE(balance == -50);
            }
        }
    }
}

BDD 风格提升可读性,特别适合团队协作和业务逻辑验证。

组织与运行测试

编译测试文件为可执行程序,例如:

g++ -std=c++17 test_main.cpp -o run_tests

运行所有测试:

./run_tests

按标签运行部分测试:

./run_tests [bdd]

查看可用测试列表:

./run_tests --list-tests

基本上就这些。Catch2 让 C++ 单元测试变得轻量又高效,BDD 风格进一步增强了测试的表达力和维护性。不复杂但容易忽略的是标签的合理使用和测试场景的清晰划分。

相关专题

更多
require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

387

2026.01.21

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2057

2024.08.16

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

117

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

178

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号