本文共 4659 字,大约阅读时间需要 15 分钟。
所谓数据驱动测试,简单的理解为数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变。通过使用数据驱动测试的方法,可以在需要验证多组数据测试场景中,使用外部数据源实现对输入输出与期望值的参数化,避免在测试中使用硬编码的数据。
这种方法对于测试步骤相同而使用不同的输入值和期望值的测试场景尤为重要,比如设计一个ATM机取款的测试用例设计。1 .测试数据为多个字典的list类型2.测试类前加修饰@ddt.ddt3.case前加修饰@ddt.data()4.运行后用例会自动加载成三个单独的用例
ddt(Data Driver Test)的库可以将测试中的变量进行参数化,使用之前先进行在线安装。
为了支持对Excel 数据表的支持,需要安装 xlrd 库
对于如何使用上述的几个装饰符,通过以下实例进行剖析
import unittestfrom ddt import ddt,data,unpack@ddtclass MyTestCase(unittest.TestCase): @data(1,2,3) def test_something(self,value): self.assertEqual(value, 2)if __name__ == '__main__': unittest.main(verbosity=2)
输出结果:
import unittestfrom ddt import ddt,data,unpack@ddtclass MyTestCase(unittest.TestCase): @data((1,2),(2,3)) @unpack def test_something(self,value1,value2): print value1,value2 self.assertEqual(value2, value1+1)if __name__ == '__main__': unittest.main()
输出结果:
基于以上的基础,现在从 Excel 中读取数据,数据表如下:
# 打开exlce表格,参数是文件路径data = xlrd.open_workbook('test.xlsx')# table = data.sheets()[0] # 通过索引顺序获取# table = data.sheet_by_index(0) # 通过索引顺序获取table = data.sheet_by_name(u'Sheet1') # 通过名称获取nrows = table.nrows # 获取总行数ncols = table.ncols # 获取总列数# 获取一行或一列的值,参数是第几行print table.row_values(0) # 获取第一行值print table.col_values(0) # 获取第一列值
读取上述的 Excel 表格
# coding:utf-8import xlrdclass ExcelUtil(): def __init__(self, excelPath, sheetName): self.data = xlrd.open_workbook(excelPath) self.table = self.data.sheet_by_name(sheetName) self.keys = self.table.row_values(0) self.rowNum = self.table.nrows self.colNum = self.table.ncols def dict_data(self): if self.rowNum <= 1: print("the sum of line is less than 1") else: r = [] j=1 for i in range(self.rowNum-1): s = {} values = self.table.row_values(j) for x in range(self.colNum): s[self.keys[x]] = values[x] r.append(s) j+=1 return rif __name__ == "__main__": filepath = "information.xlsx" sheetName = "Sheet1" data = ExcelUtil(filepath, sheetName) print data.dict_data()
输出结果:
C:\Python27\python.exe F:/py_test/UnitTest/importexcel.py[{ u'username': u'Jack', u'country': u'US', u'password': 123456.0}, { u'username': u'Pan', u'country': u'CHINA', u'password': u'abcdef'}, { u'username': u'John', u'country': u'UK', u'password': u'su39n3'}]Process finished with exit code 0
现在导入excel测试数据,模块为:ExcelUtil.py
import xlrdclass ExcelUtil(object): def __init__(self, excelPath, sheetName): self.data = xlrd.open_workbook(excelPath) self.table = self.data.sheet_by_name(sheetName) # get titles self.row = self.table.row_values(0) # get rows number self.rowNum = self.table.nrows # get columns number self.colNum = self.table.ncols # the current column self.curRowNo = 1 def next(self): r = [] while self.hasNext(): s = {} col = self.table.row_values(self.curRowNo) i = self.colNum for x in range(i): s[self.row[x]] = col[x] r.append(s) self.curRowNo += 1 return r def hasNext(self): if self.rowNum == 0 or self.rowNum <= self.curRowNo: return False else: return Trueif __name__ == "__main__": filepath = "information.xlsx" sheetName = "Sheet1" data = ExcelUtil(filepath, sheetName) print data.hasNext()
测试模块为:
import unittestimport ddt#from driver.ExcelUtil import ExcelUtilfrom ExcelUtil import ExcelUtilexcel = ExcelUtil('information.xlsx', 'Sheet1')@ddt.ddtclass DataTest(unittest.TestCase): @classmethod def setUpClass(cls): print('start') @classmethod def tearDownClass(cls): print('stop') @ddt.data(*excel.next()) def testLogin(self, data): print(data['username']) print(data['password']) print(data['country'])if __name__ == "__main__": suite = unittest.TestLoader().loadTestsFromTestCase(DataTest) unittest.TextTestRunner(verbosity=2).run(suite)
这里在这两个模块对应的目录下创建一个名为information.xlsx的Excel数据表格