前言

本文就python selenium自动化测试实践中所需要的POM设计模式进行分享,以便大家在实践中对POM的特点、应用场景和核心思想有一定的理解和掌握。

为什么要用POM

基于python selenium2开始UI级自动化测试并不是多么艰巨的任务。只需要定位到元素,执行对应的操作即可。下面我们看一下这个简单的脚本实现百度搜索。

  1. from selenium import webdriver
  2. import time
  3. driver = webdriver.Firefox()
  4. driver.implicitly_wait(30)
  5. # 启动浏览器,访问百度
  6. driver.get("http://www.baidu.com")
  7. # 定位 百度搜索框,并输入selenium
  8. driver.find_element_by_id("kw").send_keys("selenium")
  9. # 定位 百度一下 按钮并单击进行搜索
  10. driver.find_element_by_id("su").click()
  11. time.sleep(5)
  12. driver.quit()

从上述代码来看,我们所能做的就是定位到元素,然后进行键盘输入或鼠标动作。就这个小程序而已,维护起来看起来是很容易的。但随着时间的迁移,测试套件将持续的增长。脚本也将变得越来越臃肿庞大。如果变成我们需要维护10个页面,100个页面,甚至1000个呢?那页面元素的任何改变都会让我们的脚本维护变得繁琐复杂,而且变得耗时易出错。

那怎么解决呢?
在自动化测试中,引入了Page Object Model(POM):页面对象模式来解决,POM能让我们的测试代码变得可读性更好,高可维护性,高复用性。

下图为非POM和POM对比图:

pom.png

POM是什么

  • 页面对象模型(POM)是一种设计模式,用来管理维护一组web元素集的对象库
  • 在POM下,应用程序的每一个页面都有一个对应的page class
  • 每一个page class维护着该web页的元素集和操作这些元素的方法
  • page class中的方法命名最好根据其对应的业务场景进行,例如通常登录后我们需要等待几秒中,我们可以这样命名该方法: waitingForLoginSuccess().

下面我们看看POM的代码目录组织示例:

pages_dir.png

