pytest数据驱动

news2025/1/22 18:10:52

在这里插入图片描述


文章目录

  • 一、数据驱动概念
  • 二、数据驱动yaml
    • 1、yaml的基本语法:
    • 2、yaml支持的数据格式:
    • 3、安装
    • 4、使用
    • 5、读取方法
      • a、目录结构
      • b、yaml文件
      • c、测试方法
      • d、测试用例
      • e、测试结果
  • 三、数据驱动excel
    • 1、安装导入
    • 2、操作
    • 3、读取方法
      • a、目录结构
      • b、excel文件
      • c、测试方法
      • d、测试用例
      • e、测试结果
  • 四、数据驱动csv
    • 1、读取数据
    • 2、方法
      • a、目录结构
      • b、csv文件
      • c、测试方法
      • d、测试用例
      • e、测试结果
  • 五、数据驱动json
    • 1、json格式:
    • 2、读取json文件
      • a、目录结构
      • b、json文件
      • c、测试方法
      • d、测试用例
      • e、测试结果

一、数据驱动概念

数据驱动就是数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变。简单来说,就是参数化的应用。数据量小的测试用例可以使用代码的参数化来实现数据驱动,数据量大的情况下建议大家使用一种结构化的文件(例如yaml,json,csv、excel等)来对数据进行存储,然后在测试用例中读取这些数据。

二、数据驱动yaml

yaml是一种数据序列化格式,用于人类的可读性和与脚本语言的交互,一种被认为超越XML、json的配置文件。

1、yaml的基本语法:

大小写敏感
使用缩进标识层级关系
缩进时不允许使用tab键,只允许使用空格
缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
#表示注释,从这个字符一直到行尾,都会被解析器忽略

2、yaml支持的数据格式:

对象(字典):键值对的集合,用冒号“:”表示
数组(列表):一组按次序排列的值,前加“-”
纯量:单个的、不可再分的值
字符串
布尔值
整数
浮点数
Null
时间
日期

3、安装

pip install pyyaml

4、使用

datas:测试数据
func:测试方法
testcases:测试用例

5、读取方法

yaml.safe_load(file)

a、目录结构

在这里插入图片描述

b、yaml文件

# [[1,1,2],[3,6,9],[100,200,300]]
-
  - 1
  - 1
  - 3
-
  - 3
  - 6
  - 9
-
  - 100
  - 200
  - 300

c、测试方法

#被测方法,相加功能
def my_add3(x, y):
    result = x + y
    return result

d、测试用例

文件或者目录不可以创建为yaml关键字

import pytest
from testing_data.func.operation_yaml import my_add

#用到yaml文件中的数据时,就需要读取出来

# pip install pyyaml
#todo 文件或者目录不可以创建为yaml关键字
import yaml

def get_data():
    #如果yaml文件有中文,必须加上excoding='utf-8'
    with open('../datas/data.yaml',encoding='utf-8') as f:
        data=yaml.safe_load(f)
    return data

class TestWithYAML:
    @pytest.mark.parametrize('x,y,expected',get_data())
    def test_add(self, x, y, expected):
        assert my_add(int(x), int(y)) == int(expected)

e、测试结果

在这里插入图片描述

三、数据驱动excel

1、安装导入

pip install openpyxl
import openpyxl

2、操作

读取工作簿
读取工作表
读取单元格

3、读取方法

book=openpyxl.load_workbook(‘文件路径’) :读取工作簿
sheet=book.active :读取工作表
cells=sheet[‘A1’:‘C3’]
cell.value :读取数据

a、目录结构

在这里插入图片描述

b、excel文件

在这里插入图片描述

c、测试方法

#被测方法,相加功能
def my_add1(x, y):
    result = x + y
    return result

d、测试用例

import openpyxl
import pytest
from testing_data.func.operation_excel import my_add1

#用到excel文件中的数据时,就需要读取出来

