博客
关于我
使用ddt执行数据驱动测试
阅读量:370 次
发布时间:2019-03-04

本文共 1714 字,大约阅读时间需要 5 分钟。

数据驱动测试(Data-Driven Testing,简称 DDT)是一种通过外部数据源驱动自动化测试的方法,能够灵活处理多种输入数据和期望值,从而减少硬编码数据的使用。这种测试模式特别适用于需要验证多组数据的测试场景,例如ATM取款、登录功能等。

数据驱动测试的核心原理

  • 测试数据以列表形式存储:数据通常以多个字典的列表形式提供,支持单个值、列表、元组或字典等多种数据类型。
  • 使用装饰符@ddt.ddt:在测试类上使用@ddt装饰符,表示这是一个数据驱动的测试类。
  • 定义测试用例时使用@data装饰符:在测试方法上使用@data装饰符,指定测试数据。对于列表和元组,可以使用@unpack装饰符将数据解析为多个参数。
  • 自动加载测试用例:运行测试时,Python会将数据文件中的每一行单独解析为一个测试用例。
  • 安装所需库

  • 安装ddt库

    使用pip安装:

    pip install ddt

    通过ddt装饰符可以将测试变量参数化,并支持从外部数据源(如Excel文件)加载数据。

  • 安装xlrd库

    xlrd库用于读取Excel文件,支持从工作簿、工作表和单元格读取数据。安装命令:

    pip install xlrd

    如果需要写入Excel文件,还需安装xlwt或openpyxl库。

  • Excel数据读取示例

    import xlrdclass ExcelUtil:    def __init__(self, excelPath, sheetName):        self.data = xlrd.open_workbook(excelPath)        self.table = self.data.sheet_by_name(sheetName)        self.row = self.table.row_values(0)  # 获取表头        self.rowNum = self.table.nrows        # 获取总行数        self.colNum = self.table.ncols        # 获取总列数    def get_data(self):        data = []        for i in range(1, self.rowNum):            current_row = self.table.row_values(i)            item = {}            for j in range(self.colNum):                item[self.row[j]] = current_row[j]            data.append(item)        return data

    测试用例示例

    import unittestfrom ddt import ddt, data, unpackfrom ExcelUtil import ExcelUtilclass DataTest(unittest.TestCase):    @classmethod    def setUpClass(cls):        print("开始测试")    @ddt.data(*excel.get_data())    def test_login(self, data):        print(f"测试用户:{data['username']}")        print(f"测试密码:{data['password']}")        print(f"测试国家:{data['country']}")

    注意事项

    • 数据文件格式:确保Excel文件的第一行为表头,后续行为测试数据。
    • 参数解析:使用@unpack装饰符时,确保数据类型与参数类型匹配。
    • 多线程测试:在多线程环境下,使用@ddt装饰符前,需避免使用unittest.isolatedThreads()来防止干扰。

    通过上述方法,可以将测试脚本与数据源解耦,实现数据驱动测试的高复用性和灵活性。

    转载地址:http://pjbg.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现Fast Powering算法(附完整源码)
    查看>>
    Objective-C实现Fedwick树算法(附完整源码)
    查看>>
    Objective-C实现fenwick tree芬威克树算法(附完整源码)
    查看>>
    Objective-C实现FenwickTree芬威克树算法(附完整源码)
    查看>>
    Objective-C实现fermat little theorem费马小定理算法(附完整源码)
    查看>>
    Objective-C实现FermatPrimalityTest费马素数测试算法(附完整源码)
    查看>>
    Objective-C实现fft2函数功能(附完整源码)
    查看>>
    Objective-C实现FFT快速傅立叶变换算法(附完整源码)
    查看>>
    Objective-C实现FFT算法(附完整源码)
    查看>>
    Objective-C实现fibonacci search斐波那契查找算法(附完整源码)
    查看>>
    Objective-C实现fibonacci斐波那契算法(附完整源码)
    查看>>
    Objective-C实现fibonacci斐波那契算法(附完整源码)
    查看>>
    Objective-C实现FIFO(附完整源码)
    查看>>
    Objective-C实现FigurateNumber垛积数算法(附完整源码)
    查看>>
    Objective-C实现finding bridges寻找桥梁算法(附完整源码)
    查看>>
    Objective-C实现first come first served先到先得算法(附完整源码)
    查看>>
    Objective-C实现FIR滤波器(附完整源码)
    查看>>
    Objective-C实现fischer yates shuffle洗牌算法(附完整源码)
    查看>>
    Objective-C实现FisherYates Shuffle洗牌算法(附完整源码)
    查看>>
    Objective-C实现fisherYates洗牌算法(附完整源码)
    查看>>