对于如何在VS2013中进行Boost单元测试,这方面资料太少。自己也因此走了不少弯路。下文将会阐述一下如何在VS2013中进行Boost单元测试。

  在开始Boost单元测试之前,我们需要先安装VS2013插件Boost Unit Test Adapter (Update 3) 以及编译Boost库。Boost Unit Test Adapte可以在VS2013中的“工具->扩展与更新”中找到并安装。对于Boost Unit Test Adapter所支持的Boost库版本请参考网页。我选择的是版本号为1.55.0的Boost库(可以在其官网下载得到)。在编译Boost库的时候,可以参考教程博文。我选择的是完全编译(bjam --toolset=msvc-12.0 --build-type=complete)。

  下文以几个步骤来阐述:

   1. 新建解决方案及工程

  接下来,我们新建一个BoostUnitTest解决方案,然后在该方案下添加(鼠标右击解决方案新建项目)两个项目。第一个项目是空的“WIN32”项目“Tested”,另一个是“Boost Unit Test Project”项目(新建项目->模板->Visual C++->Test下)“BoostUnitTest”。如下图:

  

   2. 在被测试工程中添加文件

  在Tested工程中添加一个头文件tested.h及源文件tested.cpp. 具体代码如下

 #include <iostream>

 using namespace std;

 class Tested
{
public: Tested();
virtual ~Tested();
int add(const int a, const int b); private: };

tested.h

 #include "tested.h"

 Tested::Tested()
{ } Tested::~Tested()
{ } int Tested::add(const int a, const int b)
{
return a + b;
}

tested.cpp

  在这里,我们并不需要新建一个main函数对这个类tested进行测试(因为我们已经有单元测试了),但一个程序默认是需要main函数的,所以在需要在Tested项目属性中进行这样的设置(“配置类型”改为“动态库(.dll)”见下图):

  

  接着,“生成”该工程,产生tested.obj文件。

   3. 配置Boost单元测试工程

  新建的Boost单元测试工程中有两个源文件“BoostUnitTestSample.cpp”及“BoostUnitTest.cpp”(还有stdafx.h、stdafx.cpp、targetver.h),前一个文件是样例,可以不要,后一个文件可以当作我们的单元测试源文件。

  先对该工程进行配置:

  1)添加“平台工具集”为"Visual Studio 2013 (v120)",见下图:

  

  2)添加包含Boost库的根目录(在我电脑上是D:\boots_1_55_0),见下图:

  

  3)添加Boost库目录及待测试工程的.obj文件所在目录,见下图:

  

  4)添加“附加依赖项”“tested.obj”,见下图:

  

   4. 进行Boost单元测试

  注:我们在这时只进行简单的单元测试,更加复杂的测试请参考文章最后给出的链接。  

  在BoostUnitTest工程中的文件“BoostUnitTest.cpp”(也可新建)添加如下代码:

 #define BOOST_TEST_MODULE Tested_Module                                // 主测试套件,一个测试项目中只能有一个主测试套件

 #include "stdafx.h"
#include "D:\VSProject\BoostUnitTest\BoostUnitTest\Tested\tested.h" // 待测工程头文件 struct Tested_Fixture // 测试夹具
{
Tested_Fixture()
{
BOOST_TEST_MESSAGE("setup fixture");
tmpTested = new Tested();
}
~Tested_Fixture()
{
BOOST_TEST_MESSAGE("teardown fixture");
delete tmpTested;
}
Tested * tmpTested;
}; BOOST_FIXTURE_TEST_SUITE(Tested_test, Tested_Fixture) // 测试套件 BOOST_AUTO_TEST_CASE( Tested_Method_add_Test) // 测试用例
{
// TODO: Your test code here
BOOST_WARN(tmpTested->add(, ) == ); // WARN型预言检测
BOOST_CHECK(tmpTested->add(, ) == ); // CHECK型预言检测
BOOST_REQUIRE(tmpTested->add(, ) == ); // REQUIRE型预言检测
} BOOST_AUTO_TEST_SUITE_END()

  点击“生成->生成解决方案”(预先打开“测试->窗口->测试资源管理器”)可以看到在“测试资源管理器”中出现了“BoostUnitTest”这个单元测试用例,如下图:

  注:如果电脑安装有杀毒软件(如360),“生成解决方案”的时候可能会提示:error LNK1104: 无法打开文件“...\BoostUnitTest\Debug\Tested.dll"。这是因为杀毒软件拦截了单元测试工程对被测试工程.dll文件的访问。比较简单的方法是将杀毒软件关闭就OK了。

  

  点击“全部运行”,可以看到该测试用例变绿,说明测试通过,如下图:

  

  如果我们将“BoostUnitTest.cpp”中的第13行改成:

