python数据驱动--ddt的使用

一、使用ddt可以方便我们对测试case的管理

一般进行接口测试时,每个接口的传参都不止一种情况,一般会考虑正向、逆向等多种组合。所以在测试一个接口时通常会编写多条case,而这些case除了传参不同外,其实并没什么区别。
这个时候就可以利用ddt来管理测试数据,提高代码复用率。

二、ddt的安装方法以及四种模式
1、pip install ddt
2、四种模式:
① 装饰器@ddt
② 导入数据的@data
③ 拆分数据的@unpack
④ 导入外部数据的@file_data

三、案例的演示

1、读取元组数据

#一定要和单元测试框架一起用
import unittest,os
from ddt import ddt,data,unpack,file_data

'''NO.1单组元素'''
@ddt
class Testwork(unittest.TestCase):
    
    @data(1,2,3)
    def test_01(self,value):      #value用来接收data的数据
        print(value)
if __name__ == '__main__':
    unittest.main()
结果:
=>1
  2
  3

'''NO.2多组未分解元素'''
@ddt
class Testwork(unittest.TestCase):

    @data((1,2,3),(4,5,6))
    def test_01(self,value):       
        print(value)

if __name__ == '__main__':
    unittest.main()
结果:
=>(1, 2, 3)
  (4, 5, 6)

'''NO.3多组分解元素'''
@ddt
class Testwork(unittest.TestCase):

    @data((1,2,3),(4,5,6))
    @unpack          #拆分数据
    def test_01(self,value1,value2,value3):    #每组数据有3个值,所以设置3个形参
        print(value)

if __name__ == '__main__':
    unittest.main()
结果:
=>1 2 3
  4 5 6

2、读取列表数据

import unittest,os
from ddt import ddt,data,unpack,file_data

'''NO.1单组元素和多组元素未分解都一样,下面看嵌套,考眼力了~'''
@ddt
class Testwork(unittest.TestCase):

    @data([{'name':'lili','age':12},{'sex':'male','job':'teacher'}])
    # @unpack
    def test_01(self,a):
        print(a)

if __name__ == '__main__':
    unittest.main()
结果:
=>[{'name': 'lili', 'age': 12}, {'sex': 'male', 'job': 'teacher'}]
※上面结果可以看出:无法运用到requests数据请求中,所以不是很实用※

'''NO.2多组元素分解'''
@ddt
class Testwork(unittest.TestCase):

    @data([{'name':'lili','age':12},{'sex':'male','job':'teacher'}])
    @unpack
    def test_01(self,a,b):
        print(a,b)

if __name__ == '__main__':
    unittest.main()
结果:
=>{'name': 'lili', 'age': 12} {'sex': 'male', 'job': 'teacher'}
※拆分后的运行结果,不带有[ ],拆分是将列表中的2个字典拆分,所以有2个数据※

3、读取字典数据

import unittest,os
from ddt import ddt,data,unpack,file_data

'''※字典的读取比较特殊,因为在拆分的时候,形参和实参的key值要一致,否则就报错※'''

'''NO.1单组数据'''
@ddt
class Testwork(unittest.TestCase):

    @data({'name':'lili','age':'16'},{'sex':'female','job':'nurser'})
    # @unpack
    def test_01(self,a):
        print(a)

if __name__ == '__main__':
    unittest.main()
结果:
=>{'name': 'lili', 'age': '16'}
  {'sex': 'female', 'job': 'nurser'}
※以上运行的结果数据,就可以用来作为requests的请求参数~!※

'''NO.2多数据拆分,重点来了'''
@ddt
class Testwork(unittest.TestCase):

    @data({'name':'lili','age':'16'},{'name':'female','age':'nurser'})
    @unpack
    def test_01(self,name,age):
        print(name,age)

if __name__ == '__main__':
    unittest.main()
结果:
=>lili 16
  female nurser
※重点来了:首先结果展示的数据是字典里的value,没有打印key的值;其次@data里的数据key值和def方法里的形参
名称一定要一致,否则,打印的时候,就会报莫名的参数错误,这里就不做展示,爱学习的同学可以尝试一下~!※

4、读取文件数据

import unittest,os
from ddt import ddt,data,unpack,file_data

