如何使用pytest组织自动化测试用例结构?

news2024/12/23 13:41:41

如何组织自动化测试工程的目录结构?这篇文章介绍了我是如何组织整个自动化工程目录结构的,本篇介绍下我是如何利用pytest框架组织一个测试用例文件的。

用例文件组织原则

整个testsuite目录下整体上按照特性模块划分目录,每个目录下可以只包含一个"test"开头的用例文件,也可以根据实际情况包含多个用例文件,尽量做到每个用例文件"test_xxx.py"只编写特性比较接近的用例,而且建议不要在一个文件中写过多的用例。

单个用例文件(test_xxx.py)如何组织用例结构

如果用例结构组织不合理,往往积累到一定量的用例时就会发现再增加用例时就会受制于各种因素的影响而举步维艰,往往为了规避影响需要写大量冗余代码,这样的惩罚可能还不足以让你记忆深刻,最痛苦的莫过于大量的自动化用例并发运行时一些意想不到的因素互相影响导致通过率始终无法达到预期的目标,调试、定位、修复用例消耗大量精力。解决这些问题需要有丰富的经验,开始编写用例时就精心组织、潜心思考、仔细推敲,就是付出成本最小的办法。

pytest框架可以很方便地组织我们的测试用例,默认配置下pytest会识别test开头的文件和test开头的方法,每一个方法就会被当做一个测试用例,就像下面这个示例文件包含了n个测试用例,拉起自动化任务时这些方法都会被运行。

# 用例文件名:test_feature01.py
# setup和teardown代码
...
def test_用例001:
  # 用例代码
  ...
  
def test_用例002:
  # 用例代码
  ..
  
def test_用例00n:
  # 用例代码
  ...

编写测试用例和开发写代码也是类似的,都有一些通用的原则,下面几个是针对测试用例代码比较重要的原则:

  • DRY原则:Don't Repeat Yourself,意思就是不要写重复代码,重复代码写得越多,你就会发现后面自动化维护就是个噩梦。实际判断的原则就是,如果你发现有些代码你需要再大于2个地方使用它,就要想办法把它封装为一个关键字。

  • 每个用例都要添加检查点,否则用例就没有任何意义了,pytest框架只需要使用assert进行检查就可以了。

  • 每个测试用例要能够独立执行,不能与其他用例有任何顺序依赖等关系。

每一种产品的自动化场景千差万别,大家公认的自动化用例的执行步骤包括环境初始化setup-->用例执行-->环境清理teardown三大部分,使用pytest的fixture固件可以很方便地实现模块级、方法级的setup和teardown(还支持会话级的),自动化测试用例编写人员的代码技能一般都不会太高,最好是能形成统一的用例模板和用例编写规范,测试人员只要按照模板级规范要求去写测试用例代码就可以了,下面是我使用的一种用例组织结构(项目中实际使用的自动化测试用例代码,摘取了关键部分),关键在注释中进行了一一说明,对其他的代码不需要做过多关注,只需要关注整个用例的执行流程即可。

# 文件名:test_远程扫描配置.py
import pytest

from logic.logic import *
from logic.mysql import *
from conf.settings import *
from utils.utils import *

""" 这是一个模块级setup及teardown示例
	1- yield之前的部分为setup,之后的部分为teardown
  2- 拉起自动化后该文件下的所有用例执行前只进行一次系统登录和打开菜单的操作
	(因为都是同一个菜单下的特性用例)
  3- 该文件下的所有用例执行完毕后仅执行一次系统关闭操作	
"""
@pytest.fixture(scope="module")
def csam():
   # 该特性下所有用例公共使用的初始化配置都放在yield之前编写
    csam = CSAM()
    log.info("======setup======")
    csam.login()
    csam.menu("远程扫描配置")		
    yield csam		
		# 该特性下所有用例公共使用的初始化配置清理放在yield之后编写
    log.info("======teardown======")
    csam.driver.quit()
		
""" 这是一个方法级setup及teardown示例
	1- yield之前的部分为setup,之后的部分为teardown
  2- 每个用例执行前都会执行一次yield之前的代码
  3- 每个用例执行后都会执行一次yield之后的代码	
"""
@pytest.fixture
def setup(csam):
		# 每个用例独立的初始化配置放在yield之前编写
    # ts是一个时间戳字符串,目的是为每个用例提供一个唯一的标识符供用例代码使用
    # 主要是为了避免创建的配置信息出现重名等问题
    ts = timestamp()
    yield csam, ts
    # 每个用例独立的配置清理放在yield之后编写
		# 其中清理部分的代码也使用ts这个时间戳,主要目的为了避免删除了其他用例的配置而导致影响
    mysql.run("delete from csam.rs_task where task_name like '%{0}%';".format(ts))
    mysql.run("delete from csam.scan_targets where name like '%{0}%';".format(ts))
    pgsql.run("delete from schedules where name like '%{0}%';".format(ts))
    pgsql.conn.commit()

