c语言fuc函数,CMocker

本文探讨了在纯C语言系统中进行单元测试和功能测试时,如何利用CMocker工具对函数进行打桩。通过将外部接口替换为桩函数,允许在不同测试用例中定制行为,同时保持待测代码与正式运行时的一致性。CMocker通过宏定义实现隐式替换,确保待测函数在执行过程中调用回调函数,从而达到灵活控制外部依赖的效果。
摘要由CSDN通过智能技术生成

format,png

前言

对待测函数中的某些行为打桩可以方便单元测试(UT)/功能测试(FT)的开发,但是桩打得越彻底,其能起到防护作用也会越打折扣;如果粗略地将需要维护的代码定义为边界内的话,那么原则上不鼓励对边界内的函数打桩;在一些大型系统里,由于分工明确导致边界以外的代码量远大于边界内的代码量,而边界外的接口会给边界内UT/FT的开发带来较大成本,因此对边界外的接口打桩就是很常见的操作。

在纯C语言的系统里,对函数打桩的工具比较有限,而且使用上各有优缺点,本文要阐述的只是个人在工作中对函数打桩的总结。

CMocker原理

下图为Mock以前的正式流程,待测函数为process(),而process里调用了外部接口func,func的执行结果对process的流程有影响。

format,png

CMocker的原理如下图所示,将外部接口func(),替换成桩函数func_mock(),桩函数里指定一个回调函数(*func_callback)(),该回调函数指定的行为是与测试用例相关的,当某个用例需要改变func()的行为时,就指定回调函数(*func_callback)(),这样,在待测函数process()执行到Mocker以前的func()处时,就只会执行回调(*func_callback)()里的行为,这样就实现了在不同测试用例里指定不同行为的效果。

format,png

而对原有的业务代码里外部接口func -> func_mock的替换,实际上是通过头文件中定义宏来实现的隐式替换

#define func func_mock

从外表来看业务代码并未被修改过,这点很重要,原则上待测代码应该与正式运行时的代码相同,才能保证UT/FT防护的有效性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值