python-ddt处理测试类数据

Posted 鲲尘轻杳

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python-ddt处理测试类数据相关的知识,希望对你有一定的参考价值。

# ddt + unittest :来进行数据处理的第三方库
# 装饰器:在函数运行前运行
# 安装ddt :python -m pip install ddt

import unittest
from ddt import ddt,data,unpack

test_data1 = [1,3]
test_data2 = [[1,3],[4,5]]
test_data3 = [[1,3],[4,5,6]]
test_data4 = [{no:001,name:kite},{no:002,name:shiguang}]


@ddt # 装饰测试类
class TestMath(unittest.TestCase):
    @data(test_data1)
    def test_print_add1(self,item1):
        print("[1,3]的打印结果是---item1:",item1)  # item1: [1, 3]


    @data(test_data1)
    @unpack  # 根据逗号拆分,注意参数不对等的情况
    def test_print_add2(self,a,b):
        print("*[1,3]的打印结果是---a:",a)  # a: 1
        print("*[1,3]的打印结果是---b:",b)  # b: 3

    @data(test_data2)   # [[1,3],[4,5]]
    @unpack
    def test_print_add3(self, x1, x2):
        print("x1:", x1)  # x1: [1, 3]
        print("x2:", x2)  # x2: [4, 5]

    @data(*test_data2)  # 加*,脱一个参数 [1,3],[4,5]
    @unpack
    def test_print_add4(self, a, b):  # 根据逗号拆分,注意参数不对等,会报错
        print("a:", a)
        print("b:", b)   # 第一组a: 1 b: 3   第二组a: 4 b: 5

    @data(*test_data3)
    @unpack  # unpack拆分后, 参数太多,可以先@data(*test_data2),然后索引找要的值,不推荐使用unpack
    def test_print_add5(self, m = None, n = None, o = None):
        print(m:, m)  # m: (1, 3) m: (4, 5, 6)
        print(n:,n)
        print(o:,o)
        # m: 1          m: 4
        # n: 3          n: 5
        # o: None       o: 6
    @data(*test_data4)   # [{‘no‘:‘001‘,‘name‘:‘kite‘},{‘no‘:‘002‘,‘name‘:‘shiguang‘}]
    @unpack
    def test_print_add4(self, no, name):
        print("no:", no)
        print("name:", name)
        # no: 001        no: 002
        # name: kite     name: shiguang



if __name__ == __main__:
    unittest.main()

以上是关于python-ddt处理测试类数据的主要内容,如果未能解决你的问题,请参考以下文章

python-ddt实践

在 Python 多处理进程中运行较慢的 OpenCV 代码片段

处理recyclerview单击片段而不是持有者类

运行/调试你的PHP代码

常用python日期日志获取内容循环的代码片段

使用实体框架迁移时 SQL Server 连接抛出异常 - 添加代码片段