谷歌测试框架参数化夹具
Google test framework parametrize fixtures
我有一个问题。 我使用以下结构作为夹具:
类无效SDPTest : public ::testing::Test{保护: Virtual void SetUp(){ std::字符串名称("名称"); 服务器=新 Sip服务器(名称); std::ifstream offerFile,answerFile; offerFile.open("unvalidOfferSDP.txt"); answerFile.open("unvalidAnswerSDP.txt"); std::string offerRawSDP,answerRawSDP; offerFile>>offerRawSDP; answerFile>>answerRawSDP; offerSDPSession = Server->MakeSDPSession( const_cast(offerRawSDP.c_str()) ) ; answerSDPSession = Server->MakeSDPSession( const_cast(answerRawSDP.c_str()) ) ; } Virtual void TearDown(){ 删除服务器; } pjmedia_sdp_session *提供SDPSession, *answerSDPSession ; SipServer *服务器; SDPNeg 谈判代表;};
我想通过文件名参数化这个类。如何让它变得更好?
有很多方法可以做到这一点 - 我将向您展示两种:
方法 1:创建一个具有虚函数的基类,然后从中派生。
class unvalidSDPTestBase : public ::testing::Test{
virtual const char * offer_filename() const =0;
virtual const char * answer_filename() const =0;
protected:
virtual void SetUp(){
std::string Name("name");
Server=new SipServer(Name);
std::ifstream offerFile,answerFile;
offerFile.open( offer_filename());
answerFile.open(answer_filename());
std::string offerRawSDP,answerRawSDP;
offerFile>>offerRawSDP;
answerFile>>answerRawSDP;
offerSDPSession = Server->MakeSDPSession( const_cast(offerRawSDP.c_str()) ) ;
answerSDPSession = Server->MakeSDPSession( const_cast(answerRawSDP.c_str()) ) ;
}
virtual void TearDown(){
delete Server;
}
pjmedia_sdp_session *offerSDPSession, *answerSDPSession ;
SipServer *Server;
SDPNeg Negotiator;
};
class unvalidSPDTestBase: public unvalidSDPTestBase
{
virtual const char * offer_filename() const { return "..."; }
virtual const char * answer_filename() const { return "..."; }
}
方法 2:使用系统和模板等特征:
template<typename FILENAME_SOURCE>
class SDPTest : public ::testing::Test{
protected:
virtual void SetUp(){
std::string Name("name");
Server=new SipServer(Name);
std::ifstream offerFile,answerFile;
offerFile.open( FILENAME_SOURCE::offer_filename());
answerFile.open( FILENAME_SOURCE::answer_filename());
std::string offerRawSDP,answerRawSDP;
offerFile>>offerRawSDP;
answerFile>>answerRawSDP;
offerSDPSession = Server->MakeSDPSession( const_cast(offerRawSDP.c_str()) ) ;
answerSDPSession = Server->MakeSDPSession( const_cast(answerRawSDP.c_str()) ) ;
}
virtual void TearDown(){
delete Server;
}
pjmedia_sdp_session *offerSDPSession, *answerSDPSession ;
SipServer *Server;
SDPNeg Negotiator;
};
struct InvalidFilenames
{
static const char * offer_filename() { return "..."; }
static const char * answer_filename() { return "..."; }
};
typedef SDPTest<InvalidFilenames> unvalidSDPTest;
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 谷歌测试框架参数化夹具