import unittest
from ddt import ddt, data, unpack
"""
1.正常情况下,测试函数(即测试用例)中不可以传参,如果要使用参数,只能通过超继承_init_函数,
在初始化函数中传入参数,然后在测试函数中调用参数
2.如果不使用超继承,还可以使用ddt,这样就可以给用例传参了
3.当用例的参数不超过5个时,可以使用unpack,超过5个后,不建议使用ddt,而应该直接通过索引取参数
"""
# ddt-----------------------------
test_data = [1, 3]

# @ddt  # 装饰测试类
# class TestMath(unittest.TestCase):
#
#     @data(*test_data)  # 装饰测试用例,传入测试数据,这里会把列表的子元素分别取出来
#     def test_print_data(self, item):  # 使用ddt后,可以给用例传参,有多少个子元素,就会执行几次用例,一个子元素对应一个用例
#         print("item: ", item)
# ----------------------------------------------------

# 参数前加*,脱外套
# t = [3, 6]
# print(*t)
# -----------------------------------------------------

# 给数据加*后,会脱掉一层外套,数据被拆分,
# 有几个数据就会执行几次测试用例。和遍历是一样的效果
# test_data = [[1, 4], [2, 5]]
#
#
# @ddt  # 装饰测试类
# class TestMath(unittest.TestCase):
#
#     @data(*test_data)  # 装饰测试用例,传入数据,给数据脱外套
#     def test_print_data(self, item):
#         print("item: ", item)
# -------------------------------------------------------------

# 给用例传2个参数
# test_data = [[1, 4], [2, 6]]
#
# @ddt
# class TestMath(unittest.TestCase):
#     @data(*test_data)
#     @unpack  # 把拿到的数据,用逗号进行拆分,比如经过*test_data得到子元素[1, 4], [2, 6], 经过unpack后,会把[1,4]变成1和4,所以在用例中,需要两个参数来接收
#     def test_print_data(self, a, b):
#         print("a: ", a)
#         print("b: ", b)
# ---------------------------------------------------
# 脱掉一层外套后的子元素个数必须相等,不然会报错,要么就设置默认值参数
# test_data = [[1, 2], [3, 4, 5]]

#
# @ddt
# class TestMath(unittest.TestCase):
#     @data(*test_data)
#     @unpack
#     def test_print_data(self, a, b, c=None):
#         print("a: ", a)
#         print("b: ", b)
#         print("c: ", c)
# -----------------------------------------------
# 子元素超过5个后不建议使用unpack
# test_data = [[1, 3], [1, 2, 3, 4, 5, 6, 7]]
#
#
# @ddt
# class TestMath(unittest.TestCase):
#     @data(*test_data)
#     def test_print_data(self, item):
#         print("item: ", item)
# --------------------------------------
# 对字典进行unpack时,测试用例中传入的参数名要和字典的键名一样
# test_data = [{"num": 1, "name": "huihui"}, {"num": 2, "name": "haha"}]
#
#
# @ddt
# class TestMath(unittest.TestCase):
#     @data(*test_data)
#     @unpack
#     def test_print_data(self, num, name):
#         print("num: ", num)
#         print("name: ", name)

  

