近期通过自己的学习,完成了一个关于测试接口的接口自动化demo。
下面想跟大家分享一下,主要的思路是根据接口文档确定测试用例,并将测试用例写在excel中。
01
因为只是小作demo,测试用例我没有写的很全,有兴趣的大佬自己补充一下。
下面先分享接口文档,以及写在excel中的测试用例。
这里需要注意的是,测试用例一定要按照我这种格式写,否则下面封装的doExcel类将会无效。
现在测试文档和测试数据我们都有了,我们要明确我们要做到什么?
02
基于我目前所学,我最想做到的就是将测试数据与代码分离,执行代码产生的log会被记录下来。
测试完成之后生成测试报告,然后将测试报告以及log甚至将excel更新测试结果邮件发送给相关测试人员。
基于这个目的,主要引用的模块有unittest,ddt,openpyxl,logging,HTMLTestRunner,email,smtplib以及requests。
unittest是单元测试框架
ddt可以做到减少相同测试步骤的冗余代码
openpyxl模块可以从excel或者csv文档里面读写数据。
logging模块可以记录日志。
HTMLTestRunner可以生成测试报告
email和smtplib模块可以做到发送邮件
request模块则是做接口测试的必须
03
好,现在我们来理清一下思路。
1、测试用例有了,我们根据接口文档在代码中实现测试用例的代码化。
2、代码化的时候,发现测试步骤高度一直,可以使用ddt 模块来减少冗余代码。
3、光使用ddt模块,发现测试数据很多的情况下,把数据写在代码里还是很乱,于是考虑将测试用例excel文件的测试数据直接取出来,这就需要使用openpyxl模块了。
4、虽然这样做代码执行了,但是如果遇到代码错误的情况下,错误不好定位,执行步骤也不能人机友好的可视化,考虑到这一点,引入logging模块,在程序的各个步骤加上log。
5、现在log有了,执行完毕却没有个结果总结那可不行,咱们引入HTMLTestRunner模块来生成测试报告。
6、到这一步其实已经差不多了,但是既然测试报告以及log都有了,那执行完毕向相关测试人员发送这个测试报告以及log岂不是更完美吗?
于是乎,引入email以及smtplib模块,来解决这个问题。
04
既然思路已经有了,剩下来的就是动手实操了。
部分代码参考柠檬班python接口自动化的书,相对书上代码我有做出了改动并基于自己理解加以改进。
代码挺多,就不在社区里发出来了。
在各个模块中都有坑需要各位大佬去自己踩,踩完之后再填坑收获会更多。
时间太晚,写得比较仓促,大佬们轻喷。
网友评论