def test_get_excel():
    """
    解析Excel数据
    :return: [[1,1,2],[3,6,9],[100,200,300]]
    """
    #获取工作簿
    book=openpyxl.load_workbook('../datas/data.xlsx')
    #获取工作表sheet1
    sheet=book.active
    #读取数据
    cells=sheet['A1':'C3']
    print(cells)
    values=[]
    for row in cells:
        data=[]
        for cell in row:
            data.append(cell.value)
        values.append(data)
    print(values)
    return values


class TestWithEXCEL:
    @pytest.mark.parametrize('x,y,expected',test_get_excel(),ids=[1,2,3])
    def test_add1(self, x, y, expected):
        assert my_add1(int(x), int(y)) == int(expected)

e、测试结果

在这里插入图片描述

四、数据驱动csv

格式:逗号分隔值
以纯文本形式存储数字和文本
文件由任意数目的记录组成
每行记录由多个字段组成

1、读取数据

内置模块:import csv

2、方法

raw=csv.reader(iterable)
参数:iterable是一个可迭代对象;返回迭代器,每次迭代会返回一行数据

csv文件
在这里插入图片描述
读取csv文件

import csv


def get_csv():
    with open('demo.csv','r',encoding='utf-8') as file:
        raw=csv.reader(file)
        for line in raw:
            print(line)

if __name__ == '__main__':
    get_csv()

读取结果:

['富强', '明主', '文明', '和谐']
['自由', '平等', '公正', '法制']
['爱国', '诚信', '敬业', '友善']

a、目录结构

在这里插入图片描述

b、csv文件

在这里插入图片描述

c、测试方法

#被测方法,相加功能
def my_add2(x, y):
    result = x + y
    return result

d、测试用例

import csv

import pytest
from testing_data.func.operation_csv import my_add2

#用到csv文件中的数据时,就需要读取出来
def get_csv():
    """
    读取csv文件中的数据
    :return: 格式:[[1,2,3],[3,6,9]]
    """
    with open('../datas/data.csv','r',encoding='utf-8') as file:
        raw=csv.reader(file)
        data=[]
        for line in raw:
            data.append(line)
    print(data)
    return data

class TestWithCSV:
    @pytest.mark.parametrize('x,y,expected',get_csv())
    def test_add2(self, x, y, expected):
        assert my_add2(int(x), int(y)) == int(expected)

e、测试结果

在这里插入图片描述

五、数据驱动json

1、json格式:

是一种轻量级的数据交换格式
以键值对的格式存储数据,多个键值用逗号分割
支持嵌套
支持数组(列表)

{
  "name:": "study ",
  "detail": {
    "course": "python",
    "city": "北京"
  },
  "remark": [1000,666,888]
}

2、读取json文件

内置库:

import json

内置方法
json.loads()
json.dumps()

import json


def get_json():
    with open('demo.json','r',encoding='utf-8') as file:
        data=json.loads(file.read())
        print(data,type(data))

        data1=json.dumps(data, ensure_ascii=False)
        print(data1,type(data1))

if __name__ == '__main__':
    get_json()

读取结果

{'name:': 'study ', 'detail': {'course': 'python', 'city': '北京'}, 'remark': [1000, 666, 888]} <class 'dict'>
{"name:": "study ", "detail": {"course": "python", "city": "北京"}, "remark": [1000, 666, 888]} <class 'str'>

a、目录结构

在这里插入图片描述

b、json文件

{
  "case1": [1, 1, 2],
  "case2": [3, 6, 9],
  "case3": [100, 200, 300]
}

c、测试方法

#被测方法,相加功能
def my_add3(x, y):
    result = x + y
    return result

d、测试用例

import json
import pytest
from testing_data.func.operation_json import my_add3

#用到json文件中的数据时,就需要读取出来
def get_json():
    """
    读取json文件中的数据
    :return: 格式:[[1,2,3],[3,6,9]]
    """
    with open('../datas/data.json','r',encoding='utf-8') as file:
        data=json.loads(file.read())
        data_values=data.values()
        return list(data_values)


class TestWithJson:
    @pytest.mark.parametrize('x,y,expected',get_json())
    def test_add3(self, x, y, expected):
        assert my_add3(int(x), int(y)) == int(expected)

e、测试结果

在这里插入图片描述


在这里插入图片描述

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

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

