操作系统系统:Ubuntu6,g++
软件版本:cppunit-1.10.2.tar.gz
(1)获得源码:
到cppunit.sourceforge.net上下载源代码。将其复制到到linux下或者是直接使用wget下载到linux下。
(2)解压缩:
使用以下命令即可解压缩
tar -zxvf cppunit-1.10.2.tar.gz
(3)编译安装
cd进cppunit-1.10.2目录下。
./configure
make
make install
make的编译的文件都在src/cppunit/.libs。
make install只是把链接库文件复制到/usr/local/lib,其他的似乎什么都没有做。
(4)复制头文件
make install没有把头文件安装到/usr/include中去,此时还需要手工去复制,只要把include下面的cppunit目录复制到/usr/include下面就可以了,命令很简单,就不写了。
(5)配置链接库路径
这个时候,看起来似乎已经安装配置成功了,其实不然,在Ubutu、FC(已知的)动态链接库的配置文件里面并没有写入/usr/local/lib的路径,虽然可以编译过,但是你却发现会运行不了,会出现如是的错误:
./mytest: error while loading shared libraries: libcppunit-1.10.so.2:
cannot open shared object file: No such file or directory
真是糟糕,此时你还需要配置一下链接库的路径,链接库配置文件为/etc/ld.so.conf,以下为修改办法:
vi /etc/ld.so.conf
在新起一行里面加入:
/usr/local/lib
然后再用ldconfig命令重新装载一下配置文件就可以了:
ldconfig
OK,此时你已经可以正常的编译并使用了^__^
(6)编写第一个HelloWorld
撰写mytest.cpp(从cppunit.sourceforge.net上copy下来的),代码如下:
#include
#include
#include
#include
#include
#include
#include
class Test : public CPPUNIT_NS::TestCase
{
CPPUNIT_TEST_SUITE(Test);
CPPUNIT_TEST(testHelloWorld);
CPPUNIT_TEST_SUITE_END();
public:
void setUp(void) {}
void tearDown(void) {}
protected:
void testHelloWorld(void) { std::cout <<
"Hello, world!" << std::endl; }
};
CPPUNIT_TEST_SUITE_REGISTRATION(Test);
int main( int argc, char **argv )
{
// Create the event manager and test controller
CPPUNIT_NS::TestResult controller;
// Add a listener that colllects test
result
CPPUNIT_NS::TestResultCollector result;
controller.addListener( &result );
// Add a listener that print dots as test
run.
CPPUNIT_NS::BriefTestProgressListener progress;
controller.addListener( &progress );
// Add the top suite to the test runner
CPPUNIT_NS::TestRunner runner;
runner.addTest( CPPUNIT_NS::TestFactoryRegistry::getRegistry().makeTest()
);
runner.run( controller );
return result.wasSuccessful() ? 0 : 1;
}
将之保存为mytest.cpp。
(7)编译我们的HelloWorld
你可以链接静态库也可以链接静态库。
(a) 链接静态库。编译命令:
g++ -L/usr/local/lib/libcppunit.a mytest.cpp -lcppunit -ldl -o mytest
运行:
./mytest
结果:
Test::testHelloWorldHello, world!
: OK
(b) 链接动态库。编译命令:
g++ mytest.cpp -lcppunit -ldl -o mytest
运行:
./mytest
结果:
Test::testHelloWorldHello, world!
: OK
如果你没有执行步骤(5),那么你也可以在每次运行之前设置下临时的环境变量LD_LIBRARY_PATH命令如下:
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
补遗:
非Root用户是不能够往/usr/local/lib/和/usr/include里面写东西的,这个时候就很烦人了。你就只能够把库和头文件放到home目录里面。
非Root用户的安装需要作如下修改:
步骤三需要修改configure,这里 -prefix=/home/me的意思是把安装的根目录设置为/home/me(我的私人目录,
我不是管理员所以只好安装到自己的“家“了),这样make install的时候,库文件就会复制到此目录下的lib目录里。
./configure -prefix=/home/me
Ok,把头文件也放置到/home/me里面吧。这样,情况就是:头文件存储在/home/me/include,库文件存储在/home/me/lib。
编译的时候命令就会像如下所示:
g++ -g -L/home/me/lib -lcppunit -ldl -I/home/me/include Main.C
因为是非root用户,所以步骤(5)是无法执行的了,想要能够运行测试程序就只能够执行类型类似命令才能够运行了:
export LD_LIBRARY_PATH=/home/me/lib:$LD_LIBRARY_PATH
(注:/home/me里面的me代表的是你的用户名,在Linux下面,除了root的用户目录是在/root下,其他用户都是在/home下的,目录名为用户名。当你登录当前用户之后,就在此目录下。)
单元测试,最终它是要运用到工程中去的,如果还那样用g++命令直接编译,肯定是行不通的,所以还必须要写一个Makefile才可以。
我对CPPUNIT的一些理解(一直没有时间,忘了很多东西,以后再整理):
一、测试用例
1、CPPUnit通常用于接口测试,如果进行路径测试,需要考虑一些特殊问题,因为可能需要访问被测类的保护或者私有成员。在这种情况下,可以考虑使用辅助类,辅助类从被测类派生,并将测试类声明为友元。
2、测试类从TestFixture派生,该类声明了setUp(),tearDown()函数,分别进行重载以用来初始化测试和释放资源
3、在测试类的头文件类声明中使用以下宏进行声明测试套件
CPPUNIT_TESTSUITE(测试类名)
CPPUNIT_TEST(测试函数名1)
CPPUNIT_TEST(测试函数名2)
CPPUNIT_TEST_SUITE_END()
以上代码将测试函数准备好,测试函数原型为:void testX()
4、测试套件注册使用以下宏
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(类名,名字空间)
CPPUNIT_TEST_SUITE_REGISTRATION(类名)
以上两个宏在测试类的cpp文件开头添加,第一个宏将测试类注册到“名字空间”里,“名字空间”是一个字符串
第二个宏将测试类注册到缺省名字空间里
5、cpp的实现,以下例子是一个测试函数的实现,完成的是路径测试,其中CTest_CbackupSource从TestFixture派生
void CTest_CBackupSource::testMakeSourceName()
{
CMyBackupSource backupSource;
CPPUNIT_ASSERT(backupSource.m_strSourceName == "");
backupSource.SetSourcePath("C:\\test\\Test.tt");
CPPUNIT_ASSERT(backupSource.m_strSourceName == "Test.tt");
backupSource.SetSourcePath("C:\\test\\");
CPPUNIT_ASSERT(backupSource.m_strSourceName == "");
backupSource.SetSourcePath("test");
CPPUNIT_ASSERT(backupSource.m_strSourceName == "test");
}
二、运行测试用例
//返回测试工厂对象的引用,缺省参数为“All Tests”,对应于注册在缺省空间的测试类,在以后测试运行时,注册在缺省空间的测试用例将被运行
CPPUNIT_NS::TestFactoryRegistry ?istry = CPPUNIT_NS::TestFactoryRegistry::getRegistry();
//添加命名空间后,注册在该命名空间的测试用例将被运行
registry.addRegistry("CBackupSource");
// registry.addRegistry("CVersionInfo");
// registry.addRegistry("CSHFile");
// 得到测试套件,包括所有选择的测试空间内注册的测试用例
CPPUNIT_NS::Test* suite = registry.makeTest();
CPPUNIT_NS::TextUi::TestRunner runner;
runner.addTest(suite);
// 设置输出,注意对象被runner释放
runner.setOutputter(new CPPUNIT_NS::CompilerOutputter(&runner.result(),
std::cerr));
// 增加监听器,eventManager返回TestResult类的对象,维护一个Listener集合,Listener将决定测试过程表现,包括日志输出格式
CPPUNIT_NS::BriefTestProgressListener progress;
runner.eventManager().addListener(&progress);
nRetCode = runner.run(); |