2026/5/21 19:48:02
网站建设
项目流程
安徽省住房城乡建设厅网站电工,怎么建个私人网站,企业外贸网站,关注江苏建设厅网站一、安装
需要安装的库
pytest
pytest-html 生成HTML格式的测试报告
pytest-xdist 用例分布式执行#xff0c;多CPU分发
pytest-ordering 改变用例执行顺序
pytest-rerunfailures 用例失败重跑
allure-pytest 生成allure测试报告
py…一、安装需要安装的库pytest pytest-html 生成HTML格式的测试报告 pytest-xdist 用例分布式执行多CPU分发 pytest-ordering 改变用例执行顺序 pytest-rerunfailures 用例失败重跑 allure-pytest 生成allure测试报告 pyYAML yaml文件库安装命令# 将要安装的库放到 requirements.txt 文件中然后执行 pip install -r requirements.txt二、语法1、模块名(用例文件名)必须以test_开头或者_test结尾2、测试类必须以Test开头且不能有init方法3、测试方法必须以test开头三、执行执行命令主函数# test_login.py import pytest class TestLogin: def test_01(self): print(用例1) if __name__ __main__: pytest.main() # 执行所有命令行# 在命令行中切换到对应目录下后直接命令行输入 pytest读取pytest.ini配置文件pytest.ini是pytest单元测试框架的核心配置文件用来改变pytest默认的行为1、一般放在项目的根目录;2、编码必须是ANSI[pytest] addopts -vs testpaths ./project python_files test*.py python_classes Test* python_functions testaddopts 命令行参数testpaths 测试用例文件夹python_files 搜索文件名python_classes 搜索的测试类名python_functions 搜索的测试方法名的开头执行命令参数-s 输入调试信息如用例中的print -v 打印信息更详细 文件名(或文件夹) 指定运行文件(或文件夹里文件)用例 -n 分布式运行 --reruns 2 失败重跑(失败重跑2次加上第一次一共跑了3次) -x 只要有一个用例报错测试停止 --maxfail2 最多出现两个用例报错测试停止 -k 方法名包含的字符 根据用例部分字符串执行指定用例例如# 主函数 pytest.main([-vs, test_login.py, -n2, --reruns2]) # 使用nodeid 执行指定方法 pytest.main([-vs, ./文件名/类名::方法名]) # 命令行 pytest -vs -n 2 --reruns 2 -k login 执行顺序unittest根据ASCII码pytest从上到下改变执行顺序# 使这个用例第一个执行 pytest.mark.run(order1) def test_login(): print(Done)分组执行pytest.ini文件添加markers smoke: 冒烟用例 login: 登录用例用例文件pytest.mark.smoke def test_login2(): print(Done)命令行执行命令pytest -vs -m smoke # 执行多个分组 pytest -vs -m smoke or login跳过测试用例# 无条件跳过 pytest.mark.skip(reason跳过原因) # 符合条件跳过 pytest.mark.skipif(num3, reason数量超过3个)四、前后置每个用例都有的功能可以集体提取出来比如UI自动化的执行前打开浏览器、执行结束后关闭浏览器的操作# test_login.py import pytest class TestLogin: # 在所有用例之前只执行一次 def setup_class(self): print(在类执行前执行比如创建日志对象、创建数据库连接) # 在每个用例之前都会执行一次 def setup(self): print(每个用例执行前先执行setup打开浏览器加载网页) def test_01(self): print(用例1) def teardown(self): print(每个用例执行结束后执行teardown关闭浏览器) def teardown_class(self): print(类执行结束后执行一次比如销毁日志对象、关闭数据库连接) if __name__ __main__: pytest.main() # 执行所有五、fixture用fixture实现部分用例的前后置pytest.fixture()参数scope被标记方法的作用域function默认、class、module、package/sessionparams参数化autouse自动执行默认Falseids使用params参数化时给每个值设置一个变量名name给被标记的方法起一个别名【当取了别名以后原名就不能用了】import pytest pytest.fixture() def my_fixture(): print(这是前置方法) yield print(这是后置方法) class TestLogin: def test01(self): print(用例1) # 这个用例执行前会先执行my_fixture方法 # 用例执行完后会执行my_fixture的yield def test_02(self, my_fixture): print(用例2)如果所有方法有前后置需要则在fixture里加参数autouseTrue用例里也不需要写fixture名调用pytest.fixture(autouseTrue) ...省略... class TestLogin: def test01(self): print(用例1)params参数化params支持列表、元组、字典列表、字典元组import pytest pytest.fixture(scopefunction, params[亚索, 凯南, 腕豪]) def my_fixture(request): yield request.param print(后置) class TestLogin: def test01(self, my_fixture): print(得到参数, my_fixture)工程应用通过conftest.py和pytest.fixture()结合使用实现全局前后置conftest.py 文件是单独存放fixture的配置文件用处是可以在不同的py文件中使用同一个fixture函数使用时原则上需要将conftest.py文件和用例放到同一层放在根目录貌似也可以并且不需要导入。且可以存在多个conftest.py文件放在不同文件夹中。调用也可以调用多个def test_01(self, my_fixture1, my_fixture2)上面调用方式就是先调my_fixture1再调用my_fixture2。六、数据驱动pytest.mark.parametrize(args_name, args_value)args_name参数名args_value参数值有多少参数值用例就会执行多少次例1import pytest class TestLogin: pytest.mark.parametrize(args, [北京, 上海, 广州]) def test_01(self, args): print(args) if __name__ __main__: pytest.main()例2import pytest class TestLogin: pytest.mark.parametrize(city, rank, [[北京, 1], [上海, 2], [广州, 3]]) def test_01(self, city, rank): print(city, rank) if __name__ __main__: pytest.main()七、报告1、下载allure解压配置环境变量2、添加执行参数 --alluredir可以去pytest.ini文件中修改如下。也可以在主函数中添加pytest.main([‘–alluredir./temp’])这样生成的json文件会放到temp文件夹中[pytest] addopts -vs --alluredir ./temp testpaths ./project python_files test*.py python_classes Test* python_functions test3、在主函数下增加代码if __name__ __main__: pytest.main() os.system(allure generate ./temp -o ./report --clean)感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走这些资料对于【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴上万个测试工程师们走过最艰难的路程希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取