如何在VS2013中进行Boost单元测试
对于如何在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单元测试的更多相关文章
- 在VS2013中使用boost库遇到的问题及解决(转)
		
原文转自 https://my.oschina.net/SunLightJuly/blog/676891?p=1 最近的项目需要集成一个使用了boost库的开源库.原本应该是比较简单的工作,因为使用的 ...
 - visual c++.net 技术内幕 第6版 附带的程序如何在vs2013中编译成功
		
看vc++技术内幕时 如果你使用的是比此书的附带项目更新版的vs时千万不要使用这种方法,这些对编译都有影响. 请使用当前新版的vs并输入书中改动的代码就Ok,因为vs会生成合理的mfc代码,养成好的习 ...
 - 如何在VS2013中新建WindowsService定时任务
		
http://jingyan.baidu.com/article/cd4c2979e9330d756f6e6070.html 很多人都想做定时任务,但是没有不知道如何下手,现在就用WindowsSer ...
 - 如何在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 ...
 - 如何在VS2013中显示代码行号
		
http://jingyan.baidu.com/article/af9f5a2d2e193543140a4533.html
 - vs2013如何在C++中调用Lua(二)
		
Lua学习笔记 vs2013如何在C++中调用Lua (此为转载教程) 本人试过完全可行 一.准备工作 1.下载Lua源码,地址:http://www.lua.org/download.html(我用 ...
 - 我是如何在SQLServer中处理每天四亿三千万记录的
		
首先声明,我只是个程序员,不是专业的DBA,以下这篇文章是从一个问题的解决过程去写的,而不是一开始就给大家一个正确的结果,如果文中有不对的地方,请各位数据库大牛给予指正,以便我能够更好的处理此次业务. ...
 - 如何在springMVC 中对REST服务使用mockmvc 做测试
		
如何在springMVC 中对REST服务使用mockmvc 做测试 博客分类: java 基础 springMVCmockMVC单元测试 spring 集成测试中对mock 的集成实在是太棒了!但 ...
 - 【转】我是如何在SQLServer中处理每天四亿三千万记录的
		
原文转自:http://blog.jobbole.com/80395/ 首先声明,我只是个程序员,不是专业的DBA,以下这篇文章是从一个问题的解决过程去写的,而不是一开始就给大家一个正确的结果,如果文 ...
 
随机推荐
- 在Linux上的虚拟机上启动Oracle上报ORA-00845: MEMORY_TARGET not supported on this system的问题解决
			
解决办法: 1.将当前虚拟机的内容调整大一些(以下转载:http://jingyan.baidu.com/article/414eccf67b8baa6b421f0a60.html) VMware虚拟 ...
 - Java并发框架——什么是AQS框架
			
什么是AQS框架 1995年sun公司发布了第一个java语言版本,可以说从jdk1.1到jdk1.4期间java的使用主要是在移动应用和中小型企业应用中,在此类领域中基本不用设计大型并发场景,当然也 ...
 - 悲观的并发策略——Synchronized互斥锁
			
volatile既然不足以保证数据同步,那么就必须要引入锁来确保.互斥锁是最常见的同步手段,在并发过程中,当多条线程对同一个共享数据竞争时,它保证共享数据同一时刻只能被一条线程使用,其他线程只有等到锁 ...
 - EXCEL技能之数据去重
			
本篇不属于技术类博文,只是想找个地方记录而已,既然是我的博客嘛,那就自己想写什么就写什么了. CRM中有个EXCEL数据导入功能,几千条数据导入CRM后去重,那是死的心都有的.往回想想EXCEL是否有 ...
 - Android平移动画
			
Android平移动画 核心方法 public void startAnimation(Animation animation) 执行动画,参数可以是各种动画的对象,Animation的多态,也可以是 ...
 - Linux2.6--虚拟文件系统
			
虚拟文件系统(有时也称作虚拟文件交换,更常见的是简称做VFS)作为内核子系统,为用户空间程序提供了文件和文件系统相关的接口.系统中的所有文件系统不但依赖VFS共存,而且也依赖VFS系统协同 ...
 - java模拟链表
			
java语言不存在指针,但是我们仍可以用相应的逻辑模拟链表的实现,下面这段代码就是我的一个小伙伴实现的: package com.brucezhang.test; public class ...
 - android问题:Installation error: INSTALL_FAILED_CONFLICTING_PROVIDER
			
转载请注明出处:http://blog.csdn.net/hejjunlin/article/details/24196143 Installation error: INSTALL_FAILED_C ...
 - python 多进程 logging:ConcurrentLogHandler
			
python 多进程 logging:ConcurrentLogHandler python的logging模块RotatingFileHandler仅仅是线程安全的,如果多进程多线程使用,推荐 Co ...
 - Android初级教程图片信息
			
对图片常规信息要了解其性质.图片大小.像素.位图等等概念总结如下: 图片在计算机中的大小 图片的总大小 = 图片的总像素 * 每个像素占用的大小(图片的总像素=像素尺寸也就是分辨率,例如设定800*4 ...