相关文章

(考研湖科大教书匠计算机网络)第五章传输层-第七节:TCP可靠传输

获取pdf&#xff1a;密码7281专栏目录首页&#xff1a;【专栏必读】考研湖科大教书匠计算机网络笔记导航 文章目录一&#xff1a;TCP可靠传输二&#xff1a;补充说明本节对应视频如下 【计算机网络微课堂&#xff08;有字幕无背景音乐版&#xff09;】&#xff1a;TCP可靠传输 …

Navicat Premium 安装 注册

Navicat Premium 一.Navicat Premium的安装 1.暂时关闭windows的病毒与威胁防护弄完再开&#xff0c;之后安装打开过程中弹窗所有警告全部允许,不然会被拦住 2.下载安装包&#xff0c;解压 链接&#xff1a;https://pan.baidu.com/s/1X24VPC4xq586YdsnasE5JA?pwdu4vi 提取码…

Qt 线程

Qt中线程的解释&#xff1a; QThread(线程)&#xff0c;代表一个在应用程序中可以独立控制的线程&#xff0c;可以和进程中的其他线程分享数据。QThread 对象管理程序中的一个控制线程。QThreads 在 run&#xff08;&#xff09; 中开始执行。默认情况下&#xff0c;run&#…

DDFN: Decoupled Dynamic Filter Networks解耦的动态卷积

一、论文信息 论文名称&#xff1a;Decoupled Dynamic Filter Networks 论文&#xff1a;https://thefoxofsky.github.io/files/ddf.pdf 代码&#xff1a;https://github.com/theFoxofSky/ddfnet 主页&#xff1a;https://thefoxofsky.github.io/project_pages/ddf 作者团…

kubectl常用的命令

目录 安装 kubectl 一、命令自动补全 二、常用命令 1、查看所有pod列表 2、查看RC和service列表 3、显示Node的详细信息 4、显示Pod的详细信息, 特别是查看Pod无法创建的时候的日志 5、 根据yaml创建资源, apply可以重复执行&#xff0c;create不行 6、基于nginx.yaml…

实验室设计SICOLAB第三方检测中心实验室设计

第三方检测中心实验室怎么设计&#xff1f;详细设计内容有哪些&#xff1f;功能区域有哪些&#xff1f;仪器有哪些&#xff1f;要多少面积&#xff1f;第三方检测中心实验室是一种独立的实验室&#xff0c;为客户提供各种测试和分析服务。以下是一个第三方检测中心实验室的详细…

给你安利几款好用的谷歌浏览器插件

给你安利几款好用的谷歌浏览器插件前言一 Octotree 插件二 GitCodeTree 插件三 SourceGraph 插件四 GitZip 插件五 Enhanced GitHub 插件六 插件下载安装6.1 谷歌应用商店下载6.2 离线安装6.2.1 下载插件6.2.2 安装插件七 移除、启用、停用插件小结前言 GitHub是全球最大的代码…

Windows PowerShell中成功进入conda虚拟环境

本人操作系统是Windows10&#xff08;输入命令cmd或在运运行中输入winver查看&#xff09;在cmd命令行中大家都很熟悉&#xff0c;很方便进入到指定创建了的虚拟环境中&#xff0c;那么在PowerShell中怎么进入呢&#xff1f;比如在VSCode中的TERMINAL使用的是PowerShell&#x…

论文阅读笔记-DiffusionInst: Diffusion Model for Instance Segmentation

文章目录DiffusionInst: Diffusion Model for Instance Segmentation摘要介绍任务介绍实例分割的几种方法想法来源贡献方法整体结构Mask RepresentationDiffusionInst组成TrainingInference不足之处感悟DiffusionInst: Diffusion Model for Instance Segmentation 代码&#x…

魔兽世界经典怀旧服务器架设教程

准备工具&#xff1a;MySQL服务端服务器最重要的你需要会技术、要不然都瞎扯 给你东西你也看不懂。教程开始&#xff1a;安装MySQL并创建数据库安装MySQL社区版&#xff0c;并配置SQL服务器。安装SQLyog。利用其登录&#xff0c;创建realmd、characters、mangos、scriptdev2数据…

