从0到1精通自动化测试,pytest自动化测试框架,allure标记用例级别severity(二十一)

目录

一、前言

二、用例等级

三、pytest用例

四、统计缺陷

五、allure命令行参数allure-severities


一、前言

我们在做功能测试的时候,执行完一轮测试用例,输出测试报告的时候,会有统计缺陷的数量和等级

在做自动化测试的过程中,当你的测试用例越来越多的时候,如果执行一轮测试发现了几个测试不通过,我们也希望能快速统计出缺陷的等级

pytest结合allure框架可以对用例的等级做详细的划分

二、用例等级

allure对用例的等级划分成五个等级:

blocker:阻塞缺陷(功能未实现,无法下一步)

critical:严重缺陷(功能点缺失)

normal:一般缺陷(边界情况,格式错误)

minor:次要缺陷(界面错误与ui需求不符)

trivial:轻微缺陷(必须项无提示,或者提示不规范)比如我的用例有以下4条

那么对应的用例的等级应该是

1.修改个人信息-sex参数为空 这个属于边界值情况的测试,应该是normal级别

2.修改个人信息-sex参数传F和M两种类型,成功(枚举类型) 这个是针对接口的功能点详细测试 critical级别

3.修改个人信息-修改不是本人的用户信息,无权限操作 这个是针对接口的功能点详细测试 critical级别

4.修改个人信息-修改自己的个人信息,修改成功 这是用例是测试主流程 blocker级别

三、pytest用例

根据测试用例的重要性划分测试用例等级,如果没指定等级,默认为normal级别

import pytest
import allure
'''

@allure.severity装饰器按严重性级别来标记case   
执行指定测试用例 --allure-severities blocker
BLOCKER = 'blocker'  阻塞缺陷
CRITICAL = 'critical' 严重缺陷
NORMAL = 'normal'    一般缺陷
MINOR = 'minor'      次要缺陷
TRIVIAL = 'trivial'  轻微缺陷 
'''

@allure.severity("normal")
def test_case_1():
    '''修改个人信息-sex参数为空'''
    print("test case 11111111")


@allure.severity("critical")
def test_case_2():
    '''修改个人信息-sex参数传F和M两种类型,成功(枚举类型)'''
    print("test case 222222222")

@allure.severity("critical")
def test_case_3():
    '''修改个人信息-修改不是本人的用户信息,无权限操作'''
    print("test case 333333333")

@allure.severity("blocker")
def test_case_4():
    '''修改个人信息-修改自己的个人信息,修改成功'''
    print("test case 4444444")

def test_case_5():
    '''没标记severity的用例默认为normal'''
    print("test case 5555555555")

cd到用例的目录,执行用例,查看报告

pytest —alluredir ./report/allure
allure serve ./report/allure

 查看报告详情

四、统计缺陷

如果执行用例的过程中有测试用例不通过的情况,也可以统计缺陷的严重等级

# 修改上面2个用例,故意让用例失败
@allure.severity("blocker")
def test_case_4():
    '''修改个人信息-修改自己的个人信息,修改成功'''
    print("test case 4444444")
    assert 1==2

def test_case_5():
    '''没标记severity的用例默认为normal'''
    print("test case 5555555555")
    assert 1==2

重新执行用例,查看报告-图表

五、allure命令行参数allure-severities

pytest -h可以查看到allure相关的几个命令行参数
—allure-severities=SEVERITIES_SET
             Comma-separated list of severity names. Tests only
             with these severities will be run. Possible values
             are: blocker, critical, normal, minor, trivial.
如果有很多测试用例,现在只想做个快速的回归测试,只测试用例级别为blocker和critical级别的测试用例

pytest —alluredir ./report/allure —allure-severities blocker,critical

 也可以这样写

pytest —alluredir=./report/allure —allure-severities=blocker,critical

 如果只执行blocker级别的用例

pytest —alluredir=./report/allure —allure-severities=blocker

          【下面是我整理的2023年最全的软件测试工程师学习知识架构体系图】


一、Python编程入门到精通


二、接口自动化项目实战  

三、Web自动化项目实战


四、App自动化项目实战 

五、一线大厂简历


六、测试开发DevOps体系 

七、常用自动化测试工具


八、JMeter性能测试 

九、总结(尾部小惊喜)

生命不息,奋斗不止。每一份努力都不会被辜负,只要坚持不懈,终究会有回报。珍惜时间,追求梦想。不忘初心,砥砺前行。你的未来,由你掌握!

生命短暂,时间宝贵,我们无法预知未来会发生什么,但我们可以掌握当下。珍惜每一天,努力奋斗,让自己变得更加强大和优秀。坚定信念,执着追求,成功终将属于你!

只有不断地挑战自己,才能不断地超越自己。坚持追求梦想,勇敢前行,你就会发现奋斗的过程是如此美好而值得。相信自己,你一定可以做到!  

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值