Excel+DDT数据驱动实例

一、首先安装dtt模块

数据驱动原理

1.测试数据为多个字典的list类型

2.测试类前加修饰@ddt.ddt

3.case前加修饰@ddt.data()

4.运行后用例会自动加载成N个单独的用例

二、实例

ExcellData.py

 1 # coding:utf-8
 2 import xlrd
 3 
 4 
 5 class excel:
 6     def __init__(self):
 7         self.test_data_path = 'F:\\testdata.xlsx'
 8 
 9     def open_excel(self,file):
10         u'''读取excel文件'''
11         try:
12             data = xlrd.open_workbook(file)
13             return data
14         except Exception, e:
15             raise e
16 
17     def excel_table(self,file, sheetName):
18         u'''装载list'''
19         data = self.open_excel(file)
20         # 通过工作表名称,获取到一个工作表
21         table = data.sheet_by_name(sheetName)
22         # 获取行数
23         Trows = table.nrows
24         # 获取 第一行数据
25         Tcolnames = table.row_values(0)
26         lister = []
27         for rownumber in range(1,Trows):
28             row = table.row_values(rownumber)
29             if row:
30                 app = {}
31                 for i in range(len(Tcolnames)):
32                     app[Tcolnames[i]] = row[i]
33                 lister.append(app)
34         return lister
35 
36     def get_list(self,sheetname):
37         try:
38             data_list = self.excel_table(self.test_data_path, sheetname)
39             assert len(data_list)>=0,u'excel标签页:'+sheetname+u'为空'
40             return data_list
41         except Exception as e:
42             raise e

test.py

 1 # coding:utf-8
 2 __author__ = 'Helen'
 3 '''
 4 project:ddt数据驱动
 5 '''
 6 import unittest,ddt
 7 from ExcelData import excel
 8 
 9 # 测试数据
10 excel_data = excel()
11 testdata = excel_data.get_list('userData')
12 
13 @ddt.ddt
14 class TestDtt(unittest.TestCase):
15     @classmethod
16     def setUpClass(cls):
17         print u'开始测试---------------'
18 
19     @ddt.data(*testdata)
20     def test(self, data):
21         print 'username:'+data['username']+',password:'+data['password']
22 
23     @classmethod
24     def tearDownClass(cls):
25         print u'结束测试------------------'
26 
27 if __name__=='__main__':
28     unittest.main()

 

转载于:https://www.cnblogs.com/helenMemery/p/7029016.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pytest是一个Python的测试框架,用于编写和运行测试用例。而yaml则是一种常见的数据格式,用于存储和传输数据。 在pytest中,可以使用ddt(Data-Driven Testing)模块来进行数据驱动的测试。ddt模块允许我们将测试用例的输入数据和预期结果从代码中分离出来,以yaml格式存储在单独的文件中。这样一来,我们可以轻松地修改和扩展测试数据,而无需修改测试代码。 使用ddt进行数据驱动测试的步骤如下: 1. 安装ddt模块:在终端中运行`pip install ddt`命令来安装ddt模块。 2. 在测试类中引入ddt装饰器:在测试类上方添加`@ddt`装饰器,以告诉pytest该类将使用ddt模块。 3. 使用@data装饰器和@unpack装饰器:在测试方法上方添加`@data`装饰器,并传入从yaml文件中读取的测试数据。如果测试数据是一个列表,可以使用`@unpack`装饰器将其拆分为多个参数,方便使用。 4. 在测试方法中使用测试数据:在测试方法内部,使用传入的测试数据进行测试操作。通过调用断言函数来比较实际结果和预期结果,以判断测试是否通过。 5. 在命令行中运行测试用例:在终端中运行命令`pytest`来执行测试用例。pytest将自动查找和执行包含ddt装饰器的测试方法,并使用测试数据进行多次测试。 通过这种方式,我们可以通过简单修改或添加yaml文件中的测试数据,从而轻松地扩展和维护测试用例。同时,ddt模块还提供了更多的装饰器和功能,如@file_data、@cases、@data_class等,可以满足各种不同的测试需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值