首页 > 后端开发 > C++ > 正文

C++如何进行单元测试_C++ Google Test (gtest)框架入门指南

穿越時空
发布: 2025-12-13 08:05:02
原创
997人浏览过
首先介绍如何使用CMake集成Google Test并编写测试用例,接着演示通过TEST宏定义测试套件与用例,利用EXPECT_EQ验证结果,并展示运行输出及命令行参数控制测试执行流程。

c++如何进行单元测试_c++ google test (gtest)框架入门指南

在C++开发中,单元测试是保证代码质量的重要手段。Google Test(简称 gtest)是目前最流行的C++单元测试框架之一,由Google开源,支持跨平台,使用简单且功能强大。本文将带你快速上手如何用 gtest 编写和运行C++单元测试。

安装与配置 Google Test

gtest 支持多种方式集成到项目中,常见方法有源码编译、包管理器安装或通过 CMake 自动获取。

使用 CMake 集成(推荐方式):

在项目的 CMakeLists.txt 中添加以下内容:
cmake_minimum_required(VERSION 3.14)
project(MyTestProject)
<h1>启用 C++17</h1><p>set(CMAKE_CXX_STANDARD 17)</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/6e7abc4abb9f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">C++免费学习笔记(深入)</a>”;</p><h1>使用 FetchContent 获取 gtest</h1><p>include(FetchContent)
FetchContent_Declare(
googletest
URL <a href="https://www.php.cn/link/cb57ba36db3faf9723fcfeade897b7fb">https://www.php.cn/link/cb57ba36db3faf9723fcfeade897b7fb</a>
)
FetchContent_MakeAvailable(googletest)</p><h1>添加主程序或被测代码</h1><p>add_executable(mylib math.cpp)</p><h1>添加测试可执行文件</h1><p>enable_testing()
add_executable(test_math test_math.cpp)
target_link_libraries(test_math gtest_main mylib)</p><h1>注册测试</h1><p>include(GoogleTest)
gtest_discover_tests(test_math)</p>
登录后复制

这样 CMake 会在构建时自动下载并编译 gtest,无需手动安装。

编写第一个测试用例

假设我们有一个简单的加法函数需要测试:

math.h
#ifndef MATH_H
#define MATH_H
int add(int a, int b);
#endif
登录后复制

math.cpp

#include "math.h"
int add(int a, int b) {
    return a + b;
}
登录后复制

test_math.cpp(测试文件)

#include <gtest/gtest.h>
#include "math.h"
<p>// 测试用例:测试 add 函数
TEST(MathTest, AddPositiveNumbers) {
EXPECT_EQ(add(2, 3), 5);
EXPECT_EQ(add(0, 0), 0);
}</p><p>TEST(MathTest, AddNegativeNumbers) {
EXPECT_EQ(add(-1, -1), -2);
EXPECT_EQ(add(-5, 3), -2);
}</p>
登录后复制

说明:

  • TEST(测试套件名, 测试用例名) 定义一个测试。
  • EXPECT_EQ(实际值, 期望值) 判断是否相等,不通过仅记录错误,继续执行。
  • 若想中断测试可用 ASSERT_EQ

运行测试并查看结果

构建项目后运行测试可执行文件(如 test_math),输出类似:

星辰Agent
星辰Agent

科大讯飞推出的智能体Agent开发平台,助力开发者快速搭建生产级智能体

星辰Agent 378
查看详情 星辰Agent
[ RUN      ] MathTest.AddPositiveNumbers
[       OK ] MathTest.AddPositiveNumbers (0 ms)
[ RUN      ] MathTest.AddNegativeNumbers
[       OK ] MathTest.AddNegativeNumbers (0 ms)
<p>SUCCESS: All tests passed.</p>
登录后复制

如果某个断言失败,gtest 会打印具体哪一行出错、期望值与实际值,便于调试。

你也可以使用命令行参数控制测试行为,例如:

  • --gtest_filter=MathTest.*:只运行 MathTest 套件下的测试。
  • --gtest_list_tests:列出所有测试用例。
  • --gtest_repeat=5:重复执行5次。

高级特性简要介绍

gtest 提供丰富的测试功能,以下是常用扩展:

1. 参数化测试(Parametrized Tests)

适用于对同一函数用多组输入进行测试:

class AddTest : public ::testing::TestWithParam<std::tuple<int, int, int>> {};
<p>TEST_P(AddTest, AllCases) {
int a = std::get<0>(GetParam());
int b = std::get<1>(GetParam());
int expected = std::get<2>(GetParam());
EXPECT_EQ(add(a, b), expected);
}</p><p>INSTANTIATE_TEST_SUITE_P(
NormalCases, AddTest,
::testing::Values(
std::make_tuple(2, 3, 5),
std::make_tuple(-1, 1, 0),
std::make_tuple(0, 0, 0)
)
);</p>
登录后复制

2. 测试夹具(Test Fixtures)

当多个测试需要共享初始化/清理逻辑时使用:

class DatabaseTest : public ::testing::Test {
protected:
    void SetUp() override {
        // 初始化资源,如打开数据库连接
    }
<pre class="brush:php;toolbar:false;"><code>void TearDown() override {
    // 清理资源
}

// 可定义共用数据成员
登录后复制

};

然后使用 TEST_F(DatabaseTest, CanConnect) 来引用该夹具。

基本上就这些。掌握 gtest 的基本结构和常用语法后,你可以为 C++ 项目建立起可靠的测试体系,提升代码健壮性。

以上就是C++如何进行单元测试_C++ Google Test (gtest)框架入门指南的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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