Web自动化测试(Selenium)PO 模型详解

本文介绍了Selenium自动化测试中的PageObject模式,包括其优点如业务和对象分离、代码结构清晰。详细讲解了BasePage的设计和实现,以及如何通过继承和封装提高测试用例的维护效率。最后提到提供的免费软件测试视频教程资源。
摘要由CSDN通过智能技术生成

🍅 视频学习:文末有免费的配套视频可观看

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快

1、PO 模型介绍

在自动化中,Selenium 自动化测试中有一个名字经常被提及 PageObject (思想与面向对象的特征相同),通常PO 模型可以大大提高测试用例的维护效率。

优点:业务和对象分离,代码结构清晰,方便维护

2、PageObject 设计模式

3、PO 的核心要素

1. 在 PO 模式中抽离封装集成一个 BasePage 类,该基类应该拥有一个只实现 webdriver 实例的属性

2. 每一个page 都继承BasePage,通过 driver 来管理 page 中元素,将 page 中的操作封装成一个个方法

3. TestCase 继承 unittest.TestCase类,并依赖page类,从而实现相应的测试步骤

4、非PO 实现

4.1 代码展示

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("12306")
sleep(1)
driver.find_element_by_id("su").click()
sleep(2)
driver.quit()

4.2 代码分析

不同的运行脚本环境,浏览器不同,驱动 webdriver.Firefox() 可以剥离

请求地址的变化(生产环境和测试环境):url = http://www.baidu.com可以剥离

操作元素时,常常要等待元素加载完成方可进行操作:可以把webdriver提供的find_element*方法封装,在元素操作前,先判断元素是否可以操作

实际测试场景中,可能有多个测试场景,如果每个测试场景都需要维护url,游览器驱动,元素定位等,效率会非常低

因此基于以上分析,是否可以设计一个所有测试界面(selenium本身是B/S系统开展测试)的基类,来维护公共的方法,此处定义名字为BasePage.py,用于存放页面公共方法及webdriver原有方法二次封装等。

5、PO 实现

5.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,url):
        self.driver = driver
        self.base_url = url
    # 进入网址
    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()

5.2 实现 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,url):
        BasePage.__init__(self,driver,url)
     #进入百度
    def open_baidu(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")

5.3 实现 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()

6、总结

PO设计模式中的BasePage基类对应案例中的BasePage.py文件

PO模式中的pages中的案例显示Search.py

PO模式设计中TestCase对应案例中的TestCase.py

7、PO 模式的特点

1.PO提供了一种业务流程与页面元素操作分离的模式,这使得测试代码变得更加清晰

2.页面对象与用例分离,使得我们更好的复用对象

3.可复用的页面方法代码会变得更加优化

4.更加有效的命令方式使得我们更加清晰的知道方法所操作的UI元素

同时,在这我为大家准备了一份软件测试视频教程(含面试、接口、自动化、性能测试等),就在下方,需要的可以直接去观看,也可以直接【点击文末小卡片免费领取资料文档】

花了2万多买的自动化测试全套教程,现在分享给大家,入门到精通,全程干货无废话(软件测试全栈教程))

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值