gtest实现架构简单分析

本文主要介绍了在公司移植并修改gtest测试框架的过程,增加了命令行选项--gtest_order_filter以控制test case运行顺序,引入参数传递机制和test的重复执行功能。作者详细探讨了gtest的注册和运行机制,特别是静态变量动态初始化的实现方式,以及C++编译器对此的特殊处理。文章还提出了对gtest核心部分调度所有case运行的流程图分析。
摘要由CSDN通过智能技术生成

  公司现在需要一套成型的测试框架,选中了现在开源的gtest测试框架,公司将这个任务交给了我,要在移植gtest框架基础上进行修改,增加新的框架功能,这几天一直在看gtest源码,不懂C++,看起来有点难,不过还是有一些感悟,写下来以备后用

  gtest测试框架是在不同平台上(Linux,Mac OS X,Windows,Cygwin,Windows CE和Symbian)为编写C++测试而生成的。它是基于xUnit架构的测试框架,丰富的断言集,用户定义的断言,death测试,

致命与非致命的失败,类型参数化测试,各类运行测试的选项和XML的测试报告。


经过一段时间的开发,在gtest原框架基础上添加了本公司自己需求的框架功能。

新功能主要有:

(1)命令行选项增加--gtest_order_filter,与原有的--gtest_filter过滤选项配合,可以指定选中test case的运行顺序,便于运行固定顺序的测试

(2)增加一套test参数传递机制,使用INI文件为所有case配置参数,参数支持多种类型,gtest架构中加入利用静态变量动态初始化的参数注册、运行前参数分析、运行中获取参数等功能,用户仅需注册以及获取即可,还可列出所有参数,并根据注册参数生成INI模板

(3)支持test unit、test case、test info这3级每一项的repeat,便于针对某一项反复测试,repeat次数由INI中指定,并且test info支持repeat时有多套参数,每一次repeat传入参数不一样。

对于死亡测试,公司暂时不需要这个功能,因此没有细看

以我的理解,gtest的运行分为大体分为2部分,注册和运行,首先来说注册


1 test case register —— TEST_F/TEST

对于test case,我们是通过使用宏TEST/TEST_F等宏定义来将断言语句进行注册的。咱们以TEST_F为例,如下:

47 TEST_F(Zk_Env_test, zk1)
48 {
49     EXPECT_EQ(1, test_func(1, 2));
50 }

48-50行就是咱们test case的函数体&#

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
GTest是一个功能强大的C++测试框架,它可以用于编写各种类型的单元测试,包括数据驱动测试。数据驱动测试是一种测试方法,它基于输入数据和预期输出结果的一组测试用例,执行相同的测试代码,以便针对不同的输入数据运行测试。这样可以减少测试代码的重复性,提高测试效率。 下面是一个简单的示例,演示如何使用GTest实现数据驱动测试: ```cpp #include <gtest/gtest.h> // 定义数据结构,包含输入和预期输出 struct TestData { int input; int expected_output; }; // 定义测试类,继承自testing::TestWithParam class MyTest : public testing::TestWithParam<TestData> { }; // 定义测试数据,包含多组输入和预期输出 TestData test_data[] = { {1, 2}, {2, 4}, {3, 6}, }; // 注册测试用例,使用TEST_P宏定义 TEST_P(MyTest, TestMultiplication) { // 获取当前测试数据 TestData data = GetParam(); // 执行测试代码 int result = data.input * 2; // 验证预期输出是否正确 ASSERT_EQ(result, data.expected_output); } // 注册测试数据,使用INSTANTIATE_TEST_CASE_P宏定义 INSTANTIATE_TEST_CASE_P(MyTestInstance, MyTest, testing::ValuesIn(test_data)); ``` 在上面的示例中,我们首先定义了一个TestData结构体,用于封装输入数据和预期输出。然后,我们定义了一个测试类MyTest,它继承自testing::TestWithParam,这允许我们为每个测试用例提供不同的测试数据。接下来,我们定义了测试数据test_data,它包含多组输入和预期输出。然后,我们使用TEST_P宏定义注册了一个测试用例TestMultiplication,它使用GetParam()方法获取当前测试数据,执行测试代码,然后使用ASSERT_EQ宏验证预期输出是否正确。最后,我们使用INSTANTIATE_TEST_CASE_P宏定义注册了测试数据,它使用testing::ValuesIn将测试数据作为参数传递给测试用例。 使用上述方法,我们可以轻松地实现数据驱动测试,并且可以在一次测试运行中执行多组测试用例。这样可以大大提高测试效率,减少测试代码的重复性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值