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

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

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

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

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

一个简单的数据驱动测试

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

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

  1. import unittest
  2. from selenium import webdriver
  3. from ddt import ddt, data, unpack
  4.  
  5. @ddt
  6. class SearchDDT(unittest.TestCase):
  7. '''docstring for SearchDDT'''
  8. def setUp(self):
  9. self.driver = webdriver.Chrome()
  10. self.driver.implicitly_wait(30)
  11. self.driver.maximize_window()
  12. self.driver.get("https://www.baidu.com")
  13.  
  14. # specify test data using @data decorator
  15. @data(('python', 'PyPI'))
  16. @unpack
  17. def test_search(self, search_value, expected_result):
  18. search_text = self.driver.find_element_by_id('kw')
  19. search_text.clear()
  20. search_text.send_keys(search_value)
  21.  
  22. search_button = self.driver.find_element_by_id('su')
  23. search_button.click()
  24.  
  25. tag = self.driver.find_element_by_link_text("PyPI").text
  26. self.assertEqual(expected_result, tag)
  27.  
  28. def tearDown(self):
  29. self.driver.quit()
  30.  
  31. if __name__ == '__main__':
  32. 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实现外部数据驱动测试百度搜索,代码如下:

  1. import csv, unittest
  2. from selenium import webdriver
  3. from ddt import ddt, data, unpack
  4.  
  5. def get_data(file_name):
  6. # create an empty list to store rows
  7. rows = []
  8. # open the CSV file
  9. data_file = open(file_name, "r")
  10. # create a CSV Reader from CSV file
  11. reader = csv.reader(data_file)
  12. # skip the headers
  13. next(reader, None)
  14. # add rows from reader to list
  15. for row in reader:
  16. rows.append(row)
  17. return rows
  18.  
  19. @ddt
  20. class SearchCSVDDT(unittest.TestCase):
  21. def setUp(self):
  22. self.driver = webdriver.Chrome()
  23. self.driver.implicitly_wait(30)
  24. self.driver.maximize_window()
  25. self.driver.get("https://www.baidu.com")
  26.  
  27. # get test data from specified csv file by using the get_data funcion
  28. @data(*get_data('testdata.csv'))
  29. @unpack
  30. def test_search(self, search_value, expected_result):
  31. search_text = self.driver.find_element_by_id('kw')
  32. search_text.clear()
  33. search_text.send_keys(search_value)
  34.  
  35. search_button = self.driver.find_element_by_id('su')
  36. search_button.click()
  37.  
  38. tag = self.driver.find_element_by_link_text("PyPI").text
  39. self.assertEqual(expected_result, tag)
  40.  
  41. def tearDown(self):
  42. self.driver.quit()
  43.  
  44. if __name__ == '__main__':
  45. unittest.main(verbosity=2)

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

通过Excel获取数据

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

  

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

  1. import xlrd, unittest
  2. from selenium import webdriver
  3. from ddt import ddt, data, unpack
  4.  
  5. def get_data(file_name):
  6. # create an empty list to store rows
  7. rows = []
  8. # open the CSV file
  9. book = xlrd.open_workbook(file_name)
  10. # get the frist sheet
  11. sheet = book.sheet_by_index(0)
  12. # iterate through the sheet and get data from rows in list
  13. for row_idx in range(1, sheet.nrows): #iterate 1 to maxrows
  14. rows.append(list(sheet.row_values(row_idx, 0, sheet.ncols)))
  15. return rows
  16.  
  17. @ddt
  18. class SearchEXCLEDDT(unittest.TestCase):
  19. def setUp(self):
  20. self.driver = webdriver.Chrome()
  21. self.driver.implicitly_wait(30)
  22. self.driver.maximize_window()
  23. self.driver.get("https://www.baidu.com")
  24.  
  25. # get test data from specified excle spreadsheet by using the get_data funcion
  26. @data(*get_data('TestData.xlsx'))
  27. @unpack
  28. def test_search(self, search_value, expected_result):
  29. search_text = self.driver.find_element_by_id('kw')
  30. search_text.clear()
  31. search_text.send_keys(search_value)
  32.  
  33. search_button = self.driver.find_element_by_id('su')
  34. search_button.click()
  35.  
  36. tag = self.driver.find_element_by_link_text("PyPI").text
  37. self.assertEqual(expected_result, tag)
  38.  
  39. def tearDown(self):
  40. self.driver.quit()
  41.  
  42. if __name__ == '__main__':
  43. unittest.main(verbosity=2)

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

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

