GTest是C++常用单元测试框架,支持断言、参数化测试等功能。通过包管理器或CMake可安装配置,在项目中编写测试用例并使用CMake构建运行,结合丰富断言宏进行验证,推荐与持续集成结合使用。

GTest(Google Test)是C++中广泛使用的单元测试框架,能够帮助开发者编写和运行C++测试用例。它支持断言、参数化测试、死亡测试等功能,使用简单且功能强大。下面介绍如何在C++项目中集成并使用GTest框架。
1. 安装与配置GTest
有多种方式可以引入GTest到你的项目中,常见方法包括使用包管理器或从源码编译。
Ubuntu/Linux系统(使用apt):打开终端执行以下命令:
sudo apt-get install libgtest-dev cmake cd /usr/src/googletest sudo cmake CMakeLists.txt sudo make sudo cp *.a /usr/lib
Windows(使用vcpkg):
立即学习“C++免费学习笔记(深入)”;
如果你使用vcpkg,可以通过以下命令安装:
vcpkg install gtest
通过CMake直接引入(推荐方式):
在项目根目录的CMakeLists.txt中添加:
include(FetchContent) FetchContent_Declare( googletest URL https://github.com/google/googletest/archive/refs/tags/release-1.14.0.zip ) FetchContent_MakeAvailable(googletest)
2. 编写第一个测试用例
创建一个简单的函数并为其编写测试。
example.h
#ifndef EXAMPLE_H #define EXAMPLE_H int add(int a, int b); #endif
example.cpp
#include "example.h"
int add(int a, int b) {
return a + b;
}
test_example.cpp
#include#include "example.h" TEST(MathTest, AddTwoNumbers) { EXPECT_EQ(add(2, 3), 5); EXPECT_EQ(add(-1, 1), 0); EXPECT_EQ(add(0, 0), 0); }
int main(int argc, char **argv) { ::testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS(); }
3. 使用CMake构建项目
在项目目录下创建CMakeLists.txt:
cmake_minimum_required(VERSION 3.14) project(MyTestProject)启用C++17
set(CMAKE_CXX_STANDARD 17)
添加源文件
add_library(example example.cpp)
添加测试可执行文件
enable_testing() add_executable(test_example test_example.cpp) target_link_libraries(test_example example gtest_main)
注册测试
add_test(NAME RunTests COMMAND test_example)
构建步骤:
mkdir build cd build cmake .. make ./test_example
输出会显示测试是否通过。
4. 常用断言和测试类型
GTest提供丰富的断言宏,用于验证各种条件。
基本断言:
- EXPECT_EQ(a, b) / ASSERT_EQ(a, b):判断相等
- EXPECT_NE(a, b):不相等
- EXPECT_LT(a, b):小于
- EXPECT_GT(a, b):大于
- EXPECT_TRUE(condition):条件为真
- EXPECT_FALSE(condition):条件为假
区分EXPECT和ASSERT:
EXPECT_* 失败后继续执行后续语句;ASSERT_* 失败则终止当前测试函数。
其他测试类型:
- TEST_F:用于带测试夹具的类测试
- TEST_P:参数化测试
- Death Tests:验证程序是否崩溃(如 EXPECT_DEATH)
基本上就这些。GTest上手快,配合CMake使用非常方便,适合各类C++项目的单元测试。关键是写好测试用例并持续集成。











