这是一个采用pytest框架,结合allure完成接口自动化测试的项目,最后采用allure生成直观美观的测试报告,由于添加了allure的特性,使得测试报告覆盖的内容更全面和阅读起来更方便。
- 使用pytest构建测试框架,首先配置好pytest.ini, 它会决定pytest的运行方式。
pytest.ini放在项目根目录下,名字不能改做其他。
data:image/s3,"s3://crabby-images/ae72a/ae72ab666ee55e2aa6486c15e324e7fa281e4cf6" alt=""
如上,pytest中配置了很多数据,包括命令行的参数,收集测试用例的目录和方式,日志显示的级别和方式以及形式。可以配置markers: ,不过我项目中用不着,就没配置。
- 参数化和接口依赖部分:使用了conftest.py来配置fixture, 放在根目录下,对项目下所有测试都覆盖。
data:image/s3,"s3://crabby-images/ed975/ed97582770bd846ada311ffb6292ac44550c987c" alt=""
- 测试用例部分,测试文件名注意以test开头,测试方法命名以test_开头,我的测试用例是存放在test文件夹下的.
测试用例上加了很多allure的特性,包括allure.story, allure.title, allure.severity, 其中allure.title部分做了参数化,可以动态生成测试标题,allure.severity这个部分很重要,能依据功能的重要程度去标记测试用例如果出现bug的严重等级,它的写法可以如下图在()内写入"normal", "critical", "blocker","minor", "trivial"这5个等级,默认是normal. 也可以这么写:在()内写入allure.severity_level.CRITICAL.
data:image/s3,"s3://crabby-images/484e7/484e7f697cf7e840c97fcd7a40ea26739caeb5fe" alt=""
- 接着,我们用命令行去执行测试,因为要结合allure输出allure报告,所以命令是
pytest -n auto --alluredir=allure
data:image/s3,"s3://crabby-images/c70df/c70df282ca531a22ff4b4a152e749e4378024498" alt=""
然后,窗口就返回执行的结果,执行了多少个用例,每个用例的执行结果
data:image/s3,"s3://crabby-images/31208/3120840dfe91a6eeddd6c2c6c8246df5cdfe0b45" alt=""
再看看allure文件夹下生成了一堆json, txt 文件,这并不是我们想要的,怎么生成美观的allure测试报告呢?
data:image/s3,"s3://crabby-images/7eb84/7eb846981d9ec54e87fb004540f580b511977ca4" alt=""
- 还需要最后一步,输入 allure serve allure, 它会生成一个allure测试报告
data:image/s3,"s3://crabby-images/d4c65/d4c65a185330ab77902dcde7d7230ba6e90fb9a2" alt=""
这样就生成了,美观直观的allure测试报告,上面有用例重要程度的图表。