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