unittest(8)- 学习ddt的更多相关文章

  1. selenium + python自动化测试unittest框架学习(二)

    1.unittest单元测试框架文件结构 unittest是python单元测试框架之一,unittest测试框架的主要文件结构: File >report >all_case.py &g ...

  2. selenium + python自动化测试unittest框架学习(一)selenium原理及应用

    unittest框架的学习得益于虫师的<selenium+python自动化实践>这一书,该书讲得很详细,大家可以去看下,我也只学到一点点用于工作中,闲暇时记录下自己所学才能更加印象深刻. ...

  3. python - unittest 单元测试学习

    单元测试 单元测试是用来对一个模块.一个函数或者一个类进行正确性检验的测试工作 比如对Python中的abs 的测试 输入正数: 比如 1, 2, 3, 返回值不变 输入负数: 比如 -1, -2, ...

  4. unittest使用数据驱动ddt

    简介 ddt(data driven test)数据驱动测试:由外部数据集合来驱动测试用例,适用于测试方法不变,但需要大量变化的数据进行测试的情况,目的就是为了数据和测试步骤的分离 由于unittes ...

  5. 12.unittest的学习

    unittest学习后的总结,记录各个主要内容

  6. 【python】以souhu邮箱为例学习DDT数据驱动测试

    前言 DDT(Data-Driven Tests)是针对 unittest 单元测试框架设计的扩展库.允许使用不同的测试数据来运行一个测试用例,并将其展示为多个测试用例.通俗理解为相同的测试脚本使用不 ...

  7. selenium + python自动化测试unittest框架学习(七)随机生成姓名

    在自动化测试过程中经常要测试到添加用户的操作,每次都要输入中文,原本是找了十几个中文写成了列表,然后从列表中随机取出填入用户名文本框中,随着测试的增加,发现同名的人搜索出来一大堆,最后在网上找了个随机 ...

  8. selenium + python自动化测试unittest框架学习(五)webdriver的二次封装

    因为webdriver的api方法很长,再加上大多数的定位方式是以xpath方式定位,更加让代码看起来超级长,为了使整体的代码看起来整洁,对webdriver进行封装,学习资料来源于虫师的<se ...

  9. 单元测试模块unittest使用学习

    工作原理: unittest中最核心的四个概念是:test case, test suite, test runner, test fixture. 一个TestCase的实例就是一个测试用例.什么是 ...

随机推荐

  1. 吴裕雄--天生自然 JAVA开发学习:条件语句

    public class Test { public static void main(String args[]){ int x = 10; if( x < 20 ){ System.out. ...

  2. Servlet&JSP复习笔记 03

    1.Servlet的声明周期 容器如何创建Servlet对象,如何为Servlet对象分配资源,如何调用Servlet对象的方法来处理请求,以及如何销毁Servlet对象的过程. a.实例化 容器调用 ...

  3. Java之多线程方式一(继承Thread类)

    /** * 多线程的创建,方式一:继承于Thread类 * 1. 创建一个继承于Thread类的子类 * 2. 重写Thread类的run() --> 将此线程执行的操作声明在run()中 * ...

  4. 如何优雅的设计APP页面?

    页面框架设计只是整个产品设计中的一环,不要把眼界局限在这一环,也不要只站需求.只站在交互.只站在视觉上思考问题,从多个角度看问题,你才会学会成长. 产品设计是一个系统工程,单独拧出来其中一个流程来讲, ...

  5. 内网部署Docker版本Gitlab

    Gitlab部署: 1. 还原备份文件后记得拷贝gitlab-secrets.json,不然会遇到500错误 2. 下载Docker以及依赖项rpm包 3. 在外网机器下载镜像 a. 拉取——Dock ...

  6. win10+CUDA9.0176、CUDNN7.6.0安装

    在github上下载了一个文本分类的代码,包含了CNN.LSTM等分类模型,运行时说我的CUDA版本不行,我原来是9.1,让我安装9.0 然后开始卸载9.1啊,在此感谢博主:https://blog. ...

  7. Exchange Onine 公用文件夹

    公用文件夹专为共享访问设计,为收集.组织信息及工作组织中的其他人共享信息提供提供了一种轻松.有效的方式.公用文件夹帮助以易于浏览的层次结构来组织内容. 一.公用文件夹的适用环境 公用文件夹在以下out ...

  8. 在select2插件中append下拉选,点击没反应的解决

    今天前端大佬帮我解决了一个棘手的问题:克隆了已有系统的网页,尝试把复制下来的html改造成jsp.基本功能正常,然而点击新增按钮,出来的行无法点击下拉选,控制台也没报错. 项目用的是jeesite2. ...

  9. LeetCode No.103,104,105

    No.103 ZigzagLevelOrder 二叉树的锯齿形层次遍历 题目 给定一个二叉树,返回其节点值的锯齿形层次遍历.(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行). ...

  10. RDD(八)——缓存与检查点

    RDD通过persist方法或cache方法可以将前面的计算结果缓存,默认情况下 persist() 会把数据以序列化的形式缓存在 JVM 的堆空间中. 但是并不是这两个方法被调用时立即缓存,而是触发 ...