def test_探测任务_扫描任务管理_新增扫描任务_资产扫描(setup):
    csam, ts = setup
    csam.button_click(name="新增")
    csam.dropdown_menu_select("资产扫描")
    asset_scan = {
        "name": "asset_{0}".format(ts),
        "desc": "资产扫描",
    }
    csam.scan_task_basic(asset_scan)
    csam.button_click(name="下一步")
    # 新增扫描目标
    csam.link_click(name="新增")
    target = {
        "name": "target_{0}".format(ts),
        "ip": "192.168.30.148",
        "gport": "TOP 10",
        "desc": "auto test",
    }
    csam.scan_target_new(target)
    csam.button_click(name="保 存")
    csam.button_click(name="下一步")
    csam.button_click(name="保存")
    # 结果检查
    assert csam.text(csam.table_cell_filter(asset_scan["name"], "任务名称", "任务名称")) == asset_scan["name"]
    assert csam.text(csam.table_cell_filter(asset_scan["name"], "任务名称", "任务类型")) == "资产扫描"
    assert csam.text(csam.table_cell_filter(asset_scan["name"], "任务名称", "扫描状态")) in ["未执行", "执行中", "执行完成"]
    assert csam.text(csam.table_cell_filter(asset_scan["name"], "任务名称", "扫描目标")) == target["name"]

def test_探测任务_扫描任务管理_新增扫描任务_漏洞扫描(setup):
    csam, ts = setup
    csam.button_click(name="新增")
    csam.dropdown_menu_select("漏洞扫描")
    vul_scan = {
        "name": "vul_{0}".format(ts),
        "desc": "漏洞扫描",
    }
    csam.scan_task_basic(vul_scan)
    csam.button_click(name="下一步")
    # 新增扫描目标
    csam.link_click(name="新增")
    target = {
        "name": "target_{0}".format(ts),
        "ip": "192.168.30.148",
        "gport": "All IANA assigned TCP",
        "desc": "扫描目标",
    }
    csam.scan_target_new(target)
    csam.button_click(name="保 存")
    csam.button_click(name="下一步")
    # 新增漏扫计划
    csam.link_click(name="新增")
    csam.input_set("plan_{0}".format(ts), label="计划名称")
    csam.datetime_set(datetime_shift(days=10), label="第一次执行时间")
    csam.datetime_set(datetime_shift(days=12), label="第一次结束时间")
    csam.select_dropdown("一次", label="重复频率")
    csam.textarea_set("漏扫计划", label="说明")
    csam.button_click(name="保 存")
    csam.button_click(name="保存")
    # 结果检查
    assert csam.text(csam.table_cell_filter(vul_scan["name"], "任务名称", "任务名称")) == vul_scan["name"]
    assert csam.text(csam.table_cell_filter(vul_scan["name"], "任务名称", "任务类型")) == "漏洞扫描"
    assert csam.text(csam.table_cell_filter(vul_scan["name"], "任务名称", "扫描器")) == "脚本库扫描器"
    assert csam.text(csam.table_cell_filter(vul_scan["name"], "任务名称", "扫描状态")) in ["未执行", "执行中", "执行完成"]
    assert csam.text(csam.table_cell_filter(vul_scan["name"], "任务名称", "扫描目标")) == target["name"]

# 后面的用例代码省略了...

针对示例,用例在执行期间的执行流程示意见下图

图片

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1883953.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python容器 之 列表--下标和切片

列表的切片 得到是 新的列表字符串的切片 得到是 新的字符串 如果下标 不存在会报错 list1 [1, 3.14, "hello", False] print(list1)# 获取 列表中 第一个数据 print(list1[0]) # 1# 获取列表中的最后一个数据 print(list1[-1]) # [False]# 获取中间两个数 即 3.1…

币界网快讯,比特币7月份看牛预测

今日数字货币市场全面开启反弹,比特币从 60,000 美元大关飙升至 63,700 美元,预示着 7 月牛市的到来。在此之前,上周曾短暂跌破 60,000 美元,但受到 BTC 现货 ETF 流入的 7,300 万美元的推动——这是两周以来最大的流入。 BTC价格…

Linux下SUID提权学习 - 从原理到使用

目录 1. 文件权限介绍1.1 suid权限1.2 sgid权限1.3 sticky权限 2. SUID权限3. 设置SUID权限4. SUID提权原理5. SUID提权步骤6. 常用指令的提权方法6.1 nmap6.2 find6.3 vim6.4 bash6.5 less6.6 more6.7 其他命令的提权方法 1. 文件权限介绍 linux的文件有普通权限和特殊权限&a…

Redis基础教程(六):redis 哈希(Hash)

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 💝&#x1f49…

【火猫】cs2 donk登顶2024年上半年ADR榜

1、HLTV发布数据统计,donk以55张地图中96.8的ADR成功登顶上半年ADR榜单第一。紧随其后的是法国巨星ZywOo,以68图89.2的ADR排名第二。G2当家狙击手m0NESY以73图85的ADR排名第三。 2、白俄罗斯爆料人harumi透露:“Falcons战队向BOROS支付了6个月…

每日复盘-20240701

今日关注: 20240701 六日涨幅最大: ------1--------301182--------- 凯旺科技 五日涨幅最大: ------1--------300977--------- 深圳瑞捷 四日涨幅最大: ------1--------300977--------- 深圳瑞捷 三日涨幅最大: ------1--------300461--------- 田中精机 二日涨幅最…

