使用ddt执行数据驱动测试

article/2025/10/11 20:06:15

所谓数据驱动测试,简单的理解为数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变。通过使用数据驱动测试的方法,可以在需要验证多组数据测试场景中,使用外部数据源实现对输入输出与期望值的参数化,避免在测试中使用硬编码的数据。
这种方法对于测试步骤相同而使用不同的输入值和期望值的测试场景尤为重要,比如设计一个ATM机取款的测试用例设计。
这里写图片描述
因此只需要创建一个测试脚本就可以处理上表的测试数据和条件的组合,使用数据驱动的模式,根据业务逻辑分解测试数据,并且定义变量,使用外部的excel里的数据使其参数化,从而避免使用源测试脚本中的固定数据,这种方式可以将测试脚本与测试数据分开,使得测试脚本在不同的数据集合下高度复用。
数据驱动的模式不仅可以帮助增加类似复杂条件场景下的测试覆盖,还可以极大的减少对测试代码的编写和维护工作。
数据驱动测试的有以下几个原理:

1 .测试数据为多个字典的list类型
2.测试类前加修饰@ddt.ddt
3.case前加修饰@ddt.data()
4.运行后用例会自动加载成三个单独的用例

1、安装ddt库

ddt(Data Driver Test)的库可以将测试中的变量进行参数化,使用之前先进行在线安装。
这里写图片描述
为了创建数据驱动测试,需要在测试类上使用 @ddt 装饰符,在测试方法上使用 @data 装饰符。@data 装饰符可以把参数当做测试数据,参数可以是单个值,列表,元组,字典,对于列表和元组,需要使用 @unpack 装饰符把元组和列表解析成多个参数


2、安装xlrd库

为了支持对Excel 数据表的支持,需要安装 xlrd 库
这里写图片描述
xlrd 库提供了对工作簿,工作表以及单元格的读取方法,如果需要往表格中写入数据,需要安装xlwt 库,此外 openpyxl 库提供了对表格的读写操作。


3、实例

对于如何使用上述的几个装饰符,通过以下实例进行剖析

import unittest
from ddt import ddt,data,unpack@ddt
class MyTestCase(unittest.TestCase):@data(1,2,3)def test_something(self,value):self.assertEqual(value, 2)
if __name__ == '__main__':unittest.main(verbosity=2)

输出结果:
判断2!=1
判断2!=3
输出运行时会就爱你和用例个数
对于有两个参数的:

import unittest
from ddt import ddt,data,unpack@ddt
class MyTestCase(unittest.TestCase):@data((1,2),(2,3))@unpackdef test_something(self,value1,value2):print value1,value2self.assertEqual(value2, value1+1)
if __name__ == '__main__':unittest.main()

输出结果:
这里写图片描述

基于以上的基础,现在从 Excel 中读取数据,数据表如下:
这里写图片描述
设计一个模块对 excel 中的数据进行读取和简单的处理,首先看看在excel中如何操作的

# 打开exlce表格,参数是文件路径
data = xlrd.open_workbook('test.xlsx')# table = data.sheets()[0]           #  通过索引顺序获取
# table = data.sheet_by_index(0)     #  通过索引顺序获取
table = data.sheet_by_name(u'Sheet1')  # 通过名称获取nrows = table.nrows  # 获取总行数
ncols = table.ncols  # 获取总列数# 获取一行或一列的值,参数是第几行
print table.row_values(0)  # 获取第一行值
print table.col_values(0)  # 获取第一列值

读取上述的 Excel 表格

# coding:utf-8
import xlrdclass ExcelUtil():def __init__(self, excelPath, sheetName):self.data = xlrd.open_workbook(excelPath)self.table = self.data.sheet_by_name(sheetName)self.keys = self.table.row_values(0)self.rowNum = self.table.nrowsself.colNum = self.table.ncolsdef dict_data(self):if self.rowNum <= 1:print("the sum of line is less than 1")else:r = []j=1for i in range(self.rowNum-1):s = {}values = self.table.row_values(j)for x in range(self.colNum):s[self.keys[x]] = values[x]r.append(s)j+=1return rif __name__ == "__main__":filepath = "information.xlsx"sheetName = "Sheet1"data = ExcelUtil(filepath, sheetName)print data.dict_data()

输出结果:

C:\Python27\python.exe F:/py_test/UnitTest/importexcel.py
[{u'username': u'Jack', u'country': u'US', u'password': 123456.0}, 
{u'username': u'Pan', u'country': u'CHINA', u'password': u'abcdef'}, 
{u'username': u'John', u'country': u'UK', u'password': u'su39n3'}]Process finished with exit code 0

现在导入excel测试数据,模块为:ExcelUtil.py

