PO模型

一、PO模型介绍

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

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

二、 PageObject设计模式

三、PO的核心要素

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

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

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

四、非PO实现

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("jack")

sleep(1)

driver.find_element_by_id("su").click()

sleep(2)

driver.quit()

2.代码分析

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

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

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

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

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

五、PO实现

1.实现BasePage

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,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()

2.实现SearchPage

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,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")

3.实现TestCase

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,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()

六、组织代码

七、总结

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

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

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

八、PO模式的优点

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

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

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

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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、PO模型介绍 在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与面向对象...
    ln111阅读 275评论 0 0
  • 一、PO模型介绍在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与面向对象的...
    老友_9e40阅读 192评论 0 0
  • 一. PO模型介绍 优点:重用,业务和对象分离,代码结构清晰,方便代码维护 二、PO的核心要素 1.在PO模式中抽...
    BnAO阅读 476评论 0 0
  • 1.介绍 在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想与 面向对象的特征...
    我向星明许愿阅读 218评论 0 0
  • PO模型 一、PO模型介绍 在自动化中,Selenium自动化测试中有一个名字经常被提及PageObject(思想...
    G_eebd阅读 196评论 0 0