pytest自动化测试用例管理,常用功能简介

一、使用pytest默认的测试用例的规则以及基础应用

1. 模块名必须用test_开头或者_test结尾(例如:test_login.py)

2. 测试类必须以Test开头,并且不能有init方法(class TestLogin:)

3. 测试方法必须以test开头(def test_01_baili)

二、pytest测试用例的运行方式

1. 主函数模式

直接路径下,新增一个all.py

Import pytest

If __name__ == ‘__main__’:

    Pytest.main()

(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_04_func’])

pytest.main([‘-vs’,’./interface_testcase/test_interface.py::TestInterface::test_04_func’])

(5)多线程运行

pytest.main([‘-vs’,’./interface_testcase/test_interface.py’,“-n=2”])

(6)失败重跑

pytest.main([‘-vs’,’./interface_testcase/test_interface.py’,“--reruns=2”])

2.命令行模式:

(1)运行所有:pytest

(2)指定模块: pytes –vs test_login.py

(3)指定目录:pytest –vs ./interface_testcase

(4)通过nodeid指定用例运行:

pytest –vs ./interface_testcase/test_interface.py::test_04_func

(5)多线程运行:

pytest –vs ./interface_testcase/test_login.py –n 2  #2个线程

(6)失败重跑

pytest –vs ./interface_testcase/test_login.py –reruns 2

3. 通过读取pytest.ini全局配置文件运行(企业里经常用的)

Pytest.ini这个文件它是pytest单元测试框架的核心配置文件。

1.位置:一般放在项目的根目录,名字必须是’pytest.ini’不能变

2.编码:必须是ANSI,可以使用notpad++修改编码格式

3.作用:改变pytest默认的行为

4.运行规则:不管是主函数的模式运行,命令行模式运行,都会去读取。

 

[pytest]

adopts = -vs             #命令行的参数

testpaths = ./tstcase       #测试用例的路径

python_files = test_*.py    #模块名的规则

python_classes=Test*      #类名的规则

python_functions =test    #方法名的规则

4. 参数详解:

-s:表示输出调试信息,包括print打印的信息

-v:详细信息模式(模块名::类名::方法名)

-vs: 这2个参数一起用

-n:支持多线程或者分布式运行测试用例

pytest –vs ./interface_testcase/test_login.py –n 2  #2个线程

--reruns NUM: 失败用例重跑

-x: 表示只要有一个用例失败就停止。

--maxfail=2: 出现2个以上的失败就停止。

-k: 根据测试用例的部分字符串指定执行用例

如:pytest –vs ./testcase –k “ao”

三、Pytest执行测试用例的顺序是怎么样的

默认:从上向下执行测试用例

指定顺序执行: 使用mark标记。

@pytest.mark.run(order=1)

四、如何分组执行(冒烟,分模块执行,分接口和web执行)

1.在pytest.ini 配置文件里添加如下内容
markers =

         smoke: 冒烟用例

         usermanage: 用户管理

2. 在测试用例添加装饰器: @pytest.mark.smoke

3. 运行: pytest –vs –m “smoke”

 

4.同时执行2个: pytest –vs –m “smoke or usermanage”

五、pytest 跳过测试用例

1. 无条件的跳过

@pytest.mark.skip(reason=”跳过”)

2. 有条件的跳过

@pytest.mark.skipif(age >=18, reason=”已成年”)

六.报告

Pytest.ini 文件中

添加: adopts = -vs --html ./report/report.html

运行pytest默认就会执行pytest.ini(全局变量)

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Pytest 是一个常用Python 测试框架,用于编写和执行自动化测试用例。以下是 Pytest 接口自动化测试的一般步骤: 1. 安装 Pytest:使用 pip 工具安装 Pytest,可以通过以下命令进行安装: ``` pip install pytest ``` 2. 准备测试文件:创建一个以 `test_` 开头的 Python 文件,例如 `test_api.py`。 3. 导入依赖库:在测试文件中,导入需要用到的依赖库,例如 requests 库用于发送 HTTP 请求,json 库用于处理 JSON 数据等。 4. 编写测试用例:在测试文件中,编写测试用例。使用 `def` 关键字定义一个测试函数,函数名以 `test_` 开头,例如 `test_login()`。 5. 准备测试数据:根据测试需要,准备好需要发送的请求数据和预期的响应结果。可以将测试数据保存在一个字典中,方便后续使用。 6. 发送请求并断言:在测试用例中,使用相应的方法发送请求,并通过断言语句对响应结果进行验证。例如使用 requests 库发送 POST 请求,并使用 assert 语句判断返回的状态码和响应内容是否符合预期。 7. 执行测试用例:在终端中切换到测试文件所在目录,并执行以下命令运行测试用例: ``` pytest ``` 8. 查看执行结果:Pytest 会自动搜索当前目录及其子目录中以 `test_` 开头的文件,并执行其中的测试用例。执行完毕后,会显示测试用例的执行结果,包括通过的用例数、失败的用例数和运行时间等信息。 以上就是使用 Pytest 进行接口自动化测试的一般步骤。根据具体的测试需求,可以进一步优化测试结构和编写更多的测试用例
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值