一、 PO模型介绍
在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与面向对象的特征相同),通常PO模型可以大大提高测试用例的维护效率
优点:重用,业务和对象分离,代码结构清晰,方便代码维护
二、 PO模型的核心要素
- 在PO模式中抽离封装集成一个BasePage类,该基类应该拥有一个只实现webdriver实例的属性
- 每一个page都继承BasePage,通过driver来管理本page中元素,将page中的操作封装成一个个方法。
- TestCase继承uniittest。Testcase类,并依赖page类,从而实现相应的测试步骤。
三、PO实现
- 实现BasePage
from selenium.webdriver.common.action_chains import ActionChains
class BasePage:
def __init__(self,driver,url):
self.driver = driver
self.url = url
# 进入网站
def get(self):
self.driver.get(self.url)
# 元素定位,代替八大定位
def get_element(self,*locator):
return self.driver.find_element(*locator)
# 点击
def left_click(self,*locator):
self.get_element(*locator).click()
# 鼠标操作
# 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
from selenium.webdriver.common.by import By
from PoBase.Base.BasePage import BasePage
class Search(BasePage):
def __init__(self,driver,url):
BasePage.__init__(self,driver,url)
# 进入百度
def open_bai(self):
self.get()
# 输入搜索内容
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,time
from selenium import webdriver
from PoBase.Pages.SearchPage import Search
class TestBaiDu(unittest.TestCase):
def setUp(self) -> None:
self.driver = webdriver.Firefox()
# self.driver = webdriver.Chrome()
self.driver.implicitly_wait(10)
def test_serach(self):
url = "https://www.baidu.com"
s = Search(self.driver,url)
s.open_bai()
s.input_search_content("歼击机")
s.click_baidu_search()
def tearDown(self) -> None:
time.sleep(10)
self.driver.quit()
四、总结
PO设计模式中的BasePage基类对应案例中的BasePage.py文件
PO模式中pages中的案例显示Search.py
PO模式设中TestCase对应案例中的TestCase.py
五、PO模式的优点
- PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变的更加清晰。
- 页面对象与用例分离,使得我们更好的复用对象。
- 可复用的页面方法代码会变得更加优化。
- 更加有效的命令方式使得我们更加清晰的知道方法所操作的UI元素。