一. PO模型介紹
在自動化中,Selenium自動化測試中有一個名字經常被提及PageObject(思想與面向對象的特征相同)掺出,通常PO模型可以大大提高測試用例的維護效率
優(yōu)點:重用载慈,業(yè)務和對象分離惭等,代碼結構清晰,方便代碼維護
二娃肿、PO的核心要素
1.在PO模式中抽離封裝集成一個BasePage類咕缎,該基類應該擁有一個只實現webdriver實例的屬性
2.每一個page都繼承BasePage,通過driver來管理本page中元素料扰,將page中的操作封裝成一個個方法 3.TestCase繼承unittest.Testcase類凭豪,并依賴page類,從而實現相應的測試步驟
四.非PO實現
4.1 代碼展示
4.2:代碼分析
不同的運行腳本環(huán)境晒杈,游覽器不同:驅動webdriver.Firefox()可以剝離
請求地址的變化(生產環(huán)境和測試環(huán)境):url = http://www.baidu.com可以剝離
操作元素時嫂伞,常常要等待元素加載完成方可進行操作:可以把webdriver提供的find_element*方法封裝,在元素操作前,先判斷元素是否可以操作
實際測試場景中帖努,可能有多個測試場景撰豺,如果每個測試場景都需要維護url,游覽器驅動,元素定位等,效率會非常低
因此基于以上分析,是否可以設計一個所有測試界面(selenium本身是B/S系統(tǒng)開展測試)的基類拼余,來維護公共的方法污桦,此處定義名字為BasePage.py,用于存放頁面公共方法及webdriver原有方法二次封裝等。
五.PO實現
5.1:實現BasePage
5.1.1:BasePage代碼實現
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains #鼠標操作
class BasePage():
'''BasePage封裝所有界面都公用的方法匙监。例如driver,find_element等'''
'''實例化BasePage類時凡橱,事先執(zhí)行的init方法,該方法需要傳遞參數'''
def init(self,driver):
self.driver = driver
# 進入網址
def get(self,url):
self.driver.get(url)
#元素定位,替代八大定位
def get_element(self,locator):
return self.driver.find_element(locator)
#點擊
def left_click(self,locator):
ActionChains(self.driver).double_click(self.get_element(locator)).perform()
#輸入
def send_text(self,text,locator):
self.driver.find_element(locator).send_keys(text)
#清除
def clear_text(self,locator):
self.driver.find_element(locator).clear()
#表單切換
def switch_iframe(self,locator):
self.driver.switch_to.frame(self.driver.find_element(locator))
#窗口切換
def switch_window(self,n):
self.driver.switch_to.window(self.driver.window_handles[n])
-------------------------------------------------------------------------------------------###5.2:實現SearchPage
5.2.1:SearchPage代碼實現
'''-----------------------------------------------------------------------------------------
實現步驟:(1)繼承basepage,(2)元素傳參,(3)調取方法
'''
from selenium.webdriver.common.by import By
from pomodel.Base.base_page import BasePage
class Search(BasePage):
def init(self,driver):
BasePage.init(self,driver)
#進入百度
def open_baidu(self,url):
self.get(url)
#輸入搜索內容
def input_search_content(self,text):
self.send_text(text,By.ID,"kw")
#點擊按鈕
def click_baidu_search(self):
self.left_click(By.ID,"su")
5.3:實現TestCase
5.3.1:TestCase代碼
================================================
import unittest
from selenium import webdriver
from pomodel.Pages.search_pages import Search
class BaiBu(unittest.TestCase):
def setUp(self) -> None:
self.driver = webdriver.Firefox()
self.driver.implicitly_wait(10)
def test_serach(self):
url="http://www.baidu.com"
s = Search(self.driver)
s.open_baidu(url)
s.input_search_content("jack")
s.click_baidu_search()
def tearDown(self) -> None:
self.driver.quit()
if name == 'main':
unittest.main()
====================================================
六亭姥、PO模式的優(yōu)點
1:PO提供了一種業(yè)務流程與頁面元素操作分離的模式稼钩,這使得測試代碼變得更加清晰
2:頁面對象與用例分離,使得我們更好的復用對象
3:可復用的頁面方法代碼會變得更加優(yōu)化
4:更加有效的命令方式使得我們更加清晰的知道方法所操作的UI元素
八:多個page(界面)的操作
9.1:提供一個basepage類
9.2:多個page(界面操作)
page1:在游覽器中訪問:qq郵箱(https://qzone.qq.com/),
page2:在page2中在表單中輸入用戶名和密碼
page3:在主界面中點擊留言板
9.3:單元測試