普通动物实验室规划设计SICOLAB

一、普通动物实验室普通动物实验室是进行动物实验的专门场所&#xff0c;用于研究疾病的发生机制&#xff0c;测试药物的安全性和有效性等。以下是普通动物实验室设计的一些细节和功能房间&#xff1a;&#xff08;1&#xff09;动物饲养区&#xff1a;用于饲养动物&#xff0c…

面试浅谈之 C++ STL 篇

面试浅谈之 C STL 篇 一 &#x1f3e0; 概述 HELLO&#xff0c;各位博友好&#xff0c;我是阿呆 &#x1f648;&#x1f648;&#x1f648; 这里是面试浅谈系列&#xff0c;收录在专栏面试中 &#x1f61c;&#x1f61c;&#x1f61c; 本系列将记录一些阿呆个人整理的面试题…

hydra常见端口服务穷举

目录 工具介绍 参数说明 官方示例 官方字典 ssh爆破 ftp爆破 mysql爆破 smb爆破 rdb爆破 http爆破 redis爆破 工具介绍 hydra 是一个支持众多协议的爆破工具&#xff0c;已经集成到KaliLinux中&#xff0c;直接在终端打开即可 参数说明 -l &#xff1a; 指定破…

Linux下安装MySQL8.0的详细步骤(解压tar.xz安装包方式安装)

Linux下安装MySQL8.0的详细步骤 第一步&#xff1a;下载安装配置 第二步&#xff1a;修改密码&#xff0c;并设置远程连接&#xff08;为了可以在别的机器下面连接该mysql&#xff09; 第三步&#xff1a;使用Navicat客户端连接 搞了一台云服务器&#xff0c;首先要干的活就是…

move_base代码解析(二)MoveBase::planThread

在第一章中第四步执行了planThread函数的线程启动&#xff0c;该步骤会调用planThread函数。这里不是通过函数调用的形式实现的&#xff0c;而是通过线程开关的形式实现的: boost::unique_lock<boost::recursive_mutex> lock(planner_mutex_);//给该线程上锁planner_goal…

117页数字化转型与产业互联网发展趋势及机会分析报告(PPT)

【版权声明】本资料来源网络&#xff0c;知识分享&#xff0c;仅供个人学习&#xff0c;请勿商用。【侵删致歉】如有侵权请联系小编&#xff0c;将在收到信息后第一时间删除&#xff01;完整资料领取见文末&#xff0c;部分资料内容&#xff1a; 产业互联网是以机构组织为主体的…

CentOS7 Hive2.3.9 安装部署(mysql 8.0)

一、CentOS7安装MySQL数据库 查询载mariadb rpm -qa | grep mariadb卸载mariadb rpm -e --nodeps [查询出来的内容]安装wget为下载mysql准备 yum -y install wget在tools目录下执行以下命令&#xff0c;下载MySQL的repo源&#xff1a; wget -P /tools/ https://dev.mysql.…

网络编程学习一

1、初识网络编程2、网络编程三要素3、三要素&#xff08;IP&#xff09;4、IPV4的一些小细节5、Inetaddress类的使用package com.leitao.demo.network;import java.net.InetAddress; import java.net.UnknownHostException;/*** Description: TODO* Author LeiTao* Date 2023/2…

移动WEB开发三、flex布局

零、文章目录 文章地址 个人博客-CSDN地址&#xff1a;https://blog.csdn.net/liyou123456789个人博客-GiteePages&#xff1a;https://bluecusliyou.gitee.io/techlearn 代码仓库地址 Gitee&#xff1a;https://gitee.com/bluecusliyou/TechLearnGithub&#xff1a;https:…

企业数字化管理是什么?如何建立企业数字化管理?

企业数字化管理是什么&#xff0c;如何建立企业数字化管理&#xff1f; 01 什么是企业数字化管理&#xff1f; 提到企业数字化管理&#xff0c;就不得不联想到机器自动化、业务流程自动化以及数字处理自动化这三个概念的区别&#xff1a; ​而抛开那些又臭又长的概念解读&…