PageObject是UI自动化测试项目开发实践的最佳设计模式之一,它的主要特点体现在对界面交互细节的封装上,使测试用例更加专注于业务的操作,从而提高测试用例的可维护性。

1.认识Page Object

Page Object设计模式的优点:

  • 减少代码的重复
  • 提高测试用例的可读性
  • 提高测试用例的可维护性,特别是针对UI频繁变化的项目;

Page Object应遵循以下原则进行开发:

  • Page Object应该易于使用
  • 有清晰的结构,如PageObject对应页面对象,PageModules对应页面内容
  • 只写测试内容,不写基础内容
  • 在可能的情况下放置样板代码
  • 不需要自己管理浏览器
  • 在运行时选择浏览器,而不是类级别
  • 不需要直接接触Selenium

Page Object简单实例:

  已百度搜索为例,假设我们有如下测试代码:

import unittest
from selenium import webdriver
from selenium.webdriver.common.by import By class Test(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Chrome()
self.base_url = 'http://www.baidu.com' def test_baidu_search_case1(self):
self.driver.get(self.base_url)
self.driver.find_element(By.ID, 'kw').send_keys('unittest')
self.driver.find_element(By.ID, 'su').click() def test_baidu_search_case2(self):
self.driver.get(self.base_url)
self.driver.find_element(By.ID, 'kw').send_keys('selenium')
self.driver.find_element(By.ID, 'su').click() def test_baidu_search_case3(self):
self.driver.get(self.base_url)
self.driver.find_element(By.ID, 'kw').send_keys('page object')
self.driver.find_element(By.ID, 'su').click() def tearDown(self):
self.driver.quit() if __name__ == '__main__':
unittest.main()

  这段代码最大的问题就是三条测试用例中重复使用了元素的定位和操作。这会带来一个很大的问题,当元素的定位发生变化后,例如id=kw失效了,应及时调整整个定位方法,这时就需要三条测试用例分别进行更改。假设,我们的自动化不止3条测试用例,而UI不断变化,那么就会提高自动化测试用例的维护成本。

  Page Object的设计思想上是把元素定位于元素操作进行分层,这样带来的最直接的好处就是当元素发生变化时,只需要维护page层的元素定位,而不需要关心在哪些测试用例当中使用了这些元素。在编写测试用例时,也不需要关心元素是如何定位的。

  上面代码进行优化:

from selenium.webdriver.common.by import By

class BaiduPage:
def __init__(self, driver):
self.driver = driver def search_input(self, search_key):
self.driver.find_element(By.ID, 'kw').send_keys(search_key) def search_button(self):
self.driver.find_element(By.ID, 'su').click()

  首先,创建了一个BaiduPage类,在__init__()初始化方法中接受参数driver并赋值给self.driver。然后分别封装了search_input()和search_button()方法,定位并元素操作。这里的封装只针对一个页面中可能会操作到的元素,原则上是一个元素封装成一个方法。当元素的定位方法发生改变时,只需要维护这里的方法即可。而不需要关心这个方法被那谢谢测试用例使用了。

  使用:

import unittest
from selenium import webdriver
from selenium.webdriver.common.by import By
from samples.baidu_page import BaiduPage class Test(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Chrome()
self.base_url = 'http://www.baidu.com' def test_baidu_search_case1(self):
self.driver.get(self.base_url)
bd = BaiduPage(self.driver)
bd.search_input('selenium')
bd.search_button() def test_baidu_search_case2(self):
self.driver.get(self.base_url)
bd = BaiduPage(self.driver)
bd.search_input('unittest')
bd.search_button() def test_baidu_search_case3(self):
self.driver.get(self.base_url)
bd = BaiduPage(self.driver)
bd.search_input('page object')
bd.search_button() def tearDown(self):
self.driver.quit() if __name__ == '__main__':
unittest.main()

  首先在测试中导入BaiduPage类,然后在每个测试用例中为BaiduPage类传入 驱动,这样就可以轻松地使用它封装的方法来设计具体的测试用例了。这样做的目的就是在测试用例中消除元素定位。如果你要操作百度输入框,那么只需要调用search_input()方法并传入搜索关键字即可,并不需要再重新编写定位元素。

  备注:这样的方法带来了许多好处,但是也带来了一些问题。例如,需要些更多的代码。以前一条测试用例只需要写4到5行代码即可,现在却不得不现在Page层次对每个带操作的元素进行封装,然后在到具体的测试用例的引用。

  备注:学习selenium3 自动化测试实战

初识Page Object的更多相关文章

  1. Selenium的PO模式(Page Object Model)[python版]

     Page Object Model 简称POM  普通的测试用例代码: .... #测试用例 def test_login_mail(self): driver = self.driver driv ...

  2. 使用page object模式抓取几个主要城市的pm2.5并从小到大排序后写入txt文档

    #coding=utf-8from time import sleepimport unittestfrom selenium import webdriverfrom selenium.webdri ...

  3. Selenium的PO模式(Page Object Model)|(Selenium Webdriver For Python)

            研究Selenium + python 自动化测试有近两个月了,不能说非常熟练,起码对selenium自动化的执行有了深入的认识. 从最初无结构的代码,到类的使用,方法封装,从原始函数 ...

  4. Page Object Model (Selenium, Python)

    时间 2015-06-15 00:11:56  Qxf2 blog 原文  http://qxf2.com/blog/page-object-model-selenium-python/ 主题 Sel ...

  5. 【C#|.NET】从细节出发(三) 逻辑层事务和page object模式

    一. 业务逻辑层的事务问题 如果你的程序分层清晰并且系统禁用复杂存储过程,那么在DA中的职责比较单一.程序的逻辑通过BLL调用各种不同模块的DA来实现数据操作.如果当需要不同模块在一个事务的时候,问题 ...

  6. 浅析selenium的page object模式

    selenium目前比较流行的设计模式就是page object,那么到底什么是page object呢,简单来说,就是把页面作为对象,在使用中传递页面对象,来使用页面对象中相应的成员或者方法,能更好 ...

  7. Page Object 模式编写UiAutomator脚本

    在我们学习Page Object Model之前,我们先了解一下Page Object Model(以下简称POM). 为什么要POM 用UiAutomator启动UI自动化测试不是一件困难的任务.你 ...

  8. selenium page object model

    Page Object Model (POM) & Page Factory in Selenium: Ultimate Guide 来源:http://www.guru99.com/page ...

  9. 为什么需要Page Object?

    为什么需要Page Object? Page Object(PO)是界面自动化验收测试中的一个常见模式,要和@槽神刘叫兽探讨一下PO的必要性,顾写这篇小文表达一下我的观点. PO的主要价值体现在对界面 ...

随机推荐

  1. s2h-HTTP Status 404 - No result defined for action and result input错误解决

    今天做个小项目,用的是ssh,结果在运行的时候出现HTTP Status 404 - No result defined for action and result input的错误. 首先认真检查所 ...

  2. pytorch seq2seq模型中加入teacher_forcing机制

    在循环内加的teacher forcing机制,这种为目标确定的时候,可以这样加. 目标不确定,需要在循环外加. decoder.py 中的修改 """ 实现解码器 &q ...

  3. CentOS下宝塔如何部署Django项目?

    基础环境 装好宝塔服务 宝塔里装好[Python项目管理器] 宝塔里装好[Nginx] 把Django项目代码发到服务器 把代码放到服务器上有两种方法: 方法一:服务器上安装Git,通过Git Clo ...

  4. http与web

    在看<图解http>的时候,忽然有一个想法冒出来. web与http是什么关系? http服务器与web服务器有区别?为什么用以搞混了? web的定义:它是一种基于超文本和HTTP的.全球 ...

  5. docker企业级镜像仓库Harbor管理

    Harbor概述 Harbor是由VMWare公司开源的容器镜像仓库.事实上,Harbor是在Docker Registry上进行了相应的企业级扩展,从而获得了更加广泛的应用,这些新的企业级特性包括: ...

  6. Rancher流水线配置文档

    2019独角兽企业重金招聘Python工程师标准>>> 一.概述 Rancher流水线从逻辑上可以分为两部分,即CI和CD. CI,可分化为克隆代码.代码打包.发布镜像三部分. CD ...

  7. 从「Hello World」说起

    标签: node模块 从一个简单「hello world」程序对 node.js 有个感性的认识. const http = requier ('http'); const pathname = '1 ...

  8. 手把手教你使用ADB卸载手机内置App软件

    [一.前言] 不知道你们有没有那么一段黑暗时期,刚买个手机,手机上内置一堆app,还卸载不掉,然后每天各种广告,手机一共1G的运行内存,那些流氓app还要再占走一些内存,真是让人欲哭无泪啊,后来我就学 ...

  9. 域名系统(DNS)初探

    1.定义 域名:又称网域,是由一串用点分隔的名字组成的Internet上某一台计算机或计算机组的名称(如mail.cctv.com),用于在数据传输时对计算机的定位标识(有时也指地理位置): 域名系统 ...

  10. Python库的安装与查看

    安装库:    Step1:  win+r键打开此页面,并输入cmd     Step2 :键入cmd并点击确定    Step3 :键入语句:“ pip install 库名 “ 回车即可 这样库就 ...