python接口自动化——pytest框架

1、pytest认识

(1)pytest比unnitest的优点

(2)pytest使用规则:

  • 测试文件以test_开头(以_test结尾也可以)
  • 测试类以Test开头,并且不能带有__init__方法
  • 测试函数以test_开头

(3)安装3.8.0版本:

>pip install pytest==3.8.0

(4)pytest一个简单的例子

#test_pyexample.py脚本
 
import time
#import pytest  不用导入,安装好以后可以直接用
 
def add(x,y):
    return x+y
def test_add():
    assert add(1,2)==3
 
def test_add2():
    print("I am 2")
    time.sleep(3)
    assert add(1.2,1.3)==5.3
    assert add(2,2)==4

pycharm控制台运行结果:

Launching pytest with arguments test_pyexample.py::test_add2 in E:\navy_lu\python\exercise_script\pytest_script

============================= test session starts =============================
platform win32 -- Python 3.7.1, pytest-3.8.0, py-1.8.0, pluggy-0.12.0
rootdir: E:\navy_lu\python\exercise_script\pytest_script, inifile:
plugins: sugar-0.9.2collected 1 item

test_pyexample.py FI am 2

test_pyexample.py:8 (test_add2)
5.3 != 2.5

Expected :2.5
Actual   :5.3
 <Click to see difference>

def test_add2():
        print("I am 2")
        time.sleep(3)
>       assert add(1.2,1.3)==5.3
E       assert 2.5 == 5.3
E        +  where 2.5 = add(1.2, 1.3)

test_pyexample.py:12: AssertionError
                                                      [100%]

================================== FAILURES ===================================
__________________________________ test_add2 __________________________________

    def test_add2():
        print("I am 2")
        time.sleep(3)
>       assert add(1.2,1.3)==5.3
E       assert 2.5 == 5.3
E        +  where 2.5 = add(1.2, 1.3)

test_pyexample.py:12: AssertionError
---------------------------- Captured stdout call -----------------------------
I am 2
========================== 1 failed in 3.16 seconds ===========================
Process finished with exit code 0

命令行运行结果:

(1)cd 到代码所在的目录,执行命令:py.test test_pyexample.py

(2)安装pytest-sugar插件可以看到进度条

测试结果如下:

2、pytest参数化:@pytest.mark.parametrize()

(1)单个参数

使用装饰器:@pytest.mark.parametrize()

import pytest
import random
 
@pytest.mark.parametrize('x',[(1),(2),(6)])
 
def test_add(x):
    print(x)
    assert  x==random.randrange(1,7)
 

运行结果:

 

(2)多个参数:

import pytest
 
@pytest.mark.parametrize('x,y',[
    (1+2,3),
    (2-0,1),
    (6*2,12),
    (10*2,3),
    ("test","test"),
])
 
def test_add(x,y):   #必须与上面保持一致,只能用x,y不能用其他字母
 
    assert  x==y

运行结果:

 

3、pytest多个assert:pytest-assume

安装插件:pip install pytest-assume

使用多个assert,结果中只有第一个错误,没有报出第二个

import pytest
 
def test_multiple_assert():
 
    assert (1==2)
    assert (2==2)
    assert (3==0)

执行结果:

 使用assume ,会把所有错误都报出来:

4、重新运行失败的用例:pytest- rerunfailures

安装插件:pip install pytest- rerunfailures

(pytest的安装路径)>pytest --reruns n 脚本路径,

(pytest的安装路径)>pytest -s --reruns n 脚本路径,

import random
 
def add(x,y):
    return x+y
 
def test_add():
    random_value=random.randint(2,7)
    print('random_value:'+str(random_value))
    assert add(1,3)==random_value

运行命令:

C:\Users\ldld0\AppData\Local\Programs\Python\Python37\Lib>

pytest --rerunsE:\navy_lu\python\exercise_script\pytest_script\test_pyexample_rerun.py

第一次运行:(整个过程:一共运行4次,第一次运行失败,后面重新运行3次都失败了)

 

