0

0

c++怎么使用Catch2测试框架_C++单元测试与Catch2实践指南

下次还敢

下次还敢

发布时间:2025-11-10 18:02:02

|

681人浏览过

|

来源于php中文网

原创

Catch2是轻量级C++测试框架,仅需头文件即可使用,支持CMake集成。通过REQUIRE断言、SECTION分组、Approx浮点比较及自定义类型输出,实现高效单元测试,提升代码可维护性。

c++怎么使用catch2测试框架_c++单元测试与catch2实践指南

在C++开发中,单元测试是确保代码质量的重要手段。Catch2 是一个轻量级、头文件-only 的现代C++测试框架,使用简单且功能强大,适合从小型项目到大型工程的测试需求。本文将带你快速上手 Catch2,并展示如何在实际项目中进行有效的单元测试。

1. 安装与配置 Catch2

Catch2 的最大优势之一是“头文件即用”,不需要编译或链接复杂的库。

说明:Catch2 仅需一个头文件即可运行测试。

获取方式有以下几种:

  • 直接下载 catch2.hpp:从官方 GitHub 仓库(https://github.com/catchorg/Catch2)下载单头文件版本 catch_amalgamated.hpp,放入项目 include 目录。
  • 使用包管理器:如 vcpkg 或 Conan 可以自动集成 Catch2 到项目中。
  • CMake 集成:通过 FetchContent 自动拉取:

示例 CMakeLists.txt 配置片段:

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

include(FetchContent)
FetchContent_Declare(
  Catch2
  GIT_REPOSITORY https://github.com/catchorg/Catch2.git
  GIT_TAG        v3.4.0
)
FetchContent_MakeAvailable(Catch2)

添加测试可执行文件

add_executable(test_example test.cpp) target_link_libraries(test_example Catch2::Catch2)

2. 编写第一个测试用例

创建一个测试文件,比如 test.cpp,包含 Catch2 头文件并开始编写测试。

基础结构如下:

#define CATCH_CONFIG_MAIN
#include "catch2/catch_test_macros.hpp"

// 被测函数 int add(int a, int b) { return a + b; }

TEST_CASE("Addition works", "[math]") { REQUIRE(add(2, 3) == 5); REQUIRE(add(-1, 1) == 0); }

说明:REQUIRE 用于断言条件必须为真,否则测试失败。

编译并运行:

Narration Box
Narration Box

Narration Box是一种语音生成服务,用户可以创建画外音、旁白、有声读物、音频页面、播客等

下载
g++ -std=c++17 test.cpp -o test && ./test

输出会显示测试通过情况,包括分组标签 [math] 和测试名称。

3. 使用 SECTION 组织子测试

当一个测试用例需要覆盖多个分支时,SECTION 可以拆分逻辑路径。

例如测试字符串处理函数:

TEST_CASE("String concatenation", "[string]") {
    std::string a = "hello";
    std::string b = "world";
SECTION("Normal concat") {
    REQUIRE(a + " " + b == "hello world");
}
SECTION("Empty left") {
    REQUIRE("" + b == "world");
}
SECTION("Both empty") {
    REQUIRE("" + "" == "");
}

}

每个 SECTION 独立运行,互不影响,便于定位问题。

4. 测试浮点数与自定义类型

浮点比较需注意精度问题,Catch2 提供了 Approx 工具

TEST_CASE("Floating point comparisons", "[float]") {
    double result = (0.1 + 0.2) * 10;
    REQUIRE(result == Approx(3.0));
}

对于自定义类型,可通过重载 operator== 或提供字符串转换辅助调试输出。

struct Point { int x, y; };
bool operator==(const Point& a, const Point& b) {
    return a.x == b.x && a.y == b.y;
}

// 启用 Catch2 输出自定义类型 namespace Catch { template<> struct StringMaker { static std::string convert(const Point& p) { return "(" + std::to_string(p.x) + "," + std::to_string(p.y) + ")"; } }; }

基本上就这些。Catch2 上手快、结构清晰,配合 CMake 可轻松集成进构建流程。合理使用标签、SECTION 和 Approx,能显著提升测试可维护性。不复杂但容易忽略的是保持测试独立性和命名清晰。

相关专题

更多
require的用法
require的用法

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

456

2023.11.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

547

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

539

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

158

2025.07.29

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

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

精品课程

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

共94课时 | 5.7万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.6万人学习

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

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