import xlrdclass ExcelUtil(object):def __init__(self, excelPath, sheetName):self.data = xlrd.open_workbook(excelPath)self.table = self.data.sheet_by_name(sheetName)# get titlesself.row = self.table.row_values(0)# get rows numberself.rowNum = self.table.nrows# get columns numberself.colNum = self.table.ncols# the current columnself.curRowNo = 1def next(self):r = []while self.hasNext():s = {}col = self.table.row_values(self.curRowNo)i = self.colNumfor x in range(i):s[self.row[x]] = col[x]r.append(s)self.curRowNo += 1return rdef hasNext(self):if self.rowNum == 0 or self.rowNum <= self.curRowNo:return Falseelse:return Trueif __name__ == "__main__":filepath = "information.xlsx"sheetName = "Sheet1"data = ExcelUtil(filepath, sheetName)print data.hasNext()

测试模块为:

import unittestimport ddt
#from driver.ExcelUtil import ExcelUtil
from ExcelUtil import ExcelUtilexcel = ExcelUtil('information.xlsx', 'Sheet1')@ddt.ddt
class DataTest(unittest.TestCase):@classmethoddef setUpClass(cls):print('start')@classmethoddef tearDownClass(cls):print('stop')@ddt.data(*excel.next())def testLogin(self, data):print(data['username'])print(data['password'])print(data['country'])if __name__ == "__main__":suite = unittest.TestLoader().loadTestsFromTestCase(DataTest)unittest.TextTestRunner(verbosity=2).run(suite)

这里在这两个模块对应的目录下创建一个名为information.xlsx的Excel数据表格
这里写图片描述
输出结果为:
这里写图片描述


http://chatgpt.dhexx.cn/article/dJAF3xyW.shtml

相关文章

先测试再开发?TDD测试驱动开发了解一下?

1、什么是TDD 我第一次接触TDD这个概念&#xff0c;是在<<代码整洁之道>>中&#xff0c;作者鲍勃大叔在书中&#xff0c;写了一些关于测试代码的代码规范&#xff0c;其实就提到了有关TDD三定律: - 定律一&#xff1a; 在编写不能通过的单元测试前&#xff0c;不…

测试驱动开发(TDD)前端篇

当你在写生产代码时&#xff0c;你处在高认知的状态&#xff08;obvious&#xff09;&#xff0c;你的研发流程和你的工程实践&#xff0c;有助于你一步一步的提升你的认知能力&#xff0c;把你的问题进行一个降解&#xff08;分解&#xff09;&#xff0c;只要你做到同样的事情…

TDD 开发测试

测试驱动开发(Test-Driven Development)。是敏捷开发中的一项核心实践和技术。 TDD是在开发功能代码之前&#xff0c;先编写单元测试用例代码&#xff0c;测试代码确定需要编写什么产品代码。 变红 ——> 变绿 ——> 重构 在进行 TDD 案例编写的时候&#xff0c;看一…

TDD测试驱动开发

TDD测试驱动开发 什么是测试驱动开发测试驱动开发该怎么做&#xff1f;需求一&#xff1a;输入一个非元音字符&#xff0c;并预期返回字符本身 (输入"h" 返回“h”)需求二&#xff1a;输入一个元音&#xff08;a,e,i,o,u&#xff09;&#xff0c;返回 mommy (输入&qu…

TDD测试驱动学习

gtest 和 gmock 安装 //如果不知道对应库名字可以执行这个命令查找对应库,如果没找到要去跟新对应的源sudo apt update sudo apt-cache search gtest sudo apt-cache search gmock 测试例子 #include <string> using std::string;// 定义 Soundex 类 class Soundex {pub…

TDD (test driver development)测试驱动开发

##为什么需要测试驱动/或者说需要单元测试 我们工作接触的软件项目&#xff0c;不是学生时代&#xff0c;玩一玩就不管了&#xff0c;工作的项目&#xff0c;需要长期维护&#xff0c;并且随着时间的推移需要增加新的需求&#xff0c;进行修改&#xff0c;优化。此时已经距离你…

tdd(测试驱动开发)的概述

最近的工作的项目&#xff0c;使用了tdd&#xff08;test-driven development测试驱动开发&#xff09;的开发模式。 这两几年大概听说了无数种xxx-dd, ddd, tdd, atdd, bdd, fdd, udd各种名词眼花缭乱&#xff0c;当然很多dd其实也有相互借鉴&#xff08;抄袭&#xff09;的部…

测试驱动开发(TDD)实践与技巧

文章目录 引言Google Mock测试用例结构断言经典式断言Hamcrest 断言 测试驱动开发&#xff1a;第一个示例开场白开始吧去掉不干净的代码增量性fixture 设置思索与测试驱动开发测试驱动与测试 测试驱动开发基础与单元测试单元测试的组织结构测试驱动开发周期&#xff1a;红-绿-重…

