日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

cypress测试框架与selenium_selenium自动化测试框架之PO设计模式

發布時間:2023/12/15 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 cypress测试框架与selenium_selenium自动化测试框架之PO设计模式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

面向對象的特性:封裝、繼承、多態。在自動化中一樣適用,Selenium自動化測試中有一個名字常常被提及PageObject(思想與面向對象的特性相同),通過PO模式可以大大提高測試用例的維護效率。
傳統測試腳本的弊端

  • 測試腳本分離,維護成本高
  • 可擴展性差
  • 復用性低等

PageObject設計模式


PO的核心要素:

  • 在PO模式中抽象封裝成一個BasePage類,該基類應該擁有一個只實現webdriver實例的屬性。
  • 每個一個page都繼承BasePage,通過driver來管理本page中元素,將page中的操作封裝成一個個的方法。
  • TestCase繼承unittest.Testcase類,并且依賴page類,從而實現相應的測試步驟。
  • 案例
    基礎案例
    前面基礎場景選取的是baidu搜索頁面(baidu頁面簡單,不需要搭建測試環境)baidu.py

    from selenium import webdriver from time import sleepdriver = webdriver.Firefox() driver.get("http://www.baidu.com")driver.find_element_by_xpath("//input[@id='kw']").send_keys("Bela") driver.find_element_by_xpath("//input[@id='su']").click() sleep(5) driver.quit()


    將上面的腳本放在baidu.py文件中。
    分析
    通過對baidu.py腳本的分析,可以提取到:

    • 不同的運行腳本環境,瀏覽器不同:驅動webdriver.Firefox()可以剝離,
    • 請求地址的變化(生產環境與測試環境):url==http://www.baidu.com可以剝離
    • 操作元素時,常常需要等待元素加載完畢后方可進行操作:是否可以把webdriver提供的findelement* 方法封裝下,才操作元素前,先判斷元素的是否可操作。

    ===================================================

    • 實際測試場景中,可能有多個測試場景,如果每個測試場景都需要維護url、瀏覽器驅動、元素定位等,效率會非常低。
    • 因此基于對上面的分析,是否可以設計一個所有測試頁面(selenium本身是對B/S系統開展測試)的基類,來維護一些公共的方法。此處先定義個名字哦BasePage.py,用于存放頁面公共方法及webdriver原有方法二次封裝等。
      BasePage.py內容如下:
    from selenium.webdriver.support.wait import WebDriverWait from selenium import webdriver from selenium.webdriver.support import expected_conditions as ECclass BasePage(object):"""BasePage封裝所有頁面都公用的方法,例如driver, Find_Element等"""# 實例化BasePage類時,最先執行的就是__init__方法,該方法的入參,其實就是BasePage類的入參。# __init__方法不能有返回值,只能返回Nonedef __init__(self,selenium_driver,base_url):self.driver = selenium_driverself.base_url = base_url# self.pagetitle = pagetitledef on_page(self,pagetitle):return pagetitle in self.driver.titledef _open(self,url):self.driver.get(url)self.driver.maximize_window()def open(self):self._open(self.base_url,self.pagetitle)def find_element(self,*loc): #*loc任意數量的位置參數(帶單個星號參數)# return self.driver.find_element(*loc)try:WebDriverWait(self.driver,10).until(EC.visibility_of_element_located(loc))return self.driver.find_element(*loc)except:print("%s 頁面未能找到 %s 元素"%(self,loc))def script(self,src):self.driver.excute_script(src)def send_keys(self, loc, vaule, clear_first=True, click_first=True):try:loc = getattr(self, "_%s" % loc) # getattr相當于實現self.locif click_first:self.find_element(*loc).click()if clear_first:self.find_element(*loc).clear()self.find_element(*loc).send_keys(vaule)except AttributeError:print("%s 頁面中未能找到 %s 元素" % (self, loc))


    測試腳本的優化
    BasePage.py提取完畢,其中設計了BasePage類,對一些webdriver的方法進行了二次封裝。
    baidu.py基于BasePage.py進行優化(充分體現PO的設計思想,封裝、繼承)

    # 基本測試場景 # from selenium import webdriver # from time import sleep # # driver = webdriver.Firefox() # driver.get("http://www.baidu.com") # # driver.find_element_by_xpath("//input[@id='kw']").send_keys("Bela") #輸入框 # driver.find_element_by_xpath("//input[@id='su']").click() #百度一下按鈕 # # sleep(3) # driver.quit()# 優化后的測試場景 from selenium.webdriver.common.by import By from PODemo.BasePage import BasePage #假設baidu.py、BasePage.py均在PODemo.BasePage目錄下 from selenium import webdriverclass SearchPage(BasePage):# 定位元素search_loc = (By.ID,"kw")btn_loc = (By.ID,"su")def open(self):self._open(self.base_url)def search_content(self,content):BaiduContent = self.find_element(*self.search_loc)BaiduContent.send_keys(content)def btn_click(self):BaiduBtn = self.find_element(*self.btn_loc)BaiduBtn.click()


    PageObject總結

  • PO設計模式中的BasePage基類對應案例中的BasePage.py文件。
  • PO模式中的page1或pageN對應案例中的Search.py
  • PO設計模式中TestCase對應案例中的TestCase.py
  • 總結

    以上是生活随笔為你收集整理的cypress测试框架与selenium_selenium自动化测试框架之PO设计模式的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。