0

0

c++ Catch2框架怎么用 c++单元测试新选择【教程】

尼克

尼克

发布时间:2026-01-10 12:23:51

|

246人浏览过

|

来源于php中文网

原创

Catch2 是轻量现代的头文件即用C++单元测试框架,支持BDD风格(SCENARIO/GIVEN/WHEN/THEN)和传统TEST_CASE,通过#define CATCH_CONFIG_MAIN自动生成main,支持标签筛选、参数化测试与夹具。

c++ catch2框架怎么用 c++单元测试新选择【教程】

Catch2 是一个头文件即用的 C++ 单元测试框架,无需编译安装,轻量、现代、表达力强。它支持 BDD 风格(Given-When-Then)和传统 TEST_CASE 写法,语法简洁,错误信息友好,是当前 C++ 项目中非常主流的单元测试选择。

快速上手:单文件集成

只需下载 catch2.hpp(官方推荐从 GitHub Releases 获取最新版),将其放入项目目录或 include 路径下。测试文件中包含它即可:

#define CATCH_CONFIG_MAIN
#include "catch2.hpp"

这行宏定义会自动生成 main() 函数,让测试可直接编译运行。如果你已有 main(),改用 #define CATCH_CONFIG_RUNNER 并自己调用 Catch::Session().run(argc, argv)

写第一个测试:TEST_CASE 和 REQUIRE

TEST_CASE 定义测试用例,用 REQUIRE 做断言(失败会继续执行后续断言);REQUIRE_FALSEREQUIRE_THROWS 等也常用:

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

  • TEST_CASE("加法运算正确", "[math]") {
  •   int a = 2, b = 3;
  •   REQUIRE(a + b == 5);
  •   REQUIRE(a * b == 6);
  • }

方括号内是标签(tag),可用于按功能、模块或优先级筛选运行,例如:./test --tags "[math]"

Sider
Sider

多功能AI浏览器助手,帮助用户进行聊天、写作、阅读、翻译等

下载

组织更复杂的测试:SCENARIO + GIVEN / WHEN / THEN

适合行为驱动开发风格,语义清晰,可读性强:

  • SCENARIO("用户登录流程", "[auth]") {
  •   GIVEN("一个已注册的用户") {
  •     User u{"alice", "pass123"};
  •     WHEN("输入正确密码") {
  •       THEN("应返回登录成功") {
  •         REQUIRE(u.login("pass123") == true);
  •       }
  •     }
  •   }
  • }

注意:GIVEN/WHEN/THEN 只是语义分组宏,不改变执行逻辑,但能显著提升协作与维护体验。

进阶技巧:参数化测试与夹具

TEMPLATE_TEST_CASE 支持多类型测试:

TEMPLATE_TEST_CASE("容器 size() 返回值", "[container]", int, std::string, double) {
  std::vector v{1, 2, 3};
  REQUIRE(v.size() == 3);
}

struct MyTest : Catch::TestSpec::IDCATCH_TEST_CASE_METHOD 可定义带构造/析构的测试夹具(Fixture),复用初始化逻辑。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

typedef和define区别
typedef和define区别

typedef和define区别在类型检查、作用范围、可读性、错误处理和内存占用等。本专题为大家提供typedef和define相关的文章、下载、课程内容,供大家免费下载体验。

107

2023.09.26

define的用法
define的用法

define用法:1、定义常量;2、定义函数宏:3、定义条件编译;4、定义多行宏。更多关于define的用法的内容,大家可以阅读本专题下的文章。

328

2023.10.11

require的用法
require的用法

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

464

2023.11.27

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

306

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

728

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

25

2026.01.09

热门下载

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

精品课程

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

共21课时 | 2.6万人学习

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号