pytest自动化测试数据驱动yaml/excel/csv/json

数据驱动

数据的改变从而驱动自动化测试用例的执行,最终引起测试结果的改变。简单说就是参数化的应用。

测试驱动在自动化测试中的应用场景:

  • 测试步骤的数据驱动;
  • 测试数据的数据驱动;
  • 配置的数据驱动;
1、pytest结合数据驱动-yaml

实现读yaml文件,先创建env.yml文件配置测试数据

工程目录结构:
  • data目录:存放yaml文件

    dev: 127.0.0.1
    #dev: 127.0.0.2
    #prod: 127.0.0.3

  • testcase目录:存放测试用例文件

    import pytest
    import yaml
    class TestYaml:
    @pytest.mark.parametrize("env", yaml.safe_load(open("./env.yml")))
    def test_yaml(self, env):
    if "test" in env:
    print("这是测试环境")

    print(env)

    print("测试环境的ip是:", env["test"])
    elif "dev" in env:
    print("这是开发文件")
    print("开发环境的ip是:", env["dev"])

    print(env)

结果示例:

2、pytest结合数据驱动-excel

常用的读取方式有:xlrd、xlwings、pandas、openpyxl

以读excel文件,实现A+B=C并断言为例~

工程目录结构:

data目录:存放excel数据文件

  • func目录:存放被测函数文件

    def my_add(x, y):
    result = x + y
    return result

  • testcase目录:存放测试用例文件

    import openpyxl
    import pytest
    from test_pytest.read_excel.func.operation import my_add
    def test_get_excel():
    """
    解析excel数据
    :return: [[1,1,2],[3,6,9],[100,200,300]]
    """
    book = openpyxl.load_workbook('../data/param.xlsx')
    sheet = book.active
    cells = sheet["A1":"C3"]
    print(cells)
    values = []
    for row in sheet:
    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())
    def test_add(self, x, y, expected):
    assert my_add(int(x), int(y)) == int(expected)

3、pyetst结合数据驱动-csv

csv:逗号文件,以逗号分隔的string文件

读取csv数据:
  • 内置函数open()
  • 内置模块csv
  • 方法:csv.reader(iterable)
  • 参数:iterable,文件或列表对象
  • 返回:迭代器,遍历迭代器,每次会返回一行数据

以读csv文件,实现A+B=C并断言为例~

工程目录结构:

data目录:存放csv数据文件

  • func目录:存放被测函数文件

    def my_add(x, y):
    result = x + y
    return result

  • testcase目录:存放测试用例文件

    import csv
    import pytest
    from test_pytest.read_csv.func.operation import my_add
    def test_get_csv():
    """
    解析csv文件
    :return:
    """
    with open('../data/params.csv') 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', test_get_csv())
    def test_add(self, x, y, expected):
    assert my_add(int(x), int(y)) == int(expected)

4、pytest结合数据驱动-json

json:js对象,是一种轻量级的数据交换格式。

json结构:
  • 对象{"key":value}
  • 数组[value1,value2...]
查看json文件:
  • 1.pycharm
  • 2.txt记事本
读取json文件:
  • 内置函数open()
  • 内置库json
  • 方法 json.loads() json.dumps()

以读json文件,实现A+B=C并断言为例~

工程目录结构:

data目录:存放json数据文件

  • func目录:存放被测函数文件

    def my_add(x, y):
    result = x + y
    return result

  • testcase目录:存放测试用例文件

    import json
    import pytest
    from test_pytest.read_json.func.operation import my_add
    def test_get_json():
    """
    解析json数据
    :return: [[1,1,2],[3,6,9],[100,200,300]]
    """
    with open('../data/params.json', 'r') as file:
    data = json.loads(file.read())
    print(list(data.values()))
    return list(data.values())
    class TestWithJson:
    @pytest.mark.parametrize('x,y,expected', test_get_json())
    def test_add(self, x, y, expected):
    assert my_add(int(x), int(y)) == int(expected)

相关推荐
Fireworkitte10 小时前
Apache POI 详解 - Java 操作 Excel/Word/PPT
java·apache·excel
测试杂货铺10 小时前
Jmeter(六):json断言元件,jmeter参数化实现
jmeter·json
思则变11 小时前
[Pytest] [Part 2]增加 log功能
开发语言·python·pytest
Prodigy_kyw14 小时前
VBA初学3----实战(VBA实现Excel转csv)
excel·vba·csv
专注VB编程开发20年15 小时前
C#,VB.NET从JSON数据里提取数组中的对象节点值
c#·json·.net
红衣女妖仙17 小时前
JXLS 库导出复杂 Excel
java·excel·jxls·java 导出 excel
吃我两拳20 小时前
EasyExcel停止当前Sheet的读取,且不影响主线程及其他Sheet读取的方法
excel
草履虫建模20 小时前
Postman - API 调试与开发工具 - 标准使用流程
java·测试工具·spring·json·测试用例·postman·集成学习
qq_393828221 天前
办公文档批量打印器 Word、PPT、Excel、PDF、图片和文本,它都支持批量打印。
windows·word·powerpoint·excel·软件需求
过期的秋刀鱼!1 天前
用“做饭”理解数据分析流程(Excel三件套实战)
数据挖掘·数据分析·excel·powerbi·数据分析入门