单元测试:是指在软件开发当中,针对软件最小单位(函数,方法)进行正确性的检查测试。
1.单元测试框架主要做什么?
1.测试发现:从多个文件里面去找到我们测试用例
2.测试执行:按照一定的顺序和规则去执行,并生成结果
3.测试判断: 通过断言判断预期结果和实际结果的差异。
4.测试报告:统计测试进度,耗时,通过率,生成测试报告。
2.自动化作用
1.提高测试效率,降低维护成本
2.减少人工干预,提高测试的准确性,增加代码的重用性。
3.核心思想是让不懂代码的人也能够通过这个框架去实现自动化测试。
3.pytest相关插件
pytest
pytest-html 生成html格式的自动化报告
pytest-xdist 测试用例分布式执行,多CPU分发
pytest-ordering 用于改变测试用例的执行顺序
pytest-rerunfailures 用于失败后重跑
allure-pytest 用于生成美观的测试报告
将以上插件放到requirement.txt中,通过终端输入pip install -r requirements.txt来安装插件
4.pytest默认的测试规则
1.模块名必须以test_开头或者__test结尾。
2.测试类必须以Test开头,并且不能有init方法。
3.测试方法必须以test开头。
5.pytest测试运行方式
1.在主函数模式中运行
(1)运行所有:pytest.main()
(2) 指定模块: pytest.main([‘-vs’, ‘test_login.py’])
(3) 指定目录:pytest.main([‘-vs’, ‘./interface_testcase’])
(4) 通过nodeid指定用例运行:nodeid由模块名、分隔符、类名、方法名、函数名组成。
pytest.main([‘-vs’, ‘./interface_testcase/test_interface.py::test_01_func’])
2.命令行模式运行
(1)运行所有:pytest
(2) 指定模块: pytest -vs test_login.py
(3) 指定目录:pytest -vs ./interface_testcase
参数详解
-s : 表示输出调试信息,包括print打印的信息
-v:显示更详细的信息
-vs: 这两个参数一起用
-n: 支持多线程或者分布式运行测试用例。
如:pytest -vs ./testcase/test_login.py -n 2
–reruns NUM:用于失败后重跑
-x: 表示只要有1个用例报错,那么测试就会停止。
–maxfail=2 : 出现两个用例失败就停止。
-k: 根据测试用例的部分字符串指定测试用例。
如:pytest -vs ./testcase/test_login.py -k “ao”
–html ./report/report.html: 生成html的测试报告。
3.通过读取pytest.ini配置文件运行。
pytest.ini文件是pytest单元测试框架的核心配置文件。
1.位置:一般放在项目的根目录
2.编码:必须是ANSI,可以使用notpad++修改编码格式
3.作用:改变pytest默认的行为
4.运行的规则:不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件。
[pytest]
# 命令行参数,用空格分隔
addopts = -vs
# 测试用例文件夹,可自己配置, ../pytestproject为上一层的pytestproject文件夹
testpaths = ../pytestproject
# 配置测试搜索的模块文件名称
python_files = test*.py
# 配置测试搜索的测试类名
python_classes = Test*
# 配置测试搜索的测试函数名
python_functions = test
备注:运行时需要把上面中文注释去掉。
6.pytest执行用例顺序
unittest: ascll的大小来绝对的执行顺序
pytest : 默认从上到下
改变默认的执行顺序: 使用mark标记。
@pytest.mark.run(order=1)
7.分组执行(冒烟,分模块执行,分接口和web执行)
smoke: 冒烟测试,分布在各个模块里面
pytest -vs -m "smoke"
pytest -vs -m "smoke or usermanage"
8.跳过测试用例
(1)无条件跳过
@pytest.mark.skip(reason-"微微太漂亮")
(2)有条件跳过
@pytest.mark.skipif(age>=18, reason='已成年')