前言:

  1.首先说明gtest中事件的结构层次:

  

  测试程序:一个测试程序只有一个main函数,也可以说是一个可执行程序是一个测试程序。该级别的事件机制会在程序的开始和结束执行。

  测试套件:代表一个测试用例的集合体,该级别的事件机制会在整体的测试案例开始可结束执行。

  测试用例:该级别的事件机制会在每个测试用例开始和结束都执行。

  gtest中的事件机制是指在测试前和测试后提供给用户自行添加操作的机制,而且次机制也可用让同一测试套件下的测试用例共享数据。

  

一、全局的事件机制(针对整个测试程序)

  实现全局的事件机制,需要创建一个自己的类,然后继承testing::Environment类,然后分别实现成员函数SetUp()和TearDown(),同时在main函数内进行调用,即"testing::AddGlobalTestEnvironment(new MyEnvironment);",通过调用函数我们可以添加多个全局的事件机制。

  SetUp()函数是在所有测试开始前执行。

  TearDown()函数是在所有测试结束后执行。

  示例:  

 /***********************************************

     Filename       : test.cpp
Author :
Description :
Create Data : 2018-10-21 00:42:34
Modfiy History : 2018-10-21 00:42:34 ***********************************************/ #include <iostream> #include <gtest/gtest.h> using namespace std; class MyEnvironment0 : public testing::Environment
{
public:
virtual void SetUp()
{
cout << "Global event0 : start" << endl;
} virtual void TearDown()
{
cout << "Global event0 : end" << endl;
}
}; class MyEnvironment1 : public testing::Environment
{
public:
virtual void SetUp()
{
cout << "Global event1 : start" << endl;
} virtual void TearDown()
{
cout << "Global event1 : end" << endl;
}
}; TEST(GlobalTest0, test0)
{
EXPECT_EQ(, );
}; TEST(GlobalTest0, test1)
{
EXPECT_EQ(, );
}; TEST(GlobalTest1, test0)
{
EXPECT_EQ(, );
}; int main(int argc, char *argv[])
{
testing::AddGlobalTestEnvironment(new MyEnvironment0);
testing::AddGlobalTestEnvironment(new MyEnvironment1); testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS();
}

  编译命令及结果:

二、局部的事件机制(针对一个个测试套件)

  测试套件的事件机制我们同样需要去创建一个类,继承testing::Test,实现两个静态函数SetUpTestCase()和TearDownTestCase(),测试套件的事件机制不需要像全局事件机制一样在main注册,而是需要将我们平时使用的TEST宏改为TEST_F宏。

  SetUpTestCase()函数是在测试套件第一个测试用例开始前执行。

  TearDownTestCase()函数是在测试套件最后一个测试用例结束后执行。

  需要注意TEST_F的第一个参数使我们创建的类名,也就是当前测试套件的名称。

  示例:

 /***********************************************

     Filename       : test.cpp
Author :
Description :
Create Data : 2018-10-21 01:05:17
Modfiy History : 2018-10-21 01:05:17 ***********************************************/ #include <iostream> #include <gtest/gtest.h> using namespace std; class MyTestSuite0 : public testing::Test
{
protected:
static void SetUpTestSuite()
{
cout << "TestSuite event0 : start" << endl;
} static void TearDownTestSuite()
{
cout << "TestSuite event0 : end" << endl;
}
}; class MyTestSuite1 : public testing::Test
{
protected:
static void SetUpTestSuite()
{
cout << "TestSuite event1 : start" << endl;
} static void TearDownTestSuite()
{
cout << "TestSuite event1 : end" << endl;
}
}; TEST_F(MyTestSuite0, test0)
{
EXPECT_EQ(, );
} TEST_F(MyTestSuite1, test0)
{
EXPECT_EQ(, );
} TEST_F(MyTestSuite0, test1)
{
EXPECT_EQ(, );
} TEST_F(MyTestSuite1, test1)
{
EXPECT_EQ(, );
} int main(int argc, char *argv[])
{
testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS();
}

  编译命令及结果:

三、个体的事件机制(针对一个个测试用例)

  测试用例的事件机制的创建和测试套件的基本一样,不同地方在于测试用例实现的两个函数分别是SetUp()和TearDown(),这两个函数不是静态函数了。

  SetUp()函数是在一个测试用例的开始前执行。

  TearDown()函数是在一个测试用例的结束后执行。

  示例:

 /***********************************************

     Filename       : test.cpp
Author :
Description :
Create Data : 2018-10-21 01:23:12
Modfiy History : 2018-10-21 01:23:12 ***********************************************/ #include <iostream> #include <gtest/gtest.h> using namespace std; class MyTestCase0 : public testing::Test
{
protected:
virtual void SetUp()
{
cout << "TestCase event0 : start" << endl;
} virtual void TearDown()
{
cout << "TestCase event0 : end" << endl;
}
}; class MyTestCase1 : public testing::Test
{
protected:
virtual void SetUp()
{
cout << "TestCase event1 : start" << endl;
}
virtual void TearDown()
{
cout << "TestCase event1 : end" << endl;
}
}; TEST_F(MyTestCase0, test0)
{
EXPECT_EQ(, );
} TEST_F(MyTestCase0, test1)
{
EXPECT_EQ(, );
} TEST_F(MyTestCase1, test0)
{
EXPECT_EQ(, );
} TEST_F(MyTestCase1, test1)
{
EXPECT_EQ(, );
} int main(int argc, char *argv[])
{
testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS();
}

  编译命令及结果:

