python 基于DDT实现数据驱动测试


Posted in Python onFebruary 18, 2021

简单介绍

​ DDT(Date Driver Test),所谓数据驱动测试,简单来说就是由数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变。通过使用数据驱动测试的方法,可以在需要验证多组数据测试场景中,使用外部数据源实现对输入输出与期望值的参数化,避免在测试中使用硬编码的数据,也就是测试数据和用例脚本代码分离。

​ DDT它其实就是一个装饰器,它会根据你传递进来的数据来决定要生成几个测试用例。

​ ?使用的意义

1.代码复用率高:一个测试逻辑只需要写一次,可以多条测试数据复用,同时提高测试脚本的编写效率。

2.异常排查效率高:根据测试数据,每条数据生成一条测试用例,用例相互分离,一条失败的情况下不会影响其他测试用例。

3.代码可维护性高:简洁明了的测试框架,利于其他同事阅读,提高代码的可维护性。

安装及导入

​ cmd命令行执行安装:pip install ddt

​ 直接导入到模块:import ddt,或导入具体的装饰器:from ddt import ddt, data, unpack

使用详解

​ ?三个要点:

  • @ddt:装饰测试类
  • @data:装饰测试用例
  • @unpack:装饰测试用例

​ 要使用ddt的前提是要有测试用例类,然后用@ddt去装饰测试用例类,用@data(测试数据)去装饰测试用例,如下登录接口例子:

from ddt import ddt, data
from common.read_excel import ReadExcel
from common.my_logger import log


@ddt # 装饰登录测试用例类,声明使用ddt
class LoginTestCase(unittest.TestCase):
  
  excel = ReadExcel("cases.xlsx", "login")
  cases = excel.read_data()
  
  @data(*cases)	# 装饰测试用例
  def test_login(self, case):
    case_data = eval(case["data"])
    expected = eval(case["expected"])
    case_id = case["case_id"]
    result = login_check(*case_data)
    response = self.http.send(url=url, method=method, json=data, headers=headers)
    result = response.json()
    try:
      self.assertEqual(expected["code"], result["code"])
      self.assertEqual((expected["msg"]), result["msg"])
    except AssertionError as e:
      log.info("用例:{}--->执行未通过".format(case["title"]))
      print("预期结果:{}".format(expected))
      print("实际结果:{}".format(result))
      raise e
    else:
      log.info("用例:{}--->执行通过".format(case["title"]))


if __name__ == '__main__':
  unittest.main()

@ddt它做的事情其实就等同于这句代码:LoginTestCase = ddt(LoginTestCase),把具体的类名传给ddt,告诉ddt是这个测试用例类要使用数据驱动。

@data做的事情就是把测试数据作为一个参数传递给测试用例,一个数据对应生成一条测试用例,如果data里面有多个数据那么就对应生成多条测试用例。如果data里放的类似是元组、列表等这样的序列类型的数据,data会把他们当成是一个整体,即一个测试数据。

​ 如果想一次传递多个参数给测试用例,需要自行在脚本中对数据进行分解或者使用@unpack分解数据。如上例子中的测试用例,只使用了一个参数,但这个参数case是一个字典,字典中已经包含多个数据,直接用key获取对应的值即可。@unpack则是可以把序列类型的数据拆分为多个,以多个参数传给测试用例,但测试用例也需要定义同等数量的参数来接收。

​ 上面例子的测试数据cases来源是使用了openpyxl来读取excel中的测试数据的,关于openpyxl可以看我这个系列的另外一篇随笔。这里直接说明cases其实就是像下面这样的一个列表:

cases = [{'case_id': 1, 'title': '正常登录', 'data': '("test", "Test1234")', 'expected': '{"code": 0, "msg": "登录成功"}'}, {'case_id': 2, 'title': '密码错误', 'data': '("test", "123")', 'expected': '{"code": 1, "msg": "账号或密码不正确"}'}, {'case_id': 3, 'title': '账户名错误', 'data': '("test11", "Test1234")', 'expected': '{"code": 1, "msg": "账号或密码不正确"}'}]

# *解包后,一个字典就是一个测试用例数据
# 如第一个字典:{'case_id': 1, 'title': '正常登录', 'data': '("test", "Test1234")', 'expected': '{"code": 0, "msg": "登录成功"}'}

​ 通过*解包,它的数据就是3个字典,每次给测试用例传入1个字典,而这个字典里就存放了一条完整的登录接口测试用例的测试数据,包括用例id、用例标题、测试的账号密码、期望返回的结果。

