Bootstrap

pytest测试框架搭建


一、pytest是什么?

  pytest是python的第三方测试框架,是基于unittest的扩展框架,比unittest更简洁,更高效。能够支持简单的单元测试和复杂的功能测试,还可以用来做selenium/appnium等自动化测试、接口自动化测试(pytest+requests);pytest具有很多第三方插件,并且可以自定义扩展,比较好用的如pytest-selenium(集成selenium)、pytest-html(完美html测试报告生成)、pytest-rerunfailures(失败case重复执行)、pytest-xdist(多CPU分发)等等

二、pytest的特点

  1. 非常容易上手,入门简单,文档丰富,文档中有很多实例可以参考
  2. 能够支持简单的单元测试和复杂的功能测试
  3. 支持参数化
  4. 执行测试过程中可以将某些测试跳过,或者对某些预期失败的case标记成失败
  5. 支持重复执行失败的case
  6. 支持运行由nose, unittest编写的测试case
  7. 具有很多第三方插件,并且可以自定义扩展
  8. 方便的和持续集成工具集成

三、pytest下载安装

pytest的官网地址是:https://docs.pytest.org/
在这里插入图片描述
需要注意先检查下python的版本,需要python 3.7以上版本
安装完python后,直接使用pip命令安装:

pip install -U pytest

安装后进行检查:

pytest --version

常用的插件安装:
pip install pytest-html:生成html格式的自动化测试报告

pip install pytest-xdist:测试用例分布式执行

pip install pytest-ordering:用于改变测试用例的执行顺序

pip install pytest-rerunfailures:用例失败后重跑

pip install pytest-assume:正常情况下一条用例如果有多条断言,一条断言失败了,其他断言就不会执行了,而使用pytest-assume可以继续执行下面的断言

allure-pytest:生成测试报告

四、pytest的配置

pytest框架不是pycharm自带的框架(pycharm默认框架为unittests),还需要配置一下,路径为:
File->Settings->Tools->Python Integrated Tools->Testing中的Default test runner把默认为的unittests改为pytest。
在这里插入图片描述

五、pytest约束规则

1、测试文件名要满足test_*.py格式或*_test.py格式
2、测试类名以Test开头,并且不能带有 init 方法(注意:定义class时,需要以T开头,不然pytest是不会去运行该class的)
3、类中,测试方法名以test开头,可以包含一个或多个test_开头的函数。 在执行pytest命令时,会自动从当前目录及子目录中寻找符合上述约束的测试函数来执行
4、批量执行,脚本名以 test 开头。

六、编写脚本

import pytest
 
# 被测试函数
def add(a, b):
    return a + b
 
class TestCase:
    # 测试脚本
    def test_add(self):
        assert 3 == add(1, 2)
 
 
if __name__ == '__main__':
    pytest.main()

七、pytest的运行方式

Pytest 运行方式共有三种:

1、主函数模式

  • 运行所有 pytest.main()
  • 指定模块 pytest.main(‘[-vs],’,‘./testcase/test_day1.py’) 只运行testcase 下的test_day1.py 文件
  • 指定目录 pytest.main(‘[-vs]’),‘./testcase’) 只运行testcase 目录下的文件
  • 通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成
    1.执行某个类:
pytest 文件名.py::类名  例如: #pytest.main(["-vs"],'./interface_testcase/test_day3.py::TestLogin')

2.执行某个方法

pytest 文件名.py::类名::方法名  例如:#pytest.main(["-vs"],'./interface_testcase/test_day3.py::TestLogin::test_01')

3.执行模块中某个方法:

pytest 文件名.py::方法名  例如:#pytest.main(["-vs"],'./interface_testcase/test_day3.py::test_demo11')

2、命令行模式

(1)运行所有:pytest

(2)指定模块 pytest -vs ./testcase/test_day1.py

(3)指定目录 pytest -vs ./testcase

(4)通过nodeid指定用例运行:nodeid由模块名,分隔符,类名,方法名,函数名组成

pytest -vs ./interface_testcase/test_day3.py::test_demo11
pytest -vs ./interface_testcase/test_day3.py::TestLogin::test_01_qianghong1

参数详解:

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

-v:显示更详细的信息

-vs:一起使用

-n:支持多线程或者分布式运行测试用例
主函数模式运行举例:

pytest.main(['-vs','./testcase/test_day1.py','-n=2'])

命令行模式运行举例:

pytest -vs ./testcase/test_day1.py -n 2

#reruns==number 表示失败用例重跑,举例如下:

pytest -vs ./testcase/test_day2.py --reruns 2
pytest.main(['–vs','./testcase/test_day2.py',‘reruns=2']) #失败得的用例重跑两次

#-x 表示只要一个用例报错,那么测试停止运行

#–maxfail=2 出现两个失败用例停止

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

pytest -vs test_day2 -k “yang”

3、通过读取pytest ini配置文件运行 (最主要运用的方式)

pytest.ini是pytest单元测试框架中的核心配置文件

(1)位置:一般是放在项目的根目录

(2)编码:必须是ANSI,可以使用notepad++来修改编码格式

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

(4)运行的规则:不管是主函数的模式运行该,命令行模式,都会区读取这个配置文件

常用参数
addopts 命令行的参数,用空格分隔

testpaths 测试用例的路径

markers 标记参数,赋值方式为 key:value

python_files 模块的命名规则 xx.py

python_classes 类名的命名规则 Xxx

python_functions 方法的命名规则 **

required_plugins 插件的使用

xfail_strict = true 禁用xpass

addopts: OPTS 命令行参数集

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

-v:显示更详细的信息

-vs:这两个参数一起用

-n :支持多线程或者分布式运行测试用例
如:pytest -vs ./testcase/test_login.py -n 2

–html : 测试报告位置

–reruns : 失败重跑

-p no:warnings : 取消警告

–ff : 先执行上次失败的用例

–lf : 只执行上次失败的用例

-x : 遇到测试用例fail,就结束测试

–maxfail=num:遇到num条测试用例fail, 就结束测试

-k :根据测试用例的部分字符串指定测试用例
如:pytest -vs ./testcase -k “ao”

简单的配置如下:
在这里插入图片描述

[pytest]
addopts=-vs --html ../report/report.html
testpaths=../testnormalcase
python_files=test_*.py
python_classes=Test*
python_functions=test_*
;