java有:junit和testng
python有:unittest和pytest
单元测试框架主要做什么:
1.测试发现:从多个文件里面去找到我们的测试用例
2.测试执行:按照一定的顺序和规则去执行。并生成结果
3.测试判断:通过断言判断预期结果和实际结果的差异
4.测试报告:统计测试进度,耗时,通过率,生成测试报告
1)什么是自动化测试框架
它就是自动化测试组长针对一个项目开发的一个代码框架,这个框架封装了很多的基础模块,报告模块等等
2)作用:
1.提高测试效率,降低维护成本
2.减少人工干预,提高测试的准确性,增加代码的重要性
3.核心思想是让不懂代码的人也能通过这个框架去实现自动化测试
3)pytest单元测试框架和自动化测试框架的关系
单元测试框架:只是自动化测试框架中的组成部分之一
pom设计模式:只是自动化测试框架中的组成部分之一
数据驱动...
关键字驱动
全局配置文件的封装
日志监控
selenium,requests二次封装
断言
报告邮件
更多......
1.pytest是一个非常成熟的python的单元框架,比如unittest更灵活,容易上手
2.pytest可以和selenium,requests,appium结合实现web自动化,接口自动化,app自动化
3.pytest可以实现测试用例的跳过以及reruns失败用例重试
4.pytest可以和allure生成美观的测试报告
5.pytest可以和Jenkins持续集成
6.pytest有很多非常强大的插件,并且这些插件能够实现很多的实用的操作
pytest 本身(第一个插件)
pytest-html 用于生成html格式的自动化测试报告
pytest-xdist 测试用例分布式执行。多CPU分发
pytest-ordering 用于改变测试用例的执行顺序
pytest-rerunfailures 用例失败后重跑
allure-pytest 用于生成美观的测试报告
1.模块必须以test_开头或者_test结尾
2.测试类必须以Test开头,并且不能有init方法
3.测试方法(测试用例)必须以test开头
1.主函数模式
1)运行所有:pytest.main()
2)指定模块:pytest.main(['-vs','aaa_login.py'])
3)指定目录:pytest.main(['-vs','./interface_testcase'])
4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成(:: --分割符)
# 只执行test_interface.py用例文件中的test_04_fanc函数
pytest.main(['-vs',"./interface_testcase/test_interface.py::test_04_fanc"])
# 只执行test_interface.py用例文件中的TestInterface类下的test_03_wuyong方法
pytest.main(['-vs', "./interface_testcase/test_interface.py::test_04_fanc"])
pytest.main(['-vs',"./interface_testcase/test_interface.py::TestInterface::test_03_wuyong"])
5)失败重跑:
pytest.main(['-vs',"./testcase",'--reruns=2'])
6)失败后只要有一个用例报错,那么测试就停止:
pytest.main(['-vs',"./testcase",'-x'])
7)最大失败用例数为2:
pytest.main(['-vs',"./testcase",'--maxfail=2'])
8)根据测试用例的部分字符串指定测试用例:
pytest.main(['-vs',"./testcase",'-k',"an"])
2.命令行模式
1)运行所有:pytest
2)指定模块:pytest -vs aaa_login.py(需要在文件相对路径下输入此命令,否则则需要使用绝对路径)
3)指定目录:pytest -vs ./interface_testcase(需要在文件相对路径下输入此命令,否则则需要使用绝对路径)
4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成(:: --分割符)
pytest -vs ./interface_testcase/test_interface.py::test_04_fanc
pytest -vs ./interface_testcase/test_interface.py::TestInterface::test_03_wuyong
5)失败重跑:
pytest -vs ./testcase --reruns=2
6)失败后只要有一个用例报错,那么测试就停止
pytest -vs ./testcase -x
7)最大失败用例数为2:
pytest -vs ./testcase --maxfail=2
8)根据测试用例的部分字符串指定测试用例:
pytest -vs ./testcase -k "an"
参数详解:
-s:表示输出调试信息,包括print打印的信息
-v:显示更详细的信息
-vs:这两个参数可以一起用
-n:支持多线程或者分布式运行测试用例
如:pytest -vs ./testcase/aaa_login.py -n 2
--reruns NUM:失败用例重跑
-x:表示只要有一个用例报错,那么测试停止
--maxfail=num:用例允许失败的最大次数,超出则立即停止执行
-k:执行包含关键字的用例
如:pytest -vs ./testcase -k "an"
--html ./report/report.html:在当前目录下report路径下生成一个report.html的测试报告
-q:只显示整体测试结果(简要信息)
-m:只执行标记的用例
-l:用例失败时打印相关局部变量
-c:从指定目录加载配置文件,而非自动查找配置文件
-lf:只执行上次失败的用例,若没有则执行全部用例
-tb=style:用例失败时错误的详细程度(auto/long/short/line/native/no)
--collect-only:收集但不执行用例
--durations=num -vv:显示设定数值内,按照耗时时长降序打印结果,通过用于调优
-h:--help 帮助
3.通过读取pytest.ini全局配置文件运行
pytest.ini这个文件它是pytest单元测试框架的核心配置文件。
1.位置:一般放在项目的根目录
2.编码格式:必须是ANSI,可以使用notpad++修改编码格式
3.作用:改变pytest默认的行为
4.运行规则:不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件
[pytest]
# 命令行参数,用空格分割
addopts = -vs -p no:warnings --html ./report/report.html # -p no:warnings:去除掉使用pytest执行用例显示1个warnings,但不影响测试用例执行(忽略pytest警告)
# 测试用例的路径,./testcase为当前路径下的testcase文件夹
testpaths = ./testcase
# 模块名的规则
python_files = test*.py
# 类名的规则
python_classes = Test*
# 函数名的规则
python_functions = test
# markers标记用例,为了实现在多个用例里分组执行
markers =
smoke:冒烟用例
user:用户管理模块
productmanage:商品管理模块
unittest:ascii的大小来决定的执行的测试
pytest:默认从上到下
改变默认的顺序:使用mark标记
@pytest.mark.run(order=num) # num代表执行顺序
例:@pytest.mark.run(order=3)
smoke:冒烟用例,分布在各个模块里面
# 按自定义的标记组名称执行用例
pytest -vs -m "smoke"
pytest -vs -m "smoke or user" # 多个组要执行时用or连接组名
1)无条件跳过
@pytest.mark.skip(reason='无条件跳过') # skip就一个参数:reason='':打印无条件跳过的原因
2)有条件跳过
@pytest.mark.skipif(age<=18,reason='未成年跳过此用例(有条件跳过)') # skipif的参数前面放跳过条件,最后reason=跳过打印的原因
项目学习代码源码链接地址如下:
https://download.csdn.net/download/weixin_63069325/78124726
注:有任何疑问大家可以在该文章下发言讨论,作者看到后会逐一回复问题的