Python测试框架pytest(14)用例执行后的几种状态

目录

1、PASSED

2、FAILED 

3、ERROR 

4、XFAIL 


用例执行完成后,每条用例都有自己的状态。

常见的状态:

  • PASSED:测试通过

  • FAILED:断言失败

  • ERROR:用例本身写的质量不行,本身代码报错(例如:fixture 不存在,fixture 里面有报错)

  • XFAIL:预期失败,加了 @pytest.mark.xfail()

1、PASSED

1、创建test_passed.py文件

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
微信公众号:AllTests软件测试
"""

def abc():
    a = "123456"
    return a

def test_case():
    assert abc() == "123456"

2、运行结果:

测试通过

2、FAILED 

示例一:

1、创建test_failed.py文件

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
微信公众号:AllTests软件测试
"""

def abc():
    a = "123456"
    return a

def test_case():
    assert abc() == "12345"

2、运行结果:

test_case测试用例调用abc函数的返回值进行断言,断言失败。

示例二:

1、创建test_failed2.py文件

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
微信公众号:AllTests软件测试
"""

def abc():
    a = "123456"
    return a

def test_case():
    raise NameError
    assert abc() == "123456"

2、运行结果:

test_case用例执行时抛出异常。

3、ERROR 

示例一:

1、创建test_error.py文件

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
微信公众号:AllTests软件测试
"""

import pytest

@pytest.fixture()
def abc():
    print("获取用户名")
    a = "AllTests"
    assert a == "AllTests"
    return a

def test_case(abcd):
    assert abc == "AllTests"

2、运行结果:

test_case函数引用不存在的fixture(abcd)

示例二:

1、创建test_error2.py文件

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
微信公众号:AllTests软件测试
"""

import pytest

@pytest.fixture()
def abc():
    print("获取用户名")
    a = "AllTests"
    assert a == "All-Tests"
    return a

def test_case(abc):
    assert abc == "AllTests"

2、运行结果:

fixture里面断言失败,所以fixture会报错。

test_case函数调用了错误的fixture,所以ERROR表示用例有问题。

4、XFAIL 

1、创建test_xfail.py文件

脚本代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
微信公众号:AllTests软件测试
"""

import pytest

# 断言装饰器
@pytest.mark.xfail(raises=ZeroDivisionError)
def test_f():
    1 / 0

2、运行结果:

代码有异常,且和raised的异常类匹配,所以是XFAIL(算测试通过的一种,表示符合期望捕捉到的异常),并不算FAILED

如果和raised的异常类不匹配,则是FAILED

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wangmcn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值