'''数据格式必须为json,且必须为双引号的键值对形式,如果不是json格式,有列表等其它格式嵌套的话,无论是
否有@unpack,形参和参数数量都要和key值相等'''
@ddt
class testwork(unittest.TestCase):
    testdata=[{'a':'lili','b':12},{'a':'sasa','b':66}]
    @data(*testdata)
    # @unpack
    def test_01(self,value):
        print(value)

    @file_data(os.getcwd()+'/jsonll.txt')
    def test_02(self,value2):
        print(value2)

if __name__ == '__main__':
    unittest.main()
结果:
=>{'a': 'lili', 'b': 12}
  {'a': 'sasa', 'b': 66}
  nick
  male
  29

备注:文章转自 https://www.jianshu.com/p/78998bcf3e05


以下自己总结:方便自己理解
1、@unpack这个装饰器,默认会对@date装饰器内容中的每一项以"逗号"进行数据的分解。
举例:

import unittest
from ddt import ddt, data, unpack


@ddt
class TestMethod(unittest.TestCase):

    case = [{"data1": 1, "data2": 2},{"data1": 3, "data2": 4}]
    # *case是对 case进行解包, 就相当于把case的外层中括号去掉,由一个列表变成两个字典
    @data(*case)
    @unpack # 拆包是对每个字典进行数据拆分,通过字典的‘逗号’,分成data1, data2 两个数据
    def test01(self, data1, data2): # data1 和data2 也可以统一用**kwargs 来表示 直接用			
        print(data1, data2)			# print(kwarts.get('data1')) 也可以得到 data1的值
        
	 结果为 ..
		1 2
		3 4
	# 如果case中不是字典而是元组或者列表原理是一样的
	
	case1 = [(5, 6), (7, 8)]

    @data(*case1)
    @unpack # 对每个元组进行中的两个数据进行拆解‘逗号’分解
    def test02(self, a, b): # 设置两个变量进行接收 如果是字典的话形参必须和字典中的key保持一致
        print(a, b)
        
	结果为:
		5 6
		7 8

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

2、@file_data(), 这个装饰器的括号内可以加入一个用例case的文件路径可以是yaml格式或者excel格式
这里以yaml格式来举例

yaml文件case.yaml

-
  test1:
    test2: 1
    test3: 2
    test4: 3
    test5:
      - a
      - b
      - c
-
  test6:
    - d
    - f
    - g

python代码:

import unittest
from ddt import ddt, data, unpack,file_data


@ddt
class TestMethod(unittest.TestCase):

    # case1 = [(1, 2), (3, 4)]
    @file_data('./test.yaml')

    # @data(*case1)
    @unpack
    def test02(self, **kwargs):
        print(kwargs)
	结果为:
	{'test1': {'test2': 1, 'test3': 2, 'test4': 3, 'test5': ['a', 'b', 'c']}}
	{'test6': ['d', 'f', 'g']}

if __name__ == '__main__':
    unittest.main()
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DDT(Data Driver Tests)是一种数据驱动测试的方法。在Python中,可以使用ddt库实现数据驱动。安装ddt库可以使用pip install ddt命令。使用@ddt注解可以将测试类标记为数据驱动测试类。使用@data(*case_data)注解可以对测试函数进行数据解压,将每个元素传递给测试函数作为参数。ddt库还提供了@unpack注解,用于将元组或列表中的元素按顺序传递给测试函数的参数。下面是一个使用ddt进行数据驱动的示例代码: ```python from ddt import ddt, data, unpack import unittest case_data = [(1, 2, 3), (4, 5, 9), (7, 8, 15)] @ddt class TestDataDriven(unittest.TestCase): @data(*case_data) @unpack def test_addition(self, a, b, expected_result): result = a + b self.assertEqual(result, expected_result) if __name__ == '__main__': unittest.main() ``` 在上述代码中,我们使用ddt库的@ddt注解将测试类TestDataDriven标记为数据驱动测试类。使用@data(*case_data)注解将每个元组中的元素作为参数传递给测试函数test_addition。使用@unpack注解将元组中的元素按顺序传递给测试函数的参数a、b和expected_result。在测试函数中,我们执行了一个加法操作,并使用self.assertEqual()断言来验证结果是否符合预期。 通过这种方式,我们可以轻松地实现数据驱动的测试,并在多组测试数据上运行相同的业务逻辑。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Python自动化之-DDT数据驱动](https://blog.csdn.net/qq_37982823/article/details/121662033)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [python数据驱动-ddt](https://blog.csdn.net/pangbianlaogu/article/details/80261730)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值