POM的优势

  1. POM提供了一种在UI层操作、业务流程与验证分离的模式,这使得测试代码变得更加清晰和高可读性
  2. 对象库与用例分离,使得我们更好的复用对象,甚至能与不同的工具进行深度结合应用
  3. 可复用的页面方法代码会变得更加优化
  4. 更加有效的命名方式使得我们更加清晰的知道方法所操作的UI元素。例如我们要回到首页,方法名命名为: gotoHomePage(),通过方法名即可清晰的知道具体的功能实现。

    POM实现示例

    下面我们看下使用POM百度搜索 POM代码示例:
    看先下代码组织结构如下:

    page_demo_dir.png
  1. # basePage.py代码如下
  2. # _*_ coding:utf-8 _*_
  3. __author__ = '苦叶子'
  4. import sys
  5. reload(sys)
  6. sys.setdefaultencoding("utf-8")
  7. # pages基类
  8. class Page(object):
  9. """
  10. Page基类,所有page都应该继承该类
  11. """
  12. def __init__(self, driver, base_url=u"http://www.baidu.com"):
  13. self.driver = driver
  14. self.base_url = base_url
  15. self.timeout = 30
  16. def find_element(self, *loc):
  17. return self.driver.find_element(*loc)
  18. def input_text(self, loc, text):
  19. self.find_element(*loc).send_keys(text)
  20. def click(self, loc):
  21. self.find_element(*loc).click()
  22. def get_title(self):
  23. return self.driver.title
  1. # searchPage.py 代码如下
  2. # _*_ coding:utf-8 _*_
  3. __author__ = '苦叶子'
  4. import sys
  5. from selenium.webdriver.common.by import By
  6. from pages.basePage import Page
  7. reload(sys)
  8. sys.setdefaultencoding("utf-8")
  9. # 百度搜索page
  10. class SearchPage(Page):
  11. # 元素集
  12. # 搜索输入框
  13. search_input = (By.ID, u'kw')
  14. # 百度一下 按钮
  15. search_button = (By.ID, u'su')
  16. def __init__(self, driver, base_url=u"http://www.baidu.com"):
  17. Page.__init__(self, driver, base_url)
  18. def gotoBaiduHomePage(self):
  19. print u"打开首页: ", self.base_url
  20. self.driver.get(self.base_url)
  21. def input_search_text(self, text=u"开源优测"):
  22. print u"输入搜索关键字: 开源优测 "
  23. self.input_text(self.search_input, text)
  24. def click_search_btn(self):
  25. print u"点击 百度一下 按钮"
  26. self.click(self.search_button)
  1. # testSearchPage.py代码如下
  2. # _*_ coding:utf-8 _*_
  3. __author__ = '苦叶子'
  4. import unittest
  5. import sys
  6. from selenium import webdriver
  7. from pages.searchPage import SearchPage
  8. reload(sys)
  9. sys.setdefaultencoding("utf-8")
  10. # 百度搜索测试
  11. class TestSearchPage(unittest.TestCase):
  12. def setUp(self):
  13. self.driver = webdriver.Ie()
  14. def testSearch(self):
  15. driver = self.driver
  16. # 百度网址
  17. url = u"http://www.baidu.com"
  18. # 搜索文本
  19. text = u"开源优测"
  20. # 期望验证的标题
  21. assert_title = u"开源优测_百度搜索"
  22. print assert_title
  23. search_Page = SearchPage(driver, url)
  24. # 启动浏览器,访问百度首页
  25. search_Page.gotoBaiduHomePage()
  26. # 输入 搜索词
  27. search_Page.input_search_text(text)
  28. # 单击 百度一下 按钮进行搜索
  29. search_Page.click_search_btn()
  30. # 验证标题
  31. self.assertEqual(search_Page.get_title(), assert_title)
  32. def tearDown(self):
  33. self.driver.quit()
  1. # 主入口程序代码如下
  2. # _*_ coding:utf-8 _*_
  3. __author__ = '苦叶子'
  4. import unittest
  5. import sys
  6. from common import HTMLTestRunner
  7. from testcase.testSearchPage import TestSearchPage
  8. reload(sys)
  9. sys.setdefaultencoding("utf-8")
  10. if __name__ == '__main__':
  11. testunit = unittest.TestSuite()
  12. testunit.addTest(TestSearchPage('testSearch'))
  13. # 定义报告输出路径
  14. htmlPath = u"page_demo_Report.html"
  15. fp = file(htmlPath, "wb")
  16. runner = HTMLTestRunner.HTMLTestRunner(stream=fp,
  17. title=u"百度测试",
  18. description=u"测试用例结果")
  19. runner.run(testunit)
  20. fp.close()

按照如图所示组织代码结构,输入如上代码,执行以下命令运行,会在当前目录生成测试报告:

  1. python main.py

总结

最后做个总结,所有代码请手动输入,不要直接拷贝。再次对POM进行小结

  1. POM是selenium webdriver自动化测试实践对象库设计模式
  2. POM使得测试脚本更易于维护
  3. POM通过对象库方式进一步优化了元素、用例、数据的维护组织