第二次运行:(整个过程:一共运行了4次,第一次失败了,三个R,表示重新运行3次,第三次重新运行成功;如果重新运行第1次就成功了,就算设置的是重新运行3次,后面两次也不会再运行)

5、控制测试运行顺序:pytest--ordering

安装插件pip install pytest-ordering

借助于装饰器@pytest.mark.run(order=1)控制测试运行的顺序

import time
 
value=0
 
def test_add2():
    print("I am 2")
    time.sleep(2)
    assert value==10
 
 
def test_add():
    print("I am add")
    global value
    value=10

 

执行结果:

使用装饰器:

import pytest
import time
 
value=0
@pytest.mark.run(order=2) #后执行order=2
def test_add2():
    print("I am 2")
    time.sleep(2)
    assert value==10
 
@pytest.mark.run(order=1)   #先执行order=1
def test_add():
    print("I am add")
    global value
    value=10
    assert value==10

运行结果:

​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:485187702【暗号:csdn11】

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 希望能帮助到你!【100%无套路免费领取】

  • 27
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
<h3>回答1:</h3><br/>pytest是一个基于Python的测试框架,用于编写和运行测试用例。它提供了丰富的插件和扩展,可以轻松地进行接口自动化测试。pytest支持多种测试类型,包括单元测试、功能测试和集成测试等。它还提供了丰富的测试报告和日志,方便测试人员进行测试结果的分析和统计。总之,pytest是一个功能强大、易于使用的接口自动化测试框架,可以大大提高测试效率和质量。 <h3>回答2:</h3><br/>pytestPython编程语言的一个单元测试框架,是基于unittest框架的增强版。它具有扩展性、简洁性、可读性和易于使用等特点,广泛用于Python接口自动化测试。 pytest框架采用基于fixture标记的数据驱动测试,主要特点包括: 1、自动标记 pytest能够自动标记测试的类型,包括性能测试、功能测试、集成测试和端到端测试等,方便后续更好的统计和分析。 2、支持fixtures fixtures是一个函数,可以使得测试用例在执行前、执行过程中或执行后调用它,以获取所需要的测试数据、环境等信息。 3、高度可扩展 pytest可以根据具体业务需求扩展一些新的插件,例如Allure report、Pylint、Flake8等。 4、面向对象的设计 pytest框架采用面向对象的设计方法,可以灵活地使用各种语言特性来进行测试,并能够以简单和可读的方式来进行测试宏观分析。 5、报告清晰直观 pytest框架生成的测试报告清晰且易于查看,可以展示出失败用例的相关信息、性能分析数据等,方便了解整个测试过程。 6、多线程测试 pytest支持运行测试用例的多线程和多进程,提高了测试用例的执行速度。 总之,Python接口自动化框架pytestPython接口自动化测试中发挥了很重要的作用,其灵活性和可扩展性使它成为Python接口自动化框架中的佼佼者。无论是商业软件还是开源软件,都可以应用pytest进行接口自动化测试,帮助企业提高软件质量和测试效率。 <h3>回答3:</h3><br/>Python接口自动化测试框架pytest是一种基于Python语言的自动化测试框架,旨在提供简单易用的编写和管理测试用例的方式,同时还能够方便地集成其他工具和框架,如Selenium和Appium等。 使用pytest,可以轻松地创建测试套件、测试用例及其相关的测试数据,同时还能够使用多种丰富的断言方式进行结果验证。此外,pytest还支持多线程测试、测试结果报告生成、Testing Pattern等功能,以及一系列插件,这些插件能够提供额外的功能,比如分布式测试、按需测试等。 pytest的语法简单、易于读写,在编写测试代码时可以更加优雅和简便,比如分离设置数据和测试逻辑、使用fixture统一设置测试环境等等,从而改善测试代码阅读和维护的友好性。并且pytest支持多种测试场景,包括Web、API、数据库和UI测试等等,因此适用于不同类型的应用程序测试。 总之,使用pytest能够有效地提高测试效率和准确性,并且能够降低测试代码的维护成本和开发时间,因此在Python接口自动化测试框架中占据着重要的地位。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值