黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

Python Selenium 之?dāng)?shù)據(jù)驅(qū)動測試的實現(xiàn)

系統(tǒng) 2047 0

數(shù)據(jù)驅(qū)動模式的測試好處相比普通模式的測試就顯而易見了吧!使用數(shù)據(jù)驅(qū)動的模式,可以根據(jù)業(yè)務(wù)分解測試數(shù)據(jù),只需定義變量,使用外部或者自定義的數(shù)據(jù)使其參數(shù)化,從而避免了使用之前測試腳本中固定的數(shù)據(jù)。可以將測試腳本與測試數(shù)據(jù)分離,使得測試腳本在不同數(shù)據(jù)集合下高度復(fù)用。不僅可以增加復(fù)雜條件場景的測試覆蓋,還可以極大減少測試腳本的編寫與維護工作。

下面將使用Python下的數(shù)據(jù)驅(qū)動模式(ddt)庫,結(jié)合unittest庫以數(shù)據(jù)驅(qū)動模式創(chuàng)建百度搜索的測試。

ddt庫包含一組類和方法用于實現(xiàn)數(shù)據(jù)驅(qū)動測試。可以將測試中的變量進行參數(shù)化。

可以通過python自帶的pip命令進行下載并安裝:pip install ddt . 更多關(guān)于ddt的信息可以參考:

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

一個簡單的數(shù)據(jù)驅(qū)動測試

為了創(chuàng)建數(shù)據(jù)驅(qū)動測試,需要在測試類上使用@ddt裝飾符,在測試方法上使用@data裝飾符。@data裝飾符把參數(shù)當(dāng)作測試數(shù)據(jù),參數(shù)可以是單個值、列表、元組、字典。對于列表,需要用@unpack裝飾符把元組和列表解析成多個參數(shù)。

下面實現(xiàn)百度搜索測試,傳入搜索關(guān)鍵詞和期望結(jié)果,代碼如下:

            
import unittest
from selenium import webdriver
from ddt import ddt, data, unpack

@ddt
class 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兩個參數(shù)用來接收元組解析的數(shù)據(jù)。當(dāng)運行腳本時,ddt把測試數(shù)據(jù)轉(zhuǎn)換為有效的python標識符,生成名稱為更有意義的測試方法。結(jié)果如下:

Python Selenium 之?dāng)?shù)據(jù)驅(qū)動測試的實現(xiàn)_第1張圖片

使用外部數(shù)據(jù)的數(shù)據(jù)驅(qū)動測試

如果外部已經(jīng)存在了需要的測試數(shù)據(jù),如一個文本文件、電子表格或者數(shù)據(jù)庫,那也可以用ddt來直接獲取數(shù)據(jù)并傳入測試方法進行測試。

下面將借助外部的CSV(逗號分隔值)文件和EXCLE表格數(shù)據(jù)來實現(xiàn)ddt。

通過CSV獲取數(shù)據(jù)

同上在@data裝飾符使用解析外部的CSV(testdata.csv)來作為測試數(shù)據(jù)(代替之前的測試數(shù)據(jù))。其中數(shù)據(jù)如下:

Python Selenium 之?dāng)?shù)據(jù)驅(qū)動測試的實現(xiàn)_第2張圖片

接下來,先要創(chuàng)建一個get_data()方法,其中包括路徑(這里默認使用當(dāng)前路徑)、CSV文件名。調(diào)用CSV庫去讀取文件并返回一行數(shù)據(jù)。再使用@ddt及@data實現(xiàn)外部數(shù)據(jù)驅(qū)動測試百度搜索,代碼如下:

            
import csv, unittest
from selenium import webdriver
from ddt import ddt, data, unpack

def 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

@ddt
class 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)
          

測試執(zhí)行時,@data將調(diào)用get_data()方法讀取外部數(shù)據(jù)文件,并將數(shù)據(jù)逐行返回給@data。執(zhí)行的結(jié)果也同上~

通過Excel獲取數(shù)據(jù)

測試中經(jīng)常用Excle存放測試數(shù)據(jù),同上在也可以使用@data裝飾符來解析外部的CSV(testdata.csv)來作為測試數(shù)據(jù)(代替之前的測試數(shù)據(jù))。其中數(shù)據(jù)如下:

接下來,先要創(chuàng)建一個get_data()方法,其中包括路徑(這里默認使用當(dāng)前路徑)、EXCEL文件名。調(diào)用xlrd庫去讀取文件并返回數(shù)據(jù)。再使用@ddt及@data實現(xiàn)外部數(shù)據(jù)驅(qū)動測試百度搜索,代碼如下:

            
import xlrd, unittest
from selenium import webdriver
from ddt import ddt, data, unpack

def 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

@ddt
class 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文件一樣,測試執(zhí)行時,@data將調(diào)用get_data()方法讀取外部數(shù)據(jù)文件,并將數(shù)據(jù)逐行返回給@data。執(zhí)行的結(jié)果也同上~

如果想從數(shù)據(jù)庫的庫表中獲取數(shù)據(jù),同樣也需要一個get_data()方法,并且通過DB相關(guān)的庫來連接數(shù)據(jù)庫、SQL查詢來獲取測試數(shù)據(jù)。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論