0

0

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

穿越時空

穿越時空

发布时间:2025-12-13 08:05:02

|

1002人浏览过

|

来源于php中文网

原创

首先介绍如何使用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)

启用 C++17

set(CMAKE_CXX_STANDARD 17)

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

使用 FetchContent 获取 gtest

include(FetchContent) FetchContent_Declare( googletest URL https://www.php.cn/link/cb57ba36db3faf9723fcfeade897b7fb ) FetchContent_MakeAvailable(googletest)

添加主程序或被测代码

add_executable(mylib math.cpp)

添加测试可执行文件

enable_testing() add_executable(test_math test_math.cpp) target_link_libraries(test_math gtest_main mylib)

注册测试

include(GoogleTest) gtest_discover_tests(test_math)

这样 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 
#include "math.h"

// 测试用例:测试 add 函数 TEST(MathTest, AddPositiveNumbers) { EXPECT_EQ(add(2, 3), 5); EXPECT_EQ(add(0, 0), 0); }

TEST(MathTest, AddNegativeNumbers) { EXPECT_EQ(add(-1, -1), -2); EXPECT_EQ(add(-5, 3), -2); }

说明:

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

运行测试并查看结果

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

飞书知识问答
飞书知识问答

飞书平台推出的AI知识库管理和智能搜索工具

下载
[ RUN      ] MathTest.AddPositiveNumbers
[       OK ] MathTest.AddPositiveNumbers (0 ms)
[ RUN      ] MathTest.AddNegativeNumbers
[       OK ] MathTest.AddNegativeNumbers (0 ms)

SUCCESS: All tests passed.

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

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

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

高级特性简要介绍

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

1. 参数化测试(Parametrized Tests)

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

class AddTest : public ::testing::TestWithParam> {};

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); }

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) ) );

2. 测试夹具(Test Fixtures)

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

class DatabaseTest : public ::testing::Test {
protected:
    void SetUp() override {
        // 初始化资源,如打开数据库连接
    }
void TearDown() override {
    // 清理资源
}

// 可定义共用数据成员

};

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

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

相关专题

更多
菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

51

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

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

397

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

118

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

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

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

11

2026.01.21

热门下载

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

精品课程

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

共21课时 | 2.9万人学习

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号