C++单元测试之四--利用cppunit运行测试用例

简介: cppunit是一个很好的针对于C++/C的单元测试框架,它源自于junit。利用cppunit我们可以很好的管理运行测试用例。cppunit是开源的,遵循LGPLv2许可证。你可以从http://sourceforge.net/projects/cppunit/下载到最新版本。
cppunit是一个很好的针对于C++/C的单元测试框架,它源自于junit。利用cppunit我们可以很好的管理运行测试用例。
cppunit是开源的,遵循LGPLv2许可证。
你可以从http://sourceforge.net/projects/cppunit/下载到最新版本。
下载解压后依次运行:
./configure
./make
./make install
cppunit就会被自动部署到你的机器上,其中头文件位于/usr/include/cppunit目录下,库文件位于/usr/local/lib中。你也可以直接把附件中编译好的cppunit解压拷贝到对应目录下。

设置好cppunit环境后,下面就开始修改代码。
首先修改Main.cpp如下:

点击(此处)折叠或打开

 #include stdio.h>
  1. #include stdlib.h>
  2. #include cppunit/extensions/TestFactoryRegistry.h>
  3. #include cppunit/ui/text/TestRunner.h>

  4. int main(int argc, char *argv[])
  5. {
  6.         CppUnit::TextUi::TestRunner runner;
  7.         CppUnit::TestFactoryRegistry &registry = CppUnit::TestFactoryRegistry::getRegistry();
  8.         runner.addTest(registry.makeTest());

  9.         runner.run();


  10.     return 0;
  11. }
其次添加TestA.cpp/.h来测试A.cpp:

点击(此处)折叠或打开

  1. //TestA.h
  2. #include cppunit/extensions/HelperMacros.h>

  3. class TestA: public CppUnit::TestFixture{
  4.         CPPUNIT_TEST_SUITE(TestA);
  5.         CPPUNIT_TEST(testSum);
  6.         CPPUNIT_TEST(testMultiply);
  7.         CPPUNIT_TEST_SUITE_END();
  8. public:
  9.         void testSum();
  10.         void testMultiply();
  11. };


点击(此处)折叠或打开

  1. //TestA.cpp
  2. #include "A.h"
  3. #include "TestA.h"
  4. CPPUNIT_TEST_SUITE_REGISTRATION(TestA);
  5. void TestA::testSum()
  6. {
  7.         A a;
  8.         CPPUNIT_ASSERT(11 == a.Sum(5,6));

  9. }

  10. void TestA::testMultiply()
  11. {
  12.         A a;
  13.         CPPUNIT_ASSERT(30 == a.Multiply(5,6));
  14. }

cppunit使用断言(ASSERT)来判断测试结果是否正确。
最后修改Makefile:


点击(此处)折叠或打开

  1. OBJS= Main.o A.o TestA.o

  2. UTest.out: $(OBJS)
  3.         g++ -o UTest.out $(OBJS) -ldl -lgcov -lcppunit


  4. CURDIR=$(shell pwd)

  5. $(OBJS): %.o: %.cpp
  6.         g++ -I$(CURDIR) -c -g -fprofile-arcs -ftest-coverage $ -o $@

  7. #unit test and code coverage check
  8. UT:UTest.out
  9.         valgrind --tool=memcheck --leak-check=full ./UTest.out
  10.         ./gcov_checker 90 --objects $(OBJS)
  11. #gcov -o A.o A.cpp

  12. .PHONY: clean
  13. clean:
  14.         rm -f *.o *.gcno *.gcda *.gcov UTest.out

编译运行的结果是:

