转载请代表出处:http://www.javashuo.com/article/p-yiygkcyw-db.htmlhtml
简单介绍框架的实现逻辑,参考代码的git地址:python
https://github.com/zhangying123456/python_unittest_interfacegit
1.环境准备github
python3 + pycharm编辑器框架
2.框架目录展现编辑器
(该套代码只是简单入门,有兴趣的能够不断后期完善)函数
(1)run.py主运行文件,运行以后能够生成相应的测试报告,并以邮件形式发送;post
(2)report文件夹存放测试结果报告;学习
(3)unit_test文件夹是存放测试用例(demo.py和test_unittest.py用例用法介绍,实际项目中能够按照不一样模块新建python package,来存放不一样模块的接口用例);测试
(4)util对测试接口相关方法的封装:HTMLTestRunner.py生成测试报告的封装;send_mail.py发送邮件的封装;test_get_post.py接口请求类型的封装。
3.代码实现说明
(1)get、post接口请求实例介绍
【1】requests.get()、requests.post()用法能够参考文档:http://www.javashuo.com/article/p-vlkamtti-ea.html
【2】请求以后对返回结果进行断言:assertEqual()等,断言方法不少,可上网查询
(2)实际中,有些参数或方法在执行用例以前必须说明,这就涉及到setUp、tearDown、setUpClass、tearDownClass的用法
【1】setup():每一个测试函数运行前运行;teardown():每一个测试函数运行完后执行;setUpClass():必须使用@classmethod 装饰器,全部test运行前运行一次;tearDownClass():必须使用@classmethod装饰器,全部test运行完后运行一次
【2】也能够对某些用例执行过程当中跳过:unittest.skip(),具体使用方法可上网查询
(3)若是每次接口请求时都使用requests/get、post请求实在是繁琐,咱们能够对该方法进行封装,接口请求时直接调用便可
(4)测试用例编写完以后,主函数run.py直接使用unittest模块将全部用例一并执行
【1】unittest模块:TestSuite 多个测试用例集合在一块儿;TestRunner 是来执行测试用例的,测试的结果会保存到TestResult实例中,包括运行了多少测试用例,成功了多少,失败了多少等信息(unittest.TextTestRunner().run(suite))
【2】suite.addTests()和suite.addTest()都可实现
# 2种用法:第一种suite.addTest() suite.addTest(Case('test_case01')) suite.addTest(Case('test_case02')) suite.addTest(Test('test_01')) suite.addTest(Test('test_02')) #2种用法:第二种suite.addTests() suite.addTests(map(Test, ["test_01", "test_02"])) suite.addTests(map(Case, ["test_case01", "test_case02"]))
【3】TestRunner测试结果输出到控制台,要将测试结果输出到report中,使用HTMLTestRunner.py文件(该文件参考地址:https://github.com/huilansame/HTMLTestRunner_PY3)
(5)测试完成以后,想要将测试结果发送邮件给相关人员
发送邮件具体实现方法,参考文档:http://www.javashuo.com/article/p-rmamgiew-ec.html
说明:
1.代码中涉及到的测试数据都屏蔽掉了,能够直接使用本身负责项目的真实数据进行了解;
2.该套测试脚本相对基础,须要完善的地方还要不少,欢迎各位学习交流;
3.后续会再写一篇博客接口自动化测试(二),实现Excel来管理用例等。