C++怎么使用gtest编写单元测试_C++测试驱动开发与Google Test框架

在C++项目中通过CMake集成Google Test实现单元测试与TDD,首先使用FetchContent引入gtest,接着编写被测函数和TEST测试用例,最后构建运行验证结果,遵循“红-绿-重构”流程提升代码质量。

在C++项目中使用Google Test(简称gtest)进行单元测试,是实现测试驱动开发(TDD)的重要手段。它帮助开发者在编写功能代码前先写测试,确保代码的正确性和可维护性。下面介绍如何在C++项目中集成和使用gtest进行单元测试。

安装与配置Google Test

Google Test 是一个开源的C++测试框架,支持主流编译器和平台。使用前需要将其集成到项目中。

推荐方式:通过 CMake 引入 gtest

现代C++项目通常使用CMake管理构建。可以在 CMakeLists.txt 中使用 FetchContent 自动下载并编译gtest:

cmake_minimum_required(VERSION 3.14)
project(MyProject)

include(FetchContent)
FetchContent_Declare(
    googletest
    URL https://github.com/google/googletest/archive/refs/tags/v1.14.0.zip
)
FetchContent_MakeAvailable(googletest)

enable_testing()

add_executable(test_main test/test_main.cpp)
target_link_libraries(test_main gtest_main gmock_main)

这样无需手动安装,构建时会自动获取gtest依赖。

编写第一个测试用例

假设你要测试一个加法函数,可以按以下步骤操作。

1. 编写被测函数(待测试的代码)

src/calculator.h 中声明:

#ifndef CALCULATOR_H
#define CALCULATOR_H
int add(int a, int b);
#endif

src/calculator.cpp 中定义:

#include "calculator.h"
int add(int a, int b) {
    return a + b;
}

2. 编写测试文件

创建 test/test_main.cpp

#include 
#include "../src/calculator.h"

TEST(CalculatorTest, 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();
}

这里使用 TEST 宏定义测试用例,格式为 TEST(测试套件名, 测试用例名)。EXPECT_EQ 用于断言两个值相等。

运行测试与查看结果

使用CMake构建并运行测试:

  • mkdir build && cd build
  • cmake ..
  • make
  • ./test_main

如果所有断言通过,输出类似:

[==========] Running 1 test from 1 test suite.
[----------] Global test environment set-up.
[----------] 1 test from CalculatorTest
[ RUN      ] CalculatorTest.AddTwoNumbers
[       OK ] CalculatorTest.AddTwoNumbers (0 ms)
[----------] 1 test from CalculatorTest (0 ms total)
[==========] 1 test from 1 test suite ran.
[  PASSED  ] 1 test.

若某条断言失败,会明确提示哪一行出错,便于快速定位问题。

测试驱动开发(TDD)流程实践

在TDD中,开发流程是“红-绿-重构”循环:

  • 写测试:先为新功能写一个失败的测试(红)
  • 实现代码:编写最简代码让测试通过(绿)
  • 重构:优化代码结构,保持测试通过

例如,你想实现一个 isEven 函数:

TEST(MathUtilTest, IsEvenReturnsTrueForEvenNumbers) {
    EXPECT_TRUE(isEven(4));
    EXPECT_TRUE(isEven(0));
    EXPECT_FALSE(isEven(3));
}

此时编译会报错,因为 isEven 未定义。接着创建函数并实现逻辑,直到测试通过。

基本上就这些。使用gtest配合CMake,能高效地在C++项目中实施单元测试和TDD,提升代码质量。关键是坚持先写测试,再写实现,形成良好的开发习惯。