一. PO模型介绍
在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与面向对象的特征相同),通常PO模型可以大大提高测试用例的维护效率
优点:重用,业务和对象分离,代码结构清晰,方便代码维护
二、PO的核心要素
1.在PO模式中抽离封装集成一个BasePage类,该基类应该拥有一个只实现webdriver实例的属性
2.每一个page都继承BasePage,通过driver来管理本page中元素,将page中的操作封装成一个个方法 3.TestCase继承unittest.Testcase类,并依赖page类,从而实现相应的测试步骤
四.非PO实现
4.1 代码展示
4.2:代码分析
不同的运行脚本环境,游览器不同:驱动webdriver.Firefox()可以剥离
请求地址的变化(生产环境和测试环境):url = http://www.baidu.com可以剥离
操作元素时,常常要等待元素加载完成方可进行操作:可以把webdriver提供的find_element*方法封装,在元素操作前,先判断元素是否可以操作
实际测试场景中,可能有多个测试场景,如果每个测试场景都需要维护url,游览器驱动,元素定位等,效率会非常低
因此基于以上分析,是否可以设计一个所有测试界面(selenium本身是B/S系统开展测试)的基类,来维护公共的方法,此处定义名字为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类时,事先执行的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模式的优点
1:PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰
2:页面对象与用例分离,使得我们更好的复用对象
3:可复用的页面方法代码会变得更加优化
4:更加有效的命令方式使得我们更加清晰的知道方法所操作的UI元素
八:多个page(界面)的操作
9.1:提供一个basepage类
9.2:多个page(界面操作)
page1:在游览器中访问:qq邮箱(https://qzone.qq.com/),
page2:在page2中在表单中输入用户名和密码
page3:在主界面中点击留言板
9.3:单元测试