科普:电脑硬件挑选

目录 一cpu 二主板 三内存 四硬盘 五显卡,散热,电源,机箱 六个人配置 一cpu 品牌:intel AMD 型号:I3,I5,I7 R7等 代数:换新不换旧 cpu后缀:k(可超频)f&#xf…

PHP电商系统开发指南最佳实践

电子商务系统开发的最佳实践包括:数据库设计:选择适合关系型数据库,优化数据结构,考虑表分区;安全:加密数据,防止 sql 注入,处理会话管理;用户界面:遵循 ux 原…

WhaleStudio 2.6正式发布,WhaleTunnel同步性能与连接器数量再创新高!

在这个数据驱动的大模型时代,数据集成的作用和意义愈发重要。数据不仅仅是信息的载体,更是推动企业决策和创新的关键因素。作为全球最流行的批流一体数据集成工具,WhaleTunnel随着WhaleStudio 2.6版本正式发布,带来了多项功能增强…

App测试技术(纯理论)

之前我们也学习过一些普通用例的设计, 如功能, 性能, 安全性, 兼容性, 易用性, 界面的测试用例设计, 之前我们讲的基本都是对于Web应用而言的, 这里我们来讲一下移动端的App测试用例设计. 功能方面 安装&卸载测试 这是只属于App的一类测试, 再平常我们使用移动设备(手机…

扩展学习|风险评估和风险管理:回顾其基础上的最新进展

文献来源:[1]Aven, T. (2016). Risk assessment and risk management: Review of recent advances on their foundation. European journal of operational research, 253(1), 1-13. 文章简介:大约30-40年前,风险评估和管理被确立为一个科学领…

Linux环境安装配置nginx服务流程

Linux环境的Centos、麒麟、统信操作系统安装配置nginx服务流程操作: 1、官网下载 下载地址 或者通过命令下载 wget http://nginx.org/download/nginx-1.20.2.tar.gz 2、上传到指定的服务器并解压 tar -zxvf nginx-1.20.1.tar.gzcd nginx-1.20.1 3、编译并安装到…

CCT技术

概念介绍 多个功能核心的集成可以通过片上系统(SOC)或封装中系统(SIP)设备的开发来实现。SOC器件将核心集成到单个集成电路中。SIP集成是将多个集成电路组合到单个封装中。核心数量 的增加可能导致必要的测试人员资源和/或测试时间的增加。这直接影响了与测试这些设备相关的…

【TB作品】打地鼠游戏,ATMEGA16单片机,Proteus仿真 打地鼠游戏

11个按键LCD1602显示器9个灯蜂鸣器打地鼠小游戏就是九个灯泡,对应九个按键,灯泡有红黄蓝,每间隔一会儿就会亮一个灯,代表地鼠冒出来,按一下按键让灯泡灭掉代表打地鼠,红的三分,黄的两分&#xf…

Java案例抢红包

目录 一:题目要求: 二:思路分析:(遇见问题先想出完整的思路逻辑再去动手事半功倍) 三:具体代码: 一:题目要求: 二:思路分析:&#x…

[无广告!纯干货]免费用CodeFlying自动化生成一个专属的AI机器人

前言: 真心话,花3分钟看文章,再花5分钟体验,你会回来给我点赞的。 随着AIGC(人工智能生成内容)行业的迅猛发展,人工智能正在以前所未有的速度和方式改变我们的生活。 它不仅在娱乐、教育、医疗…

Nomad Web 1.0.12还能这样

大家好,才是真的好。 前几天讲代码和开发,忽略了大家的真实感受,那就是不爱开。我也记起来我们很久没有讲Notes/Domino产品的更新,因为除了补丁程序外,确实没多少更新。 不过就在前两天,有一项产品得到了…

惠海100V 15A HC070N10L TO-252封装 N沟道MOS管 打火机/BMS电源板应用

MOS管的工作原理是基于在P型半导体与N型半导体之间形成的PN结,通过改变栅极电压来调整沟道内载流子的数量,从而改变沟道电阻和源极与漏极之间的电流大小。由于MOS管具有输入电阻高、噪声小、功耗低等优点,它们在大规模和超大规模集成电路中得…

【技术追踪】SegGuidedDiff:基于分割引导扩散模型实现解剖学可控的医学图像生成(MICCAI-2024)

它来了它来了,它带着 mask 做生成了~ SegGuidedDiff:提出一种用于解剖学可控医学图像生成的扩散模型,在每个采样步骤都遵循多类解剖分割掩码并结合了随机掩码消融训练算法,可助力乳房 MRI 和 腹部/颈部到骨盆 CT 等任务涨点。 论文…

基于pycharm对每个工程配置python环境

目录 1 生成环境2 配置pycharm 1 生成环境 设定一个存放虚拟环境的目录,比如可以放在如下目录下: /Users/Name/PycharmProjects/env 然后生成虚拟环境,执行如下操作: python3 -m venv /Users/Name/PycharmProjects/env/agent_pr…