在上面一篇博客中已经介绍了关于gtest的一些基本的用法,gtest的介绍和使用。今天主要是对gtest的熟练掌握做的一个实战练习。
在实战练习之前先来在学习一个gtest的用法–>gtest的参数化。
在设计测试案例的时候,经常需要考虑到多种不同的情况。我们一般的做法就是提前编写一个通用的方法,然后在编写测试用例的时候调用它。但是Google的程序员为了解决代码的复用性,在gtest中同时也提供了一个灵活的参数化的方案。
参数化的使用规则:
1、告诉gtest你要参数化的类型是什仫?
必须添加一个类,继承testing::TestWithParam<T>
,其中的T就是你要告诉gtest你要参数化的类型;
2、告诉gtest有了参数之后你要进行什仫样的测试?
在这里就用到了之前提到的TEST_P这个宏了。这个”P”你可以理解为”parameterized” 或者 “pattern”。在TEST_P
这个宏里面,使用GetParam()
函数可以获取当前参数的具体值;
3、告诉gtest你想要测试的参数具体是什仫?
使用这个INSTANTIATE_TEST_CASE_P
宏告诉gtest用户的测试范围。
1>、它的第一个参数是测试案例的前缀,可以任意取名;
2>、第二个参数是测试案例的名称,必须和之前参数化定义的名称相同;
3>、第三个参数可以理解为参数的生成方式,一般提供了下列几种方式:
1>、Range(begin,end,step); //范围在begin~end之间,步长为step,不包括end
2>、Values(v1,v2,...,vN); //v1,v2到vN的值
3>、ValuesIn(container) and ValuesIn(begin, end) //从一个C类型的数组或是STL容器,或是迭代器中取值
4>、Bool() //只能是true、false这两种值
5>、Combine(g1, g2, ..., gN) //将g1,g2,...gN进行排列组合,g1,g2,...gN本身是一个参数生成器,每次分别从g1,g2,..gN中各取出一个值,组合成一个元组(Tuple)作为一个参数。这个功能只在提供了<tr1/tuple>头的系统中有效。gtest会自动去判断是否支持tr/tuple,如果你的系统确实支持,而gtest判断错误的话,你可以重新定义宏GTEST_HAS_TR1_TUPLE=1。
还是测试绝对值的那个函数,此时使用参数化进行测试:
在使用参数化的情况下,当运行案例的时候是可以查看每个案例的名称的
好了,穿插了一下gtest的参数化的知识,下面就来模拟实现一个MyVector,并用gtest来测试吧!
MyVector.h
#include<iostream>
using namespace std;
#include<cassert>
#include<gtest/gtest.h>
template<class T>
class MyVector
{
public:
MyVector()
:_pData(NULL)
,_capacity(0)
,_size(0)
{}
MyVector(size_t n,const T& data)
:_pData(new T[n])
,_capacity(n)
,_size(n)
{
for(int i=0;i<_size;i++)
{
_pData[i]=data;
}
}
//MyVector<int> V2(v1);
MyVector(const MyVector<T>& v) //拷贝构造函数
:_pData(new T[v._size])
,_capacity(v._size)
,_size(