Python Selenium 之数据驱动测试的更多相关文章

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

    数据驱动模式的测试好处相比普通模式的测试就显而易见了吧!使用数据驱动的模式,可以根据业务分解测试数据,只需定义变量,使用外部或者自定义的数据使其参数化,从而避免了使用之前测试脚本中固定的数据.可以将测 ...

  2. Selenium WebDriver 数据驱动测试框架

    Selenium WebDriver 数据驱动测试框架,以QQ邮箱添加联系人为示例,测试框架结构如下图,详细内容请阅读吴晓华编著<Selenium WebDiver 实战宝典>: Obje ...

  3. 开源you-get项目爬虫,以及基于python+selenium的自动测试利器

    写在前面 爬虫和自动测试,对于python来说是最合适不过也是最擅长的. 开源的项目也很多,例如you-get项目https://github.com/soimort/you-get.盗链和爬虫神器. ...

  4. python selenium中如何测试360等基于chrome内核的浏览器

    转自:https://blog.csdn.net/five3/article/details/50013159 直接上代码,注意是基于chrome内核的浏览器,基于ie的请替换其中的chrome方法为 ...

  5. Python&Selenium 关键字驱动测试框架之数据文件解析

    摘要:在关键字驱动测试框架中,除了PO模式以及一些常规Action的封装外,一个很重要的内容就是读写EXCEL,在团队中如何让不会写代码的人也可以进行自动化测试? 我们可以将自动化测试用例按一定的规格 ...

  6. python selenium自动化(二)自动化注册流程

    需求:使用python selenium来自动测试一个网站注册的流程. 假设这个网站的注册流程分为三步,需要提供比较多的信息: 在这个流程里面,需要用户填入信息.在下拉菜单中选择.选择单选的radio ...

  7. python for selenium 数据驱动测试

    # -*- coding:utf-8 -*- """ 数据驱动测试,从 csv 文件中读取数据 """ from selenium impo ...

  8. Python+Selenium笔记(十二):数据驱动测试

    (一)   前言 通过使用数据驱动测试,实现对输入值和预期结果的参数化.(例如:输入数据和预期结果可以直接读取Excel文档的数据) (二)   ddt 使用ddt执行数据驱动测试,ddt库可以将测试 ...

  9. Python+Selenium+Unittest+Ddt+HTMLReport分布式数据驱动自动化测试框架结构

    1.Business:公共业务模块,如登录模块,可以把登录模块进行封装供调用 ------login_business.py from Page_Object.Common_Page.login_pa ...

随机推荐

  1. __new__ 单例

    a.实例化类 实例化一个类时 1. 创建一个对象,调用__new__方法,如果没有会调用父类的__new__方法 2. 调用__init__方法 3. 返回对象的引用 class Dog(object ...

  2. QT 设计师使用样式表添加背景

    QT create中样式表可以用来设置背景图.背景颜色.字体大小格式颜色等 1.添加背景图的话需要先添加资源文件 右击项目文件选择添加新文件,再选择QT资源文件(QT resource file)然后 ...

  3. html如何实现的

    超文本标记语言是标准通用标记语言下的一个应用,也是一种规范,一种标准,它通过标记符号来标记要显示的网页中的各个部分.网页文件本身是一种文本文件,通过在文本文件中添加标记符,可以告诉浏览器如何显示其中的 ...

  4. line-height与图片底部间隙的学习整理转述

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 看大牛张鑫旭的视屏可能会理解的更深一些,点击这里: line-height,两行文字的基线之间的距离: 基 ...

  5. 浅析java的深拷贝与浅拷贝

    (转自:http://www.cnblogs.com/chenssy/p/3308489.html) 首先来看看浅拷贝和深拷贝的定义: 浅拷贝:使用一个已知实例对新创建实例的成员变量逐个赋值,这个方式 ...

  6. volatile 到i++ 原子操作 详解

    1.可见性(Visibility) 可见性是指,当一个线程修改了某一个全局共享变量的数值,其他线程是否能够知道这个修改. 显然,在串行程序来说可见性的问题是不存在的.因为你在任何一个地方操作修改了某个 ...

  7. 实验吧_who are you?(盲注)

    who are you? 翻翻源码,抓抓包,乱试一通都没有什么结果 题目中提示有ip,立马应该联想到X-Forwarded-For 虽然知道是这个方面的题,但完全不知道从何入手,悄咪咪去翻一下wp 才 ...

  8. [HNOI 2001]软件开发

    Description 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员 ...

  9. no zuo no die

    #include <iostream> #include <cstring> #include <cstdio> using namespace std; name ...

  10. BZOJ 3938 Robot

    Description 小q有n只机器人,一开始他把机器人放在了一条数轴上,第i只机器人在ai的位置上静止,而自己站在原点.在这 之后小q会执行一些操作,他想要命令一个机器人向左或者向右移动x格.但是 ...