​ ?小结:

  • @data(a,b):a和b各运行一次用例
  • @data(*(a,b):a和b各运行一次用例,使用*解包,相当于@data(a,b)
  • @data([a,d],[c,d])

                  如果没有@unpack[a,b]、[c,d]都会被当成一个参数传入用例,即用[a,b]运行一次,用[c,d]运行一次;
                  如果有@unpack,[a,b]会被分解开,一次传递两个参数给用例,用例需要定义两个参数接收
                  @unpack可适用元组、列表或字典,但当传入的是字典时,字典的key和用例定义的参数名需要保持一致

​ 关键代码:@file_data,传递文件(json/yaml)

扩展

​ 关键代码:@file_data,传递文件(json/yaml)

# 传递json
"""
json文件数据
{
	"token":123456,
	"actionName": "api.login",
	"content": {
		"user": "miki",
		"pwd": "Test123"
	}
}
"""
"""
yaml文件
test_list:
 - 11
 - 22
 - 12

sorted_list: [ 11, 12, 22 ]
"""
from ddt import *


@ddt	# 声明使用ddt
class TestFile(unittest.TestCase):

  @file_data('D:/test/test.json')
  def test_json(self, json_data):
    print(json_data)
    
  @file_data('D:/test/test.yaml')
  def test_yaml(self, yaml_data):
    print("yaml", yaml_data)

以上就是python 基于DDT实现数据驱动测试的详细内容,更多关于python 实现数据驱动测试的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python3图片转换二进制存入mysql
Dec 06 Python
python实现多线程采集的2个代码例子
Jul 07 Python
对Python中type打开文件的方式介绍
Apr 28 Python
解决Pycharm界面的子窗口不见了的问题
Jan 17 Python
pandas中的series数据类型详解
Jul 06 Python
python基于paramiko将文件上传到服务器代码实现
Jul 08 Python
Python3并发写文件与Python对比
Nov 20 Python
python分布式计算dispy的使用详解
Dec 22 Python
Python for循环搭配else常见问题解决
Feb 11 Python
python中使用you-get库批量在线下载bilibili视频的教程
Mar 10 Python
python如何编写win程序
Jun 08 Python
python如何对链表操作
Oct 10 Python
详解解决jupyter不能使用pytorch的问题
Feb 18 #Python
python 使用openpyxl读取excel数据
Feb 18 #Python
Python用SSH连接到网络设备
Feb 18 #Python
python 实现IP子网计算
Feb 18 #Python
详解python3 GUI刷屏器(附源码)
Feb 18 #Python
基于Python-turtle库绘制路飞的草帽骷髅旗、美国队长的盾牌、高达的源码
Feb 18 #Python
Python如何telnet到网络设备
Feb 18 #Python
You might like
PHP 杂谈《重构-改善既有代码的设计》之四 简化条件表达式
2012/04/09 PHP
php文件夹与文件目录操作函数介绍
2013/09/09 PHP
php中并发读写文件冲突的解决方案
2013/10/25 PHP
PHP fastcgi模式上传大文件(大约有300多K)报错
2014/09/28 PHP
php上传功能集后缀名判断和随机命名(强力推荐)
2015/09/10 PHP
php生成验证码函数
2015/10/20 PHP
PHP strcmp()和strcasecmp()的区别实例
2016/11/05 PHP
用jquery来定位
2007/02/20 Javascript
Js 获取Gridview选中行的内容操作步骤
2013/02/05 Javascript
Javascript中的arguments与重载介绍
2015/03/15 Javascript
Javascript ES6中数据类型Symbol的使用详解
2017/05/02 Javascript
express框架实现基于Websocket建立的简易聊天室
2017/08/10 Javascript
JavaScript中为事件指定处理程序的五种方式分析
2018/07/27 Javascript
微信小程序使用npm支持踩坑
2018/11/07 Javascript
Vue数字输入框组件的使用方法
2019/10/19 Javascript
javascript实现画板功能
2020/04/12 Javascript
ES6的循环与可迭代对象示例详解
2021/01/31 Javascript
[01:35]2018年度CS GO最佳战队-完美盛典
2018/12/17 DOTA
更改Ubuntu默认python版本的两种方法python-> Anaconda
2016/12/18 Python
python实现感知器
2017/12/19 Python
python如何为被装饰的函数保留元数据
2018/03/21 Python
Python多线程处理实例详解【单进程/多进程】
2019/01/30 Python
Django实现简单网页弹出警告代码
2019/11/15 Python
python 计算方位角实例(根据两点的坐标计算)
2020/01/17 Python
python ffmpeg任意提取视频帧的方法
2020/02/21 Python
python nohup 实现远程运行不宕机操作
2020/04/16 Python
HTML5+css3:3D旋转木马效果相册
2017/01/03 HTML / CSS
兰芝美国网上商城:购买LANEIGE睡眠面膜等
2017/06/30 全球购物
Sephora丝芙兰马来西亚官方网站:国际化妆品购物
2018/03/15 全球购物
中国双语服务优势的在线购票及活动平台:247tickets
2018/10/26 全球购物
美国购买隐形眼镜网站:Lenses For Less
2020/07/05 全球购物
"引用"与多态的关系
2013/02/01 面试题
护理专业求职信
2014/06/15 职场文书
退休劳动合同怎么写?
2019/10/25 职场文书
Mysql binlog日志文件过大的解决
2021/10/05 MySQL
《巫师》是美食游戏?CDPR10月将推出《巫师》官方食谱
2022/04/03 其他游戏