关于API测试
作者:网络转载 发布时间:[ 2012/6/18 14:05:34 ] 推荐标签:
首先要说明的是,“对API的测试”和“利用API进行测试”是两个概念;
对API的测试是以API为测试目标;那为何要进行对API的测试呢?
几个原因:
1、产品本身提供了API给外部客户,比如现在很多网站提供了OPEN API,还有很多微软的产品,诸如SharePoint,WSUS,都提供API给用户,这样用户可以做一些定制化,甚至是第二次的开发;
这种情况下,对API的测试,除了要测试API本身可以被使用之外(功能测试);还要经过性能测试,压力测试,兼容性测试,易用性测试;因为API本身是产品; 这个时候相当于对API进行了黑盒测试(不是说对API的测试一定是白盒测试或者灰盒测试),因为你相当于代表外面的客户(或者说是开发人员)对API进行使用;
2、产品本身并不提供API给外部客户,但是研发团队分析出对API进行测试有利于产品质量的稳定;或者说有利于提高“工程质量”(Engineering Quality),注意,不是Product Quality,因为测试了API,只能证明工程质量是OK的,API本身并不开放给终用户,终产品可能是桌面的程序,或者Web 程序,或者其他的UI;这些UI的体验还有提供的功能决定了终产品的质量;因为测试的模型像一个金字塔模型,越是底层的东西越容易自动化,规模化;所以通过对API进行测试,可以在回归测试的时候保证regression不会有太大问题;
讨论完了对API进行测试之后,再讨论一下利用API进行测试;
利用API进行测试,API不是测试的目标;比如说我想测试一个计算器的加法是否正确;通过UI我可以得到加法的结果,然后和期望的值进行比较;但是UI容易变;万一加号的ID变了或者其他因素变了,UI自动化得重写;维护成本相当高;那么如何更好的减少对UI的依赖呢?我可以通过调用产品本身用来计算加法的API,然后得出实际结果,再和期望值进行比较;因为API本身的变动小;所以测试的自动化的改动小;维护成本低;
另外一点对API进行测试或者利用API进行测试,不能Assume API是正确的,Dev也不觉得说这个API是正确的;所以我们调用这些API是想拿到实际的值(也是通过UI获得的值,我们姑且认为这2个是一致的,因为有小概率事件,这2者不一定一致,比如实际的UI调用的函数的参数和你所调用的函数的参数可能不一样);而期望的值是需要我们自己通过别的方式拿到的,不能用API来拿到(除非这个API已经被证明是正确的,比如OS API)
总而言之;研发本身是为了提高效果和效率;或者说是ROI;尽量减少对外界的依赖;尽量减少维护的成本,那么通过对API进行测试,或者利用API进行测试是可以从某种程度达到这样的目标。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11