一、命令行方式运行

执行某个目录下所有的用例,符合规范的所有用例

       进入到对应的目录,直接执行pytest; 例如需要执行testcases 下的所有用例; 可以进入testcases 目录; 然后执行pytest

       进入对应目录的上级目录,执行pytest 目录名称/ ;  ; 例如需要执行testcases 下的所有用例; 可以在study_project 目录; 然后执行pytest testcases/

执行某一个py文件下用例

       pytest 脚本名称.py

运行.py模块里面的某个函数

pytest  test_mod.py::TestClass

运行.py模块里面的某个函数

pytest test_mod.py::test_func

运行.py模块里面,某个测试类

pytest test_mod.py::TestClass

运行.py模块里面,测试类里面的某个方法

pytest test_mod.py::TestClass::test_method

多种组合

pytest  test_mod1.py::TestClass::test_method test_mod2.py

标记运行

pytest  -m login  运行标记为login 的用例

二、main方法运行

一般在项目根目录指定需要运行的路径和参数

pytest 不会执行重复用例 pytest运行指定用例_用例

三、通过全局配置文件pytest.ini

pytest.ini应该放哪里?就放在项目根目录下 ,不要乱放,不要乱起其他名字

常用的配置项

marks

作用:测试用例中添加了 @pytest.mark.webtest 装饰器,如果不添加marks选项的话,就会报warnings

格式:list列表类型

写法:

# mark
markers =

smoke:冒烟用例


     order: 订单用例


product: 商品用例

更改测试用例收集规则

pytest默认的测试用例收集规则

  •  文件名以 test_*.py 文件和 *_test.py
  •  以  test_ 开头的函数
  •  以  test 开头的类,不能包含 __init__ 方法
  •  以  test_ 开头的类里面的方法

我们是可以修改或者添加这个用例收集规则的;当然啦,是建议在原有的规则上添加的,如下配置:

testpaths=testcases/test_study/

python_files =test_*  *_test  test*

python_classes =Test*   test*

python_functions =test_*  test*

备注: testpaths=testcases/test_study/  如果在项目根目录执行pytest,那么就会以当前执行目录为相对路径,执行根目录下的testcases下的test_study下的文件会执行;其他不执行

例如:

pytest 不会执行重复用例 pytest运行指定用例_测试用例_02

 输出:

pytest 不会执行重复用例 pytest运行指定用例_测试用例_03

addopts

作用:addopts参数可以更改默认命令行选项,这个当我们在cmd输入一堆指令去执行用例的时候,就可以用该参数代替了,省去重复性的敲命令工作

# 例如命令行参数,失败重跑两次,一共运行两次,生成测试报告

addopts = -v --reruns=1 --count=2 --html=reports.html --self-contained-html -n=auto

log_cli

作用:控制台实时输出日志

格式:log_cli=true 或false(默认),或者log_cli=1 或 0

pytest 不会执行重复用例 pytest运行指定用例_pytest 不会执行重复用例_04