BOOST_CHECK(tmpTested->add(, ) == );

  单元测试运行结果是不通过,如下图:

  

  至此,如何进行一个简单的Boost单元测试的过程就完成了。

  // 添加于2014.10.18 ---------------------------------------------------------------------------

  现在,我在之前程序的基础上又添加了一点异常测试,相关的源代码如下:

 #include <iostream>

 using namespace std;

 class Tested
{
public: Tested();
virtual ~Tested();
int add(const int a, const int b);
void testException(); private: };

tested.h

 #include "tested.h"

 Tested::Tested()
{ } Tested::~Tested()
{ } int Tested::add(const int a, const int b)
{
return a + b;
} void Tested::testException()
{
throw logic_error("my throw"); // 抛出一个逻辑错误异常
}

tested.cpp

 #define BOOST_TEST_MODULE Tested_Module                                // 主测试套件,一个测试项目中只能有一个主测试套件

 #include "stdafx.h"
#include "D:\VSProject\BoostUnitTest\BoostUnitTest\Tested\tested.h" // 待测工程头文件 struct Tested_Fixture // 测试夹具
{
Tested_Fixture()
{
BOOST_TEST_MESSAGE("setup fixture");
tmpTested = new Tested();
}
~Tested_Fixture()
{
BOOST_TEST_MESSAGE("teardown fixture");
delete tmpTested;
}
Tested * tmpTested;
}; BOOST_FIXTURE_TEST_SUITE(Tested_test, Tested_Fixture) // 测试套件 BOOST_AUTO_TEST_CASE(Tested_Method_add_Test) // 测试用例
{
// TODO: Your test code here
BOOST_WARN(tmpTested->add(, ) == ); // WARN型预言检测
BOOST_CHECK(tmpTested->add(, ) == ); // CHECK型预言检测
BOOST_REQUIRE(tmpTested->add(, ) == ); // REQUIRE型预言检测 } BOOST_AUTO_TEST_CASE(Tested_Method_testException_Test) // 测试用例
{
// TODO: Your test code here
BOOST_REQUIRE_NO_THROW(tmpTested->testException()); // 验证是否无异常抛出,是则为真
BOOST_REQUIRE_THROW(tmpTested->testException(), logic_error); // 验证抛出的是否是logic_error异常
BOOST_REQUIRE_THROW(tmpTested->testException(), runtime_error); // 验证抛出的是否是runtime_error异常 } BOOST_AUTO_TEST_SUITE_END()

BoostUnitTest.cpp

  很显示,程序的运行结果如下:

 BOOST_REQUIRE_NO_THROW(tmpTested->testException());              // 测试不通过
BOOST_REQUIRE_THROW(tmpTested->testException(), logic_error); // 测试通过
BOOST_REQUIRE_THROW(tmpTested->testException(), runtime_error); // 测试不通过

  如果要进行更复杂的测试,可以参考官方文档

  还有一些个人觉得比较好的参考资料:

  Boost Test Library 中文手册

  DeveloperWorks的“了解Boost单元测试框架”;

  博文“单元测试分享”;

  博文“Boost学习总结(C++)”;

  博文“面向C++的测试驱动开发”。

  连载“单元测试实践的主要问题与解决”。

如何在VS2013中进行Boost单元测试的更多相关文章

  1. 在VS2013中使用boost库遇到的问题及解决(转)

    原文转自 https://my.oschina.net/SunLightJuly/blog/676891?p=1 最近的项目需要集成一个使用了boost库的开源库.原本应该是比较简单的工作,因为使用的 ...

  2. visual c++.net 技术内幕 第6版 附带的程序如何在vs2013中编译成功

    看vc++技术内幕时 如果你使用的是比此书的附带项目更新版的vs时千万不要使用这种方法,这些对编译都有影响. 请使用当前新版的vs并输入书中改动的代码就Ok,因为vs会生成合理的mfc代码,养成好的习 ...

  3. 如何在VS2013中新建WindowsService定时任务

    http://jingyan.baidu.com/article/cd4c2979e9330d756f6e6070.html 很多人都想做定时任务,但是没有不知道如何下手,现在就用WindowsSer ...

  4. 如何在C++中使用boost库序列化自定义class ?| serialize and deserialize a class in cpp with boost

    本文首发于个人博客https://kezunlin.me/post/6887a6ee/,欢迎阅读! serialize and deserialize a class in cpp Guide how ...

  5. 如何在VS2013中显示代码行号

    http://jingyan.baidu.com/article/af9f5a2d2e193543140a4533.html

  6. vs2013如何在C++中调用Lua(二)

    Lua学习笔记 vs2013如何在C++中调用Lua (此为转载教程) 本人试过完全可行 一.准备工作 1.下载Lua源码,地址:http://www.lua.org/download.html(我用 ...

  7. 我是如何在SQLServer中处理每天四亿三千万记录的

    首先声明,我只是个程序员,不是专业的DBA,以下这篇文章是从一个问题的解决过程去写的,而不是一开始就给大家一个正确的结果,如果文中有不对的地方,请各位数据库大牛给予指正,以便我能够更好的处理此次业务. ...

  8. 如何在springMVC 中对REST服务使用mockmvc 做测试

    如何在springMVC 中对REST服务使用mockmvc 做测试 博客分类: java 基础 springMVCmockMVC单元测试  spring 集成测试中对mock 的集成实在是太棒了!但 ...

  9. 【转】我是如何在SQLServer中处理每天四亿三千万记录的

    原文转自:http://blog.jobbole.com/80395/ 首先声明,我只是个程序员,不是专业的DBA,以下这篇文章是从一个问题的解决过程去写的,而不是一开始就给大家一个正确的结果,如果文 ...

随机推荐

  1. JAVA面向对象-----包机制

    JAVA面向对象-–包机制 问题: 当定义了多个类的时候,可能会发生类名的重复问题. 在java中采用包机制处理开发者定义的类名冲突问题. 怎么使用java的包机制呢? 1.使用package 关键字 ...

  2. Java异常处理-----Throwable类

    Throwable类 1.toString() 输出该异常的类名. 2.getMessage() 输出异常的信息,需要通过构造方法传入异常信息(例如病态信息). 3.printStackTrace() ...

  3. 【SSH系列】-- hibernate基本原理&&入门demo

        什么是hibernate?      hibernate在英文中是冬眠的意思,当冬季来临,世界万物开始准备冬眠,但是程序猿这种动物好像不冬眠,因为需求变了,要改bug,冬眠,对于对象来说就是持 ...

  4. Xcode7.3中SKAudioNode"诡异"初始化的解决

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我没有在之前版本的Xcode中测试,不过很多人反映SKAudi ...

  5. Swift基础之Demo包含刷新,加载,网络请求,MVC

    Swift中有一个Alamofire第三方是进行网络请求的,它是AFNetworking的作者写的Swift形式,今天先介绍一下,利用pod导入AFNetworking,SVProgressHUD,M ...

  6. 一个 Linux 上分析死锁的简单方法

    简介 死锁 (deallocks): 是指两个或两个以上的进程(线程)在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这 ...

  7. Android Studio安装Genymotion插件

    Android Studio安装Genymotion插件 Eclipse就不介绍了,谷歌都已经放弃Eclipse了,你还在坚持什么. 安装Genymotion 官网:https://www.genym ...

  8. 第一行代码阅读笔记---AndroidMainfest.xml分析

    按照这本书的指引,我随作者一样创建了一个安卓应用,开始了安卓开发的启程. 找到AndroidMainfest.xml这个文件,打开后看到了我创建的Activity在这个文件里被成功注册,文件内容如下: ...

  9. android view事件分发机制

    首先我们先写个简单的例子来测试View的事件转发的流程~ 1.案例 为了更好的研究View的事件转发,我们自定以一个MyButton继承Button,然后把跟事件传播有关的方法进行复写,然后添加上日志 ...

  10. Android简易实战教程--第十五话《在外部存储中读写文件》

    第七话里面介绍了在内部存储读写文件 点击打开链接. 这样有一个比较打的问题,假设系统内存不够用,杀本应用无法执行,或者本应用被用户卸载重新安装后.以前保存的用户名和密码都不会得到回显.所以,有必要注意 ...