selenium自动化测试框架之PO设计模式

面向对象的特性:封装、继承、多态。在自动化中一样适用,Selenium自动化测试中有一个名字常常被提及PageObject(思想与面向对象的特性相同),通过PO模式可以大大提高测试用例的维护效率。

##传统测试脚本的弊端

  • 测试脚本分离,维护成本高
  • 可扩展性差
  • 复用性低等

    PageObject设计模式

PO的核心要素:

  1. 在PO模式中抽象封装成一个BasePage类,该基类应该拥有一个只实现webdriver实例的属性。
  2. 每个一个page都继承BasePage,通过driver来管理本page中元素,将page中的操作封装成一个个的方法。
  3. TestCase继承unittest.Testcase类,并且依赖page类,从而实现相应的测试步骤。

    案例

    基础案例

    前面基础场景选取的是baidu搜索页面(baidu页面简单,不需要搭建测试环境)baidu.py

from selenium import webdriver
from time import sleep

driver = webdriver.Firefox()
driver.get("http://www.baidu.com")

driver.find_element_by_xpath("//input[@id=‘kw‘]").send_keys("Bela")
driver.find_element_by_xpath("//input[@id=‘su‘]").click()
sleep(5)
driver.quit()

将上面的脚本放在baidu.py文件中。

分析

通过对baidu.py脚本的分析,可以提取到:

  • 不同的运行脚本环境,浏览器不同:驱动webdriver.Firefox()可以剥离,
  • 请求地址的变化(生产环境与测试环境):url==http://www.baidu.com可以剥离
  • 操作元素时,常常需要等待元素加载完毕后方可进行操作:是否可以把webdriver提供的findelement* 方法封装下,才操作元素前,先判断元素的是否可操作。

===================================================

  • 实际测试场景中,可能有多个测试场景,如果每个测试场景都需要维护url、浏览器驱动、元素定位等,效率会非常低。
  • 因此基于对上面的分析,是否可以设计一个所有测试页面(selenium本身是对B/S系统开展测试)的基类,来维护一些公共的方法。此处先定义个名字哦BasePage.py,用于存放页面公共方法及webdriver原有方法二次封装等。
    BasePage.py内容如下:
from selenium.webdriver.support.wait import WebDriverWait
from selenium import  webdriver
from selenium.webdriver.support import expected_conditions as EC

class BasePage(object):
    """
    BasePage封装所有页面都公用的方法,例如driver, Find_Element等
    """
    # 实例化BasePage类时,最先执行的就是__init__方法,该方法的入参,其实就是BasePage类的入参。
    # __init__方法不能有返回值,只能返回None

    def __init__(self,selenium_driver,base_url):
        self.driver = selenium_driver
        self.base_url = base_url
        # self.pagetitle = pagetitle

    def on_page(self,pagetitle):
        return pagetitle in self.driver.title

    def _open(self,url):
        self.driver.get(url)
        self.driver.maximize_window()

    def open(self):
        self._open(self.base_url,self.pagetitle)

    def find_element(self,*loc):  #*loc任意数量的位置参数(带单个星号参数)
        # return self.driver.find_element(*loc)
        try:
            WebDriverWait(self.driver,10).until(EC.visibility_of_element_located(loc))
            return self.driver.find_element(*loc)
        except:

            print("%s 页面未能找到 %s 元素"%(self,loc))

    def script(self,src):
        self.driver.excute_script(src)

    def send_keys(self, loc, vaule, clear_first=True, click_first=True):
        try:
            loc = getattr(self, "_%s" % loc)  # getattr相当于实现self.loc
            if click_first:
                self.find_element(*loc).click()
            if clear_first:
                self.find_element(*loc).clear()
                self.find_element(*loc).send_keys(vaule)
        except AttributeError:
            print("%s 页面中未能找到 %s 元素" % (self, loc))

测试脚本的优化

BasePage.py提取完毕,其中设计了BasePage类,对一些webdriver的方法进行了二次封装。

baidu.py基于BasePage.py进行优化(充分体现PO的设计思想,封装、继承)

# 基本测试场景
# from selenium import  webdriver
# from time import sleep
#
# driver = webdriver.Firefox()
# driver.get("http://www.baidu.com")
#
# driver.find_element_by_xpath("//input[@id=‘kw‘]").send_keys("Bela") #输入框
# driver.find_element_by_xpath("//input[@id=‘su‘]").click() #百度一下按钮
#
# sleep(3)
# driver.quit()

# 优化后的测试场景
from selenium.webdriver.common.by import By
from PODemo.BasePage import BasePage  #假设baidu.py、BasePage.py均在PODemo.BasePage目录下
from selenium import webdriver

class SearchPage(BasePage):

    # 定位元素
    search_loc = (By.ID,"kw")
    btn_loc = (By.ID,"su")

    def open(self):
        self._open(self.base_url)

    def search_content(self,content):
        BaiduContent = self.find_element(*self.search_loc)
        BaiduContent.send_keys(content)

    def btn_click(self):
        BaiduBtn = self.find_element(*self.btn_loc)
        BaiduBtn.click()

PageObject总结

  1. PO设计模式中的BasePage基类对应案例中的BasePage.py文件。
  2. PO模式中的page1或pageN对应案例中的Search.py
  3. PO设计模式中TestCase对应案例中的TestCase.py

    如果你想系统学习,打个广告吧

    推广下我的博客专栏,目前选定了一个主题《从零学Selenium自动化测试框架》,让我们从代码撸起,一步步实现Web自动化测试框架

该专题会从零带你搭建一个可用的自动化测试框架(基于python+selenium)

