一.po模型介紹
在自動化中锈颗,Selenium自動化測試中有一個名字經(jīng)常被提及PageObject(思想與面向?qū)ο蟮奶卣飨嗤?,通常PO模型可以大大提高測試用例的維護效率
優(yōu)點:重用余指,業(yè)務和對象分離,代碼結(jié)構(gòu)清晰,方便代碼維護
二. page object設計模式
三.po的核心要素
1.在PO模式中抽離封裝集成一個BasePage類瑰谜,該基類應該擁有一個只實現(xiàn)webdriver實例的屬性
2.每一個page都繼承BasePage,通過driver來管理本page中元素树绩,將page中的操作封裝成一個個方法
3.TestCase繼承unittest.Testcase類萨脑,并依賴page類,從而實現(xiàn)相應的測試步驟
四.非po實現(xiàn)
代碼展示
from selenium import webdriver
from time import sleep
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")
driver.find_element_by_id("kw").send_keys("jack")
sleep(1)
driver.find_element_by_id("su").click()
sleep(2)
driver.quit()
代碼分析
<meta charset="utf-8">
不同的運行腳本環(huán)境饺饭,瀏覽器不同:驅(qū)動webdriver.Firefox()可以剝離
請求地址的變化(生產(chǎn)環(huán)境和測試環(huán)境):url = http://www.baidu.com可以剝離
操作元素時渤早,常常要等待元素加載完成方可進行操作:可以把webdriver提供的find_element*方法封裝,在元素操作前砰奕,先判斷元素是否可以操作
實際測試場景中蛛芥,可能有多個測試場景,如果每個測試場景都需要維護url,瀏覽器驅(qū)動,元素定位等,效率會非常低
因此基于以上分析军援,是否可以設計一個所有測試界面(selenium本身是B/S系統(tǒng)開展測試)的基類仅淑,來維護公共的方法,此處定義名字為BasePage.py,用于存放頁面公共方法及webdriver原有方法二次封裝等胸哥。
5.po實現(xiàn)
1.實現(xiàn)Base Page
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains #鼠標操作
class BasePage():
'''BasePage封裝所有界面都公用的方法涯竟。例如driver,find_element等'''
'''實例化BasePage類時,事先執(zhí)行的__init__方法空厌,該方法需要傳遞參數(shù)'''
def __init__(self,driver,url):
self.driver = driver
self.base_url = url
# 進入網(wǎng)址
def get(self):
self.driver.get(self.base_url)
#元素定位,替代八大定位
def get_element(self,*locator):
return self.driver.find_element(*locator)
#點擊
def left_click(self,*locator):
ActionChains(self.driver).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()
SearchPage
'''
實現(xiàn)步驟:(1)繼承basepage,(2)元素傳參,(3)調(diào)取方法
'''
from selenium.webdriver.common.by import By
from pomodel.Base.base_page import BasePage
class Search(BasePage):
def __init__(self,driver,url):
BasePage.__init__(self,driver,url)
#進入百度
def open_baidu(self):
self.get()
#輸入搜索內(nèi)容
def input_search_content(self,text):
self.send_text(text,By.ID,"kw")
#點擊按鈕
def click_baidu_search(self):
self.left_click(By.ID,"su")
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,url)
s.open_baidu()
s.input_search_content("jack")
s.click_baidu_search()
def tearDown(self) -> None:
self.driver.quit()
if __name__ == '__main__':
unittest.main()
六.組織代碼
七.總結(jié)
PO設計模式中的BasePage基類對應案例中的BasePage.py文件
PO模式中的pages中的案例顯示Search.py
PO模式設計中TestCase對應案例中的TestCase.py
八.po模式的優(yōu)點
1.PO提供了一種業(yè)務流程與頁面元素操作分離的模式庐船,這使得測試代碼變得更加清晰
2.頁面對象與用例分離,使得我們更好的復用對象
可復用的頁面方法代碼會變得更加優(yōu)化
3.更加有效的命令方式使得我們更加清晰的知道方法所操作的UI元素