点击(此处)折叠或打开

  1. [root@tivu25 utcov_cppunit]# make clean;make UT
  2. rm -f *.o *.gcno *.gcda *.gcov UTest.out
    g++  -I/home/haoqf/src/UTest/utcov_cppunit -c -g -fprofile-arcs -ftest-coverage Main.cpp -o Main.o
    g++  -I/home/haoqf/src/UTest/utcov_cppunit -c -g -fprofile-arcs -ftest-coverage A.cpp -o A.o
    g++  -I/home/haoqf/src/UTest/utcov_cppunit -c -g -fprofile-arcs -ftest-coverage TestA.cpp -o TestA.o
    g++ -o UTest.out Main.o A.o TestA.o  -ldl -lgcov -lcppunit
    valgrind --tool=memcheck --leak-check=full ./UTest.out
    ==31409== Memcheck, a memory error detector.
    ==31409== Copyright (C) 2002-2006, and GNU GPL'd, by Julian Seward et al.
    ==31409== Using LibVEX rev 1658, a library for dynamic binary translation.
    ==31409== Copyright (C) 2004-2006, and GNU GPL'd, by OpenWorks LLP.
    ==31409== Using valgrind-3.2.1, a dynamic binary instrumentation framework.
    ==31409== Copyright (C) 2000-2006, and GNU GPL'd, by Julian Seward et al.
    ==31409== For more details, rerun with: -v
    ==31409==
    ..


    OK (2 tests)


    ==31409==
    ==31409== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 19 from 1)
    ==31409== malloc/free: in use at exit: 0 bytes in 0 blocks.
    ==31409== malloc/free: 82 allocs, 82 frees, 9,807 bytes allocated.
    ==31409== For counts of detected errors, rerun with: -v
    ==31409== All heap blocks were freed -- no leaks are possible.
    ./gcov_checker 90 --objects Main.o A.o TestA.o
    Code coverage:
    Main.cpp:100.0%
    A.cpp:100.0%
    TestA.cpp:100.0%
    See *.gcov files for details.

zip.gif cppunit_compiled.zip  
《返璞归真--UNIX技术内幕》在全国各大书店及网城均有销售:
京东
亚马逊                          China pub
上学吧                          1号店




目录
相关文章
|
2月前
|
API C++ Windows
Visual C++运行库、.NET Framework和DirectX运行库的作用及常见问题解决方案,涵盖MSVCP140.dll丢失、0xc000007b错误等典型故障的修复方法
本文介绍Visual C++运行库、.NET Framework和DirectX运行库的作用及常见问题解决方案,涵盖MSVCP140.dll丢失、0xc000007b错误等典型故障的修复方法,提供官方下载链接与系统修复工具使用指南。
649 2
|
2月前
|
IDE 编译器 开发工具
msvcp100.dll,msvcp120.dll,msvcp140.dll,Microsoft Visual C++ 2015 Redistributable,Visual C++ 运行库安装
MSVC是Windows下C/C++开发核心工具,集成编译器、链接器与调试器,配合Visual Studio使用。其运行时库(如msvcp140.dll)为程序提供基础函数支持,常因缺失导致软件无法运行。通过安装对应版本的Microsoft Visual C++ Redistributable可解决此类问题,广泛应用于桌面软件、游戏及系统级开发。
367 2
|
3月前
|
并行计算 C++ Windows
|
7月前
|
监控 安全 测试技术
【01】卓伊凡收到冒充税务机关的诈骗程序-决定在沙盒Sandbox环境中运行测试下-广大企业同胞们注意防诈骗
【01】卓伊凡收到冒充税务机关的诈骗程序-决定在沙盒Sandbox环境中运行测试下-广大企业同胞们注意防诈骗
214 14
【01】卓伊凡收到冒充税务机关的诈骗程序-决定在沙盒Sandbox环境中运行测试下-广大企业同胞们注意防诈骗
|
机器学习/深度学习 人工智能 API
如何在c++侧编译运行一个aclnn(AOL)算子?
CANN的AOL库提供了一系列高性能算子API,优化了昇腾AI处理器的调用流程。通过两段式接口设计,开发者可以高效地调用算子库API,实现模型创新与应用,提升开发效率和模型性能。示例中展示了如何使用`aclnnAdd`算子,包括环境初始化、算子调用及结果处理等步骤。
|
10月前
|
缓存 Java 测试技术
【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
1354 3
【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
|
C++
C++ 根据程序运行的时间和cpu频率来计算在另外的cpu上运行所花的时间
C++ 根据程序运行的时间和cpu频率来计算在另外的cpu上运行所花的时间
189 0
|
测试技术 Python
自动化测试项目学习笔记(一):unittest简单运行(初始化,清除,设置测试行为)
本文介绍了Python的unittest框架的基础用法,包括测试初始化(setup)、清除(tearDown)函数的使用,以及assertEqual和assertGreaterEqual等断言方法,并展示了如何创建测试用例,强调了测试函数需以test_开头才能被运行。
240 1
自动化测试项目学习笔记(一):unittest简单运行(初始化,清除,设置测试行为)
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
1780 1