分享

Python 接口自动化测试之数据驱动(DDT)

 青柠二锅头 2021-08-03

      在接口测试中,一个接口往往需要有多组数据进行测试,以验证接口的正确性。这样就涉及到一个问题,是不是需要编写多个测试用例来实现呢?比如一个登陆接口,登陆成功的一组数据、登陆密码错误的一组数据、登陆账号错误的一组数据。那我们要怎么操作呢?数据驱动就可以很好的解决该问题。只需要编写一个测试用例脚本,通过传入不同的数据,返回不同的测试结果。

     python中实现数据驱动是通过引入ddt模块来实现的。没有安装的,直接安装改模块即可。

   import ddt

使用数据驱动时,需要在测试的模块上进行声明。在具体的测试方法上使用ddt.data()方法或者ddt.file_data()进行参数传递

ddt.data()默认将参数都传递给第一个参数,每一组数据执行一遍测试用例,以达到数据驱动的效果。如果传递多个参数时需要用到ddt.unpack 声明进行拆分

案例如下:

import ddtimport unittestimport ReadExcel
testData =ReadExcel.ReadExcel.readExcel('E:\\study\\data\\test_ddt.xls', 'Sheet1')@ddt.ddt #声明使用数据驱动class DDTtest(unittest.TestCase):    @ddt.data([1,2],[3,4])   #数据参数 @ddt.unpack #拆分参数 def test_A(self,a,b): print(a+b)
@ddt.data({'a','b'}) def test_B(self,a): print(a) @ddt.data([1,2]) def test_C(self,a): print(a)
    @ddt.data(*testData)  #读取Excel文件进行传递,这里必须是迭代器 def test_D(self, data): print(data) print('执行完成') return
if __name__=='__main__': unittest.main();
import xlrd#读取Excel的方法class ReadExcel():     def readExcel(fileName,SheetName='Sheet1'):         data = xlrd.open_workbook(fileName)         table = data.sheet_by_name(SheetName)
#获取总行数、总列数 nrows = table.nrows ncols = table.ncols if nrows > 1: #获取第一行的内容,列表格式 keys = table.row_values(0) #print(keys)
listApiData = [] #获取每一行的内容,列表格式 for col in range(1,nrows): values = table.row_values(col) # keys,values这两个列表一一对应来组合转换为字典                 api_dict = dict(zip(keys, values))  #print(api_dict) listApiData.append(api_dict) return listApiData else: return None
if __name__ == '__main__': s = ReadExcel.readExcel('E:\\study\\data\\test_ddt.xls','Sheet1') print(s)
执行结果如下:

图片

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多