前提:你要掌握了python与selenium基础哦。要不你看不懂的。

原文地址:http://blog.51cto.com/starpoint/2285046

时间: 2024-08-15 05:12:10

selenium自动化测试框架之PO设计模式的相关文章

Selenium自动化测试框架的搭建

说 起自动化测试,我想大家都会有个疑问,要不要做自动化测试? 自动化测试给我们带来的收益是否会超出在建设时所投入的成本,这个嘛别说是我,即便是高手也很难回答,自动化测试的初衷是美好的,而测试工程师往往在实现 过程中花费了很多成本.精力,而最终以失败告终. 失败的原因会很多,我总结几项: 1.   太过依赖测试工具,高估了工具的力量,最终会以失望告终. 2.    项目紧急的情况,为了规避那些多余的环节,干脆人工测试,结果整个链路中断. 3.    研发和测试人员不能很好的交互,如果这两个角色之间

简易selenium自动化测试框架(Python)

最近空闲时间在探索Selenium的自动化测试,简单的写了一个小框架来测试公司的一个web产品.该框架包括以下模块: 1. Test case编写模式(page模式,参考之前的博文http://www.cnblogs.com/AlwinXu/p/5537955.html) 2. Test case的管理及执行 (主要是用nose) 该模块借助了一个外部txt文件来记录测试用例,每个用例为自身的文件名,如果不需要在本次执行,只需在文件名前添加一个"#"标识符就可以跳过该用例的执行. 3.

Selenium自动化测试框架-01

1.Selenium简介 Selenium是一款适用于Web应用程序的便携式软件测试框架,通过模拟浏览器执行操作的工具. Selenium为编写测试提供了一个回放工具,无需学习测试脚本语言.它还提供了一种测试领域特定的语言,用于编写包括C#,Groovy,Java,Perl,PHP,Python,Ruby和Scala等多种流行编程语言的测试. Selenium官网地址:https://www.seleniumhq.org/ 2.自动化测试那点事 2.1 自动化测试目标 提高测试人员的工作成就感,

Python3+Selenium2完整的自动化测试实现之旅(五):自动化测试框架、Python面向对象以及POM设计模型简介

前言 之前的系列博客,陆续学习整理了自动化测试环境的搭建.IE和Chrome浏览器驱动的配置.selenium-webdriver模块封装的元素定位以及控制浏览器.处理警示框.鼠标键盘等方法的使用,这些内容还需要后续多加练习掌握,以达到灵活运用的程度.but,这仅仅只是开始,说明咱们能够使用selenium框架下的webdriver写出一个个测试用例脚本,也仅仅写给自己看看,如果需要写100条.1000条测试脚本,并能够高效快速的编写完成并批量执行,且要看到完整的执行结果,失败多少,成功多少,等

Python3-Selenium自动化测试框架(三)之xpath元素定位

Selenium自动化测试框架(三)之xpath元素定位 xpath元素定位 节点(Node) 在 XPath 中,有七种类型的节点:元素.属性.文本.命名空间.处理指令.注释以及文档节点(或称为根节点). 选取节点 XPath 使用路径表达式来选取 XML 文档中的节点或节点集.节点是通过沿着路径 (path) 或者步 (steps) 来选取的. 谓语(Predicates) 谓语用来查找某个特定的节点或者包含某个指定的值的节点. 谓语被嵌在方括号中. 路径表达式: 表达式 描述 / 从根节点

Python3-Selenium自动化测试框架(四)之css元素定位

Selenium自动化测试框架(四)之css元素定位 一.css元素定位 CSS可以通过元素的id.class.标签(input)这三个常规属性直接定位到 id-->> # class-->> . 1.通过id进行定位 input#kw #kw 2.通过class进行定位 input.s_ipt .s_ipt 3.子类定位">":通过先定位父类(self),再定位self下的子类 #s_kw_wrap>#kw 4.同级定位"+":

Python3-Selenium自动化测试框架(六)之窗口切换、等待

Selenium自动化测试框架(六)之窗口切换.等待 窗口切换有三种: 1.Windows切换 2.iframe切换 3.alert切换 一.Windows切换 获取所有窗口的句柄 handles = driver.window_handles 获取当前窗口的句柄 handle = driver.current_window_handle 通过所有窗口的句柄索引来进行窗口切换 driver.switch_to.window(driver.window_handles[-1]) 窗口等待 等待新窗

基于Python Selenium Unittest PO设计模式详解

本文章会讲述以下几个内容: 1.什么是PO设计模式(Page Object Model) 2.为什么要使用PO设计模式 3.使用PO设计模式要点 4.PO设计模式实例 1.什么是PO设计模式 (Page Object Model) 一种在测试自动化中变得流行的设计模式,使得自动化测试脚本的减少代码重复.更易读.减少维护成本. 一般PO设计模式有三层 第一层: 对Selenium 进行二次封装,定义一个所有页面都继承的 BasePage , 封装 Selenium 基本方法 例如:元素定位,元素等

Python Selenium设计模式 - PO设计模式

整理一下python selenium自动化测试实践中使用较多的po设计模式. 为什么要用PO 基于python selenium2开始开始ui自动化测试脚本的编写不是多么艰巨的任务.只需要定位到元素,执行对应元素的操作即可. 下面我们看一下这个简单的脚本实现百度搜索. 从上述代码来看,我们所能做的就是元素的定位,然后进行键盘输入或鼠标动作.就这个小程序而已,维护起来看起来是很容易的. 但随着时间的迁移,测试套件将持续的增长.脚本也将变的越来越多.如果我们需要维护10个页面,100个页面,甚至1