CUnit C语言单元测试框架使用体验

本文详细介绍了如何在大型项目中利用CUnit进行单元测试、路径测试和分支测试。针对现有工程代码的复杂耦合,建议将CUnit整合进工程源码,作为第三方库来简化测试过程。在编写测试用例时,可以通过设定不同变量和状态,对代码分支进行深度测试,确保业务流程的正确性。此外,CUnit还能用于状态机功能的验证。尽管篇幅有限,但本文提供了一种有效测试大型项目的方法,并鼓励读者分享更多测试策略。
摘要由CSDN通过智能技术生成


CUnit是一个C语言的单元测试框架,具体使用方式可参考:C语言单元测试框架——CUnit

在一个代码量交大的工程项目中,在研发自测环节里面,仅完成单元测试不足以确保代码的质量,还要进行代码的路径测试,分支测试。测试不同情况下的代码的分支功能是否正常。


对于代码路径测试和分支测试,其他的方法暂不讨论,欢迎大家评论交流。

本文介绍一下使用CUnit来进行代码的路径测试和分支测试的方法。


对于一个现有的工程代码,代码之间功能的耦合,源文件之间相互关联很难避免,尤其是千古遗留的代码,一言难尽。在这样的背景下想要在cunit框架中测试某个功能函数,编译的时候往往让人怀疑人生,缺少这个变量定义,缺少那个文件包含,类似的编译错误数不胜数。
对于这样的情况,我们可以换一个思路,我们可以把cunit仅当作成一个第三方库,和libxml库一样看待,把cunit库加入到我们自己的工程源码中,在我们自己的工程中使用cunit的一些功能。通过这样的形式可以有效的降低测试一个现有的工程的难度。


代码编译通过后,下一步就是写测试用例或者叫测试套件、测试函数。
在一些介绍cunit使用的文章中,测试函数往往写的很简单,而且都是针对单个功能具体的函数,仅仅体现了cunit的单元测试的功能。
对于代码分支测试,此时代码的业务功能往往已经编写完毕,具体的函数功能均已实现,这时可以使用cunit在测试函数中编写一些较复杂的测试方式,对代码分支进行测试,可以设置不同的变量,测试代码分支的功能是否符合预期。这时的测试重点在于业务流程,而不是单个函数的功能了。

除此之外,还可以使用cunit来测试状态机的功能,设置不同的状态,测试状态机跳转是否符合我们的预期。

有意思的是,每个测试函数之间彼此互不干扰,可以在测试函数中可以初始不同的变量和状态,然后对代码功能进行测试。这样我们就可以把一个个测试函数看成不同的main函数,这样我们就可以对不同的功能同时进行测试,查看测试结果。

文章写的有点仓卒,表达的信息可能不够准确,希望大家理解,也欢迎大家评论交流。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值