Python Selenium设计模式-POM的更多相关文章

  1. 转 Python Selenium设计模式-POM

    前言 本文就python selenium自动化测试实践中所需要的POM设计模式进行分享,以便大家在实践中对POM的特点.应用场景和核心思想有一定的理解和掌握. 为什么要用POM 基于python s ...

  2. python selenium设计模式POM

    POM模式是什么 页面对象模型(POM)是一种设计模式,用来管理维护一组web元素集的对象库 在POM模式下,应用程序的每一个页面都有一个对的page class 每一个page class维护着该w ...

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

    整理一下python selenium自动化测试实践中使用较多的po设计模式. 为什么要用PO 基于python selenium2开始开始ui自动化测试脚本的编写不是多么艰巨的任务.只需要定位到元素 ...

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

    前言 之前的系列博客,陆续学习整理了自动化测试环境的搭建.IE和Chrome浏览器驱动的配置.selenium-webdriver模块封装的元素定位以及控制浏览器.处理警示框.鼠标键盘等方法的使用,这 ...

  5. python+selenium 自动化测试实战

    一.前言: 之前的文章说过, 要写一篇自动化实战的文章, 这段时间比较忙再加回家过11一直没有更新博客,今天整理一下实战项目的代码共大家学习.(注:项目是针对我们公司内部系统的测试,只能内部网络访问, ...

  6. 学霸笔记系列 - Python Selenium项目实战(一)—— 怎么去验证一个按钮是启用的(可点击)?

    Q: 使用 Python Selenium WebDriver 怎么去验证一个按钮是启用的(可点击)? A:Selenium WebDriver API 里面给出了解决方法is_enabled() 使 ...

  7. 《一头扎进》系列之Python+Selenium框架设计篇4- 价值好几K的框架,呵!这个框架有点意思啊

    1.简介 前面文章,我们实现了框架的一部分功能,包括日志类和浏览器引擎类的封装,今天我们继续封装一个基类和介绍如何实现POM.关于基类,是这样定义的:把一些常见的页面操作的selenium封装到bas ...

  8. 《一头扎进》系列之Python+Selenium框架设计篇5 - 价值好几K的框架,哎呦!这个框架还真有点料啊!!!

    1. 简介 其实,到前面这一篇文章,简单的Python+Selenium自动化测试框架就已经算实现了.接下来的主要是介绍,unittest管理脚本,如何如何加载执行脚本,再就是采用第三方插件,实现输出 ...

  9. Python+Selenium(1)- 环境搭建

    一,Selenium 简介 Selenium是目前最流行的web自动化测试工具,也常用于网络爬虫,已经更新到3以上的版本. 1,组件 它提供了以下web自动化测试组件: Selenium IDE,Fi ...

随机推荐

  1. PB程序“无法启动此程序,因为计算机中丢失PBvm90.dll。尝试重新安装该程序以解决此问题”的解决方法

    因为有计算机自考科目,要求使用PB程序做一个管理系统.昨天刚安装好了PB程序,今天使用的时候,当我打开一个PB程序时,出现了"无法启动此程序,因为计算机中丢失PBvm90.dll.尝试重新安 ...

  2. java学习笔记——IO流部分

    IO流常用的有:字符流.字节流.缓冲流.序列化.RandomAccessFile类等,以上列出的都是开发中比较常用的. 1.字节流: 字节流包含:FileInputStream/FileOutputS ...

  3. Keepalived安装与配置

      下载并解压Keepalived安装包到两台nginx所在的服务器   192.168.200.1   192.168.200.2     执行编译安装(安装目录设置为 /usr/local/kee ...

  4. Sicily 1151 魔板

    Constraints Time Limit: 1 secs, Memory Limit: 32 MB , Special Judge Description 魔板由8个大小相同方块组成,分别用涂上不 ...

  5. Linux配置JDK

    在etc/profile文件下添加 export JAVA_HOME=/root/Desktop/jdk1.7.0_79 export CLASSPATH=/root/Desktop/jdk1.7.0 ...

  6. 规范 : 过程 : login cookies sessionTimeOut

    规范 用户登入网站将得到一个cookies,如果用户有2个account,各别登入admin page 和 client page,是会得到2个cookies. 在reload page时,后台会得到 ...

  7. 一个chrome图片下载插件的开发过程

    最近在做采集,发现用chrome的插件来下载整站也是一个不错的思路,所以想开发一个下载网页(仿站)的插件,学习过程如下: 首先查看一些文档资料 学习360翻译的开发文档:http://open.se. ...

  8. javaSE复习总结

    之前匆匆忙忙学完了java,后来又接着学习ee,然而,越是想要快一点最后反而会更慢一点.因为匆忙间 我几乎什么都没学会.在后面的学习中实在非常吃力.就把javase 的视频大部分又重新看了一遍.真的收 ...

  9. 考试模块 - ERP数据流

    快速链接:人力资源知识体系索引 本主题主要列出考试中涉及到的所有表. 步骤 操作 相关表 说明 1 考试辅助资料   基础资料,见附表1 2 题库(109130) HXExmGp   3 试题 HXE ...

  10. JavaScript 基础阶段测试题

    JavaScript 基础阶段测试题,试试你能得多少分? 一.选择题1.分析下段代码输出结果是( )    var arr = [2,3,4,5,6];    var sum =0;    for(v ...