侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Python Selenium 之数据驱动测试的实现

Python  /  管理员 发布于 7年前   156

数据驱动模式的测试好处相比普通模式的测试就显而易见了吧!使用数据驱动的模式,可以根据业务分解测试数据,只需定义变量,使用外部或者自定义的数据使其参数化,从而避免了使用之前测试脚本中固定的数据。可以将测试脚本与测试数据分离,使得测试脚本在不同数据集合下高度复用。不仅可以增加复杂条件场景的测试覆盖,还可以极大减少测试脚本的编写与维护工作。

下面将使用Python下的数据驱动模式(ddt)库,结合unittest库以数据驱动模式创建百度搜索的测试。

ddt库包含一组类和方法用于实现数据驱动测试。可以将测试中的变量进行参数化。

可以通过python自带的pip命令进行下载并安装:pip install ddt . 更多关于ddt的信息可以参考:

https://pypi.org/project/ddt/

一个简单的数据驱动测试

为了创建数据驱动测试,需要在测试类上使用@ddt装饰符,在测试方法上使用@data装饰符。@data装饰符把参数当作测试数据,参数可以是单个值、列表、元组、字典。对于列表,需要用@unpack装饰符把元组和列表解析成多个参数。

下面实现百度搜索测试,传入搜索关键词和期望结果,代码如下:

import unittestfrom selenium import webdriverfrom ddt import ddt, data, unpack@ddtclass SearchDDT(unittest.TestCase):  '''docstring for SearchDDT'''  def setUp(self):    self.driver = webdriver.Chrome()    self.driver.implicitly_wait(30)    self.driver.maximize_window()    self.driver.get("https://www.baidu.com")  # specify test data using @data decorator  @data(('python', 'PyPI'))  @unpack  def test_search(self, search_value, expected_result):    search_text = self.driver.find_element_by_id('kw')    search_text.clear()    search_text.send_keys(search_value)    search_button = self.driver.find_element_by_id('su')    search_button.click()    tag = self.driver.find_element_by_link_text("PyPI").text    self.assertEqual(expected_result, tag)  def tearDown(self):    self.driver.quit()if __name__ == '__main__':  unittest.main(verbosity=2)

在test_search()方法中,search_value与expected_result两个参数用来接收元组解析的数据。当运行脚本时,ddt把测试数据转换为有效的python标识符,生成名称为更有意义的测试方法。结果如下:

使用外部数据的数据驱动测试

如果外部已经存在了需要的测试数据,如一个文本文件、电子表格或者数据库,那也可以用ddt来直接获取数据并传入测试方法进行测试。

下面将借助外部的CSV(逗号分隔值)文件和EXCLE表格数据来实现ddt。

通过CSV获取数据

同上在@data装饰符使用解析外部的CSV(testdata.csv)来作为测试数据(代替之前的测试数据)。其中数据如下:

接下来,先要创建一个get_data()方法,其中包括路径(这里默认使用当前路径)、CSV文件名。调用CSV库去读取文件并返回一行数据。再使用@ddt及@data实现外部数据驱动测试百度搜索,代码如下:

import csv, unittestfrom selenium import webdriverfrom ddt import ddt, data, unpackdef get_data(file_name):  # create an empty list to store rows  rows = []  # open the CSV file  data_file = open(file_name, "r")  # create a CSV Reader from CSV file  reader = csv.reader(data_file)  # skip the headers  next(reader, None)  # add rows from reader to list  for row in reader:    rows.append(row)  return rows@ddtclass SearchCSVDDT(unittest.TestCase):  def setUp(self):    self.driver = webdriver.Chrome()    self.driver.implicitly_wait(30)    self.driver.maximize_window()    self.driver.get("https://www.baidu.com")  # get test data from specified csv file by using the get_data funcion  @data(*get_data('testdata.csv'))  @unpack  def test_search(self, search_value, expected_result):    search_text = self.driver.find_element_by_id('kw')    search_text.clear()    search_text.send_keys(search_value)    search_button = self.driver.find_element_by_id('su')    search_button.click()    tag = self.driver.find_element_by_link_text("PyPI").text    self.assertEqual(expected_result, tag)  def tearDown(self):    self.driver.quit()if __name__ == '__main__':  unittest.main(verbosity=2)

测试执行时,@data将调用get_data()方法读取外部数据文件,并将数据逐行返回给@data。执行的结果也同上~

通过Excel获取数据

测试中经常用Excle存放测试数据,同上在也可以使用@data装饰符来解析外部的CSV(testdata.csv)来作为测试数据(代替之前的测试数据)。其中数据如下:

接下来,先要创建一个get_data()方法,其中包括路径(这里默认使用当前路径)、EXCEL文件名。调用xlrd库去读取文件并返回数据。再使用@ddt及@data实现外部数据驱动测试百度搜索,代码如下:

import xlrd, unittestfrom selenium import webdriverfrom ddt import ddt, data, unpackdef get_data(file_name):  # create an empty list to store rows  rows = []  # open the CSV file  book = xlrd.open_workbook(file_name)  # get the frist sheet  sheet = book.sheet_by_index(0)  # iterate through the sheet and get data from rows in list  for row_idx in range(1, sheet.nrows): #iterate 1 to maxrows    rows.append(list(sheet.row_values(row_idx, 0, sheet.ncols)))  return rows@ddtclass SearchEXCLEDDT(unittest.TestCase):  def setUp(self):    self.driver = webdriver.Chrome()    self.driver.implicitly_wait(30)    self.driver.maximize_window()    self.driver.get("https://www.baidu.com")  # get test data from specified excle spreadsheet by using the get_data funcion  @data(*get_data('TestData.xlsx'))  @unpack  def test_search(self, search_value, expected_result):    search_text = self.driver.find_element_by_id('kw')    search_text.clear()    search_text.send_keys(search_value)    search_button = self.driver.find_element_by_id('su')    search_button.click()    tag = self.driver.find_element_by_link_text("PyPI").text    self.assertEqual(expected_result, tag)  def tearDown(self):    self.driver.quit()if __name__ == '__main__':  unittest.main(verbosity=2)

与上面读取CVS文件一样,测试执行时,@data将调用get_data()方法读取外部数据文件,并将数据逐行返回给@data。执行的结果也同上~

如果想从数据库的库表中获取数据,同样也需要一个get_data()方法,并且通过DB相关的库来连接数据库、SQL查询来获取测试数据。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    Python CVXOPT模块安装及使用解析
    下一条:
    Python 一键获取百度网盘提取码的方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客