zoukankan      html  css  js  c++  java
  • ddt数据驱动简单学习

    使用ddt来进行数据驱动

              根据用例的数量来自动生成实例方法,批量执行用例

    数据驱动好处:

                  代码复用率高:同一测试逻辑编写一次,可以被多条测试数据复用

                  异常排查效率高:每条数据生成一条测试用例,用例执行过程相互隔离,在其中一条失败的情况下,不会影响其他的测试用例。

                  代码的可维护性高:清晰的测试框架,利于其他测试工程师阅读,提高了代码的可维护性。

                  实现测试数据与代码分离,测试数据需要修改时,代码不需要修改,修改文件即可

    ddt 第三方,使用需要安装

            cmd——pip install ddt

    导入ddt

           from ddt import ddt,data

    从excel中获取数据

    # testcase.xlsx 文件名, multiply 表单名
    do_excel = HandleExcel("testcase.xlsx","minus")
    # 获取所有的cases
    cases = do_excel.get_cases()

    ddt 装饰器,装饰类

    @ddt
    class Testdivide(unittest.TestCase):

    @data 装饰实例方法

      方法一: 缺陷,如果有100条用例,要写100个数据

    @data("第一条用例数据","第二条用例数据","第三条用例数据","第四条用例数据",)
    def test_divide(self): 
    # 4条用例,每执行一次,就创建一个实例方法test_divide_01、test_divide_02、test_divide_03、test_divide_04

     方法二:拆包

      

    @data(*cases)  # 拆包,将嵌套字典的列表,拆成字典
     def test_divide(self,one_case):

           # 执行了多少条用例,用例执行的条数与data装饰器的(位置)参数的个数一致:data有100个位置参数,那么用例总数为100

             # 每执行一条用例,会自动将一个参数传给one_case

            # 当最后一个参数传给one_case,且用例执行结束之后,程序就会执行完毕

            # ddt 与 data是黄金搭档,要一起使用才行

      

  • 相关阅读:
    How to read a whole document content into a string onetime
    how to get the Authorization of adobe acrobat 8.0 for free
    给求职的同学的几点建议
    select() manul select() 手册
    有无一步登天之法?
    VB6.0 Excel模版,自己設定好分析餅圖,如何動態地更新分析圖的數據源呢?
    C#中的委托和事件(续)
    C# 中的委托和事件
    VB6.0 Excel的動態生成多個Sheet的方法
    VB6.0 用Excel生成數據分析餅圖例子
  • 原文地址:https://www.cnblogs.com/taiyangfeng/p/11815931.html
Copyright © 2011-2022 走看看