Python Selenium设计模式-POM_python selenium pom(1)

文章介绍了如何通过PageObjectModel(POM)解决Web自动化测试中元素管理和脚本维护的问题,强调了POM模式带来的高可读性、复用性和清晰的命名规则,以及通过实例展示了POM在百度搜索测试中的应用。
摘要由CSDN通过智能技术生成

import time

driver = webdriver.Firefox()
driver.implicitly_wait(30)

启动浏览器,访问百度

driver.get(“http://www.baidu.com”)

定位 百度搜索框,并输入selenium

driver.find_element_by_id(“kw”).send_keys(“selenium”)

定位 百度一下 按钮并单击进行搜索

driver.find_element_by_id(“su”).click()

time.sleep(5)driver.quit()


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


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


 下图为非POM和POM对比图:


 ![](https://img-blog.csdn.net/20171203193939944?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemh1c29uZ3ppeWU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)  
 


###  POM是什么


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


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


 ![](https://img-blog.csdn.net/20171203193952656?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemh1c29uZ3ppeWU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)  
 


###  POM的优势


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


###  POM实现示例


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


 ![](https://img-blog.csdn.net/20171203194003632?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvemh1c29uZ3ppeWU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)  
 



basePage.py代码如下

_*_ coding:utf-8 _*_

import sys
reload(sys)
sys.setdefaultencoding(“utf-8”)

pages基类

class Page(object):
   “”"
       Page基类,所有page都应该继承该类
   “”"
   def __init__(self, driver, base_url=u"http://www.baidu.com"):
       self.driver = driver
       self.base_url = base_url
       self.timeout = 30
   
   def find_element(self, *loc):
       return self.driver.find_element(*loc)  
 
   def input_text(self, loc, text):
       self.find_element(*loc).send_keys(text)
           
   def click(self, loc):
       self.find_element(*loc).click()
         
   def get_title(self):
       return self.driver.title





searchPage.py 代码如下

_*_ coding:utf-8 _*_

import sys
from selenium.webdriver.common.by import By
from pages.basePage import Page

reload(sys)
sys.setdefaultencoding(“utf-8”)

百度搜索page

class SearchPage(Page):
   # 元素集
   
   # 搜索输入框
   search_input = (By.ID, u’kw’)    
   # 百度一下 按钮
   search_button = (By.ID, u’su’)  
 
   def __init__(self, driver, base_url=u"http://www.baidu.com"):
       Page.init(self, driver, base_url)  
     
   def gotoBaiduHomePage(self):
       print u"打开首页: “, self.base_url
       self.driver.get(self.base_url)          
      
   def input_search_text(self, text=u"开源优测”):
       print u"输入搜索关键字: 开源优测 "
       self.input_text(self.search_input, text)  
     
   def click_search_btn(self):
       print u"点击 百度一下  按钮"
       self.click(self.search_button)





testSearchPage.py代码如下

_*_ coding:utf-8 _*_

import unittest
import sys
from selenium import webdriver
from pages.searchPage import SearchPage

reload(sys)
sys.setdefaultencoding(“utf-8”)

百度搜索测试

class TestSearchPage(unittest.TestCase):

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里无偿获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值