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


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

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

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

    可以通过python自带的pip命令进行下载并安装:pip install ddt .

    一个简单的数据驱动测试

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

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

    1. import unittest
    2. from selenium import webdriver
    3. from ddt import ddt, data, unpack
    4. @ddt
    5. class SearchDDT(unittest.TestCase):
    6. '''docstring for SearchDDT'''
    7. def setUp(self):
    8. self.driver = webdriver.Chrome()
    9. self.driver.implicitly_wait(30)
    10. self.driver.maximize_window()
    11. self.driver.get("https://www.baidu.com")
    12. # specify test data using @data decorator
    13. @data(('python', 'PyPI'))
    14. @unpack
    15. def test_search(self, search_value, expected_result):
    16. search_text = self.driver.find_element_by_id('kw')
    17. search_text.clear()
    18. search_text.send_keys(search_value)
    19. search_button = self.driver.find_element_by_id('su')
    20. search_button.click()
    21. tag = self.driver.find_element_by_link_text("PyPI").text
    22. self.assertEqual(expected_result, tag)
    23. def tearDown(self):
    24. self.driver.quit()
    25. if __name__ == '__main__':
    26. unittest.main(verbosity=2)

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

    1. 现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
    2. 如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
    3. 可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
    4. 分享他们的经验,还会分享很多直播讲座和技术沙龙
    5. 可以免费学习!划重点!开源的!!!
    6. qq群号:110685036

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

    如果外部已经存在了需要的测试数据,如一个文本文件、电子表格或者数据库,那也可以用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. def get_data(file_name):
    5. # create an empty list to store rows
    6. rows = []
    7. # open the CSV file
    8. data_file = open(file_name, "r")
    9. # create a CSV Reader from CSV file
    10. reader = csv.reader(data_file)
    11. # skip the headers
    12. next(reader, None)
    13. # add rows from reader to list
    14. for row in reader:
    15. rows.append(row)
    16. return rows
    17. @ddt
    18. class SearchCSVDDT(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. # get test data from specified csv file by using the get_data funcion
    25. @data(*get_data('testdata.csv'))
    26. @unpack
    27. def test_search(self, search_value, expected_result):
    28. search_text = self.driver.find_element_by_id('kw')
    29. search_text.clear()
    30. search_text.send_keys(search_value)
    31. search_button = self.driver.find_element_by_id('su')
    32. search_button.click()
    33. tag = self.driver.find_element_by_link_text("PyPI").text
    34. self.assertEqual(expected_result, tag)
    35. def tearDown(self):
    36. self.driver.quit()
    37. if __name__ == '__main__':
    38. unittest.main(verbosity=2)

    测试执行时,@data将调用get_data()方法读取外部数据文件,并将数据逐行返回给@data。执行的结果也同上~
    如果对软件测试、接口测试、自动化测试、面试经验交流。感兴趣可以加软件测试交流:1085991341,还会有同行一起技术交流。

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

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

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

    以上就是本文的全部内容,希望对大家的学习有所帮助。有被帮助到的朋友欢迎点赞,评论。

  • 相关阅读:
    基于java的运动健康微信小程序
    @ 代码随想录算法训练营第9周(C语言)|Day63(单调栈)
    「6.18福利」精选大厂真题|笔试刷题陪伴|明天正式开屋啦 - 打卡赢价值288元丰厚奖励
    给Elasticsearch-ik分词器添加额外的分词字典
    【Python21天学习挑战赛】-爬虫(B站)程序示例
    QT day1
    【kafka】基本名词解释
    关于redisson的序列化配置
    docker+mongo主从仲裁+用户密码认证
    python文本转语音
  • 原文地址:https://blog.csdn.net/qq_43371695/article/details/134076020