总结:

  gtest的三种事件机制总的来说还是简单的,而且也比较灵活,通过上面的例子也能看出我们可以在事件机制中实现一些资源共享,使我们的测试更加灵活。

gtest 三种事件机制的更多相关文章

  1. 【css笔记】css中的盒模型和三种定位机制(固定定位,绝对定位,浮动)

    html页面上的元素都可以看成是框组成的,框通过三种定位机制排列在一起就过程了我们看到的页面.而框就是盒模型. 盒模型 1.页面上的每个元素可以看成一个矩形框,每个框由元素的内容,内边距,边框和外边距 ...

  2. Oracle基础学习2--Oracle登录与三种验证机制

    首先,Oracle安装完毕有三个默认用户 Ø  Sys:数据库对象的拥有者.权限最高.password在安装的时候(口令管理)能够改变 Ø  System:数据库管理员,password为manage ...

  3. 请写出JavaScript中常用的三种事件。

    请写出JavaScript中常用的三种事件. 解答: onclick,onblur,onChange

  4. Oracle数据库的三种验证机制

    关于超级管理员登陆不需要密码因为: 数据库的三种验证机制: 操作系统验证(具有sysdba和sysopera的用户) 密码文件验证(具有sysdba和sysopera的用户) 数据库验证(普通用户) ...

  5. NET下三种缓存机制(Winform里面的缓存使用 )

    原文(http://www.cnblogs.com/wuhuacong/p/3526335.html)非常感谢伍华聪作者的分享! 缓存在很多情况下需要用到,合理利用缓存可以一方面可以提高程序的响应速度 ...

  6. java中存在三种调用机制

    1:同步调用:一种阻塞式调用,调用方要等待对方执行完毕才返回,它是一种单向调用 2:回调:一种双向调用模式,也就是说,被调用方在接口被调用时也会调用对方的接口: 3:异步调用:一种类似消息或事件的机制 ...

  7. jQuery三种事件绑定方式.bind(),.live(),.delegate()

    .bind(), .live(), 和 .delegate()之间的区别并不明显.但是理解它们的不同之处有助于写出更简洁的代码,并防止我们的交互程序中出现没有预料到的bug. 基础 DOM树 首先,图 ...

  8. python三种回收机制

    Python的GC模块主要运用了“引用计数”(reference counting)来跟踪和回收垃圾.在引用计数的基础上,还可以通过“标记-清除”(mark and sweep)解决容器对象可能产生的 ...

  9. CSS三种定位机制

    标准文档流 块级元素撑满整个页面div,ul,li,dl,dt,p 行级元素可以一行显示多个span,strong,img,input大部分 一般不设置盒子的高度,另其自动调整 margin属性的au ...

随机推荐

  1. C语言:开平方根sqrt程序02

    #include <stdio.h> int sqrt01(int x); void main(void){ int x=49,y; y=sqrt01(x); if(y<0) pri ...

  2. Base包equivalent

    Guava 18.0到22.0 Equivalence发生了较大的变化,这里我们先不可考虑Equivalence 新实现的那个接口,首先看一个测试demo: import java.util.Arra ...

  3. C# Vs2017启动调试,debug或者release调试状态闪一下程序就独立运行了

    最近发现一个没太大影响但是很奇怪的事情,编辑状态下点击调试,发现和之前的项目不一样,调试状态闪一下,程序就“独立了”,不受调试状态的控制了. 找了半天才发现,是在program.cs里加了一段代码引起 ...

  4. DevExpress v18.2新版亮点——Reporting篇(一)

    行业领先的.NET界面控件——DevExpress v18.2日前正式发布,本站将以连载的形式为大家介绍新版本新功能.本文将介绍了DevExpress Reporting v18.2 的新功能,新版3 ...

  5. 第十四周翻译-《Pro SQL Server Internals, 2nd edition》

    <Pro SQL Server Internals, 2nd edition> 作者:Dmitri Korotkevitch 翻译:赖慧芳 译文: 设计和优化索引 定义一种应用于所有地方的 ...

  6. 日积月累——java虚拟机内存区域的划分

    看了博主“一杯凉茶”一篇对java内存详解的文章后,虚心学习,并记录下来 ,以便日后再来温故. 一,运行时数据区 1.程序计数器 当前线程所执行的字节码行号指示器,字节码解释器工作依赖计数器控制完成, ...

  7. WebStorm 安装及使用

    WebStrom 插件安装 File(文件) -> settings(设置) -> Plugins 即可调出设置中的插件选项. 或者 按 快捷键ctrl + alt + s也可调出设置菜单 ...

  8. QT自定义控件系列(二) --- Loading加载动画控件

    本系列主要使用Qt painter来实现一些基础控件.主要是对平时自行编写的一些自定义控件的总结. 为了简洁.低耦合,我们尽量不使用图片,qrc,ui等文件,而只使用c++的.h和.cpp文件. 由于 ...

  9. re模块(正则表达式)

    re,findall("匹配正则","内容") #所有满足条件的结果都返回到一个列表里 ret = re.search(“匹配规则”,“内容”) #返回 匹配到 ...

  10. SQL注入之Sqli-labs系列第四十六关(ORDER BY注入)

    0X1查看页面 0x2源码 <?php include("../sql-connections/sql-connect.php"); $id=$_GET['sort']; i ...