opencv配置相关的截图参考

opencv配置相关的截图参考&#xff0c;如下&#xff1a;

Anaconda3安装及opencv配置

一、Anaconda安装 1.直接百度搜anaconda&#xff0c;进入官网即可&#xff08;anaconda网站链接&#xff09; 2.点击图片上黑框&#xff08;Get Started&#xff09;即可进入下一步&#xff0c;选择下图中第四个 3.选择适合电脑类型的anaconda安装器&#xff0c;注意选好64位…

linux安装配置opencv

刚开始学习ubuntu&#xff0c;有些项目需要用到opencv&#xff0c;当我用下面的命令安装包的时候&#xff0c;总是出现“E&#xff1a;无法定位软件包 opencv”的错误。然后开始着手解决&#xff0c;网上搜集了很多的教程&#xff0c;大部分都是说要更换源&#xff0c;我也照做…

opencv安装配置测试

前面安装了pcl和qt&#xff0c;以及qt中的vtk&#xff0c;这里配置下opencv4.3 将cv复制到D盘下。 安装完成之后&#xff0c;添加环境变量&#xff0c;[计算机]->右键 [属性]->[高级系统设置]->[环境变量]->[系统环境变量]->编辑 [Path]&#xff0c;添加“D:…

Qt中配置OpenCV

Qt中配置OpenCV 1. 环境下载2. 进行编译和安装2.1 新建opencv-build文件夹&#xff0c;用于opencv的 编译和安装&#xff08;直接在opencv下新建即可&#xff09;2.2 CMake设置2.3 命令行进行编译安装 3. Qt测试4. 其它问题4.1 若电脑上安装有PyQt4.2 电脑无法访问wai网 1. 环境…

Anaconda配置OpenCV

文章目录 1.安装Anaconda2.配置OpenCV2.1打开Anaconda Prompt2.2找到里面Scripts的路径2.3下载2.4验证是否配置成功 3.出错解决办法4.参考文章 1.安装Anaconda 可以查看我的上一篇文章&#xff1a;Anaconda下载、安装和环境配置 2.配置OpenCV 2.1打开Anaconda Prompt 在开始…

Opencv学习笔记——opencv配置安装与IDE环境安装

文章目录 前言一、opencv配置安装二、IDE的安装总结 前言 既然开始对AI视觉这个方面有兴趣&#xff0c;也初步接触了一些AI视觉在嵌入式方面的应用&#xff0c;那自然少不了对Opencv的学习。到现在开始学习opencv之前对它了解不多&#xff0c;只知道opencv的全称是Open Source…

vs + python + opencv 配置

首要条件&#xff0c;在vs上安装python环境。 以Visual Studio 2019为例讲解如何配置python、opencv、及相关第三方库。&#xff08;其它vs版本只是在界面上有所区别&#xff0c;过程相同。&#xff09; 步骤一&#xff1a;安装python开发工具 按下图操作&#xff0c;勾选Pyt…

vscode配置opencv

前言 本篇文章主要用来记录使用vscode配置opencv的全过程&#xff0c;在整个过程中需要用到的工具包括vscode安装包、MinGW-w64和opencv的源码。vs studio配置opencv比较简单&#xff0c;opencv官网中已经有用vs studio编译器编译好的opencv库&#xff0c;但是对于vscode而言&a…

windows下 C++ openCV配置及x86编译(傻瓜式教程)

本傻瓜教程需要的环境如下: IDE: vs2015或vs2017 , windows 10 或 11 vs2017下载地址如下: ①百度网盘 链接&#xff1a;https://pan.baidu.com/s/1r628e9M5lv_F9IWO-h05jA 提取码&#xff1a;23a7 ②官网地址 https://my.visualstudio.com/Downloads/Featured?mktzh-cnh…

【Qt+OpenCV配置简介】

【Qt&OpenCV】QtOpenCV配置简介 文章目录 【Qt&OpenCV】QtOpenCV配置简介前言一、Qt安装二、OpenCV安装三、Qt配置OpenCV四、测试​总结 前言 越来越多的开发人员选择基于开源的Qt框架与OpenCV来实现界面和算法&#xff0c;其原因不单单是无版权问题&#xff0c;更多是…

Qt+OpenCV配置教程(图解亲测)

文章目录 QtOpenCV配置教程安装配置使用 QtOpenCV配置教程 安装 我都安的最新版的&#xff08;cmake 3.22.1 opencv 4.5.1 qt 5.12.1&#xff09;。 1、cmake安装 2、qt mingw安装 3、opencv安装 配置 首先要设置环境变量。 换成对应你自己版本、位置的环境变量 D:\Prog…