51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 965|回复: 1
打印 上一主题 下一主题

Python Selenium设计模式及代码实现

[复制链接]
  • TA的每日心情
    无聊
    11 小时前
  • 签到天数: 1043 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-7-14 10:07:39 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    前言
      本文就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)driver.quit()
    复制代码
    从上述代码来看,我们所能做的就是定位到元素,然后进行键盘输入或鼠标动作。就这个小程序而已,维护起来看起来是很容易的。但随着时间的迁移,测试套件将持续的增长。脚本也将变得越来越臃肿庞大。如果变成我们需要维护10个页面,100个页面,甚至1000个呢?那页面元素的任何改变都会让我们的脚本维护变得繁琐复杂,而且变得耗时易出错。
      那怎么解决呢? 在自动化测试中,引入了Page Object Model(POM):页面对象模式来解决,POM能让我们的测试代码变得可读性更好,高可维护性,高复用性。
      下图为非POM和POM对比图:

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

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

    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.      
    17.       def find_element(self, *loc):
    18.           return self.driver.find_element(*loc)  
    19.   
    20.       def input_text(self, loc, text):
    21.           self.find_element(*loc).send_keys(text)
    22.               
    23.       def click(self, loc):
    24.           self.find_element(*loc).click()
    25.            
    26.       def get_title(self):
    27.           return self.driver.title
    28.   # searchPage.py 代码如下
    29.   # _*_ coding:utf-8 _*_
    30.   __author__ = '苦叶子'
    31.   import sys
    32.   from selenium.webdriver.common.by import By
    33.   from pages.basePage import Page
    34.   reload(sys)
    35.   sys.setdefaultencoding("utf-8")
    36.   # 百度搜索page
    37.   class SearchPage(Page):
    38.       # 元素集
    39.      
    40.       # 搜索输入框
    41.       search_input = (By.ID, u'kw')   
    42.       # 百度一下 按钮
    43.       search_button = (By.ID, u'su')  
    44.     
    45.       def __init__(self, driver, base_url=u"http://www.baidu.com"):
    46.           Page.__init__(self, driver, base_url)  
    47.        
    48.       def gotoBaiduHomePage(self):
    49.           print u"打开首页: ", self.base_url
    50.           self.driver.get(self.base_url)         
    51.         
    52.       def input_search_text(self, text=u"开源优测"):
    53.           print u"输入搜索关键字:开源优测 "
    54.           self.input_text(self.search_input, text)  
    55.        
    56.       def click_search_btn(self):
    57.           print u"点击 百度一下  按钮"
    58.           self.click(self.search_button)
    59.   # testSearchPage.py代码如下
    60.   # _*_ coding:utf-8 _*_
    61.   __author__ = '苦叶子'
    62.   import unittest
    63.   import sys
    64.   from selenium import webdriver
    65.   from pages.searchPage import SearchPage
    66.   reload(sys)
    67.   sys.setdefaultencoding("utf-8")
    68.   # 百度搜索测试
    69.   class TestSearchPage(unittest.TestCase):
    70.      
    71.       def setUp(self):
    72.           self.driver = webdriver.Ie()   
    73.      
    74.       def testSearch(self):
    75.           driver = self.driver        
    76.           # 百度网址
    77.           url = u"http://www.baidu.com"
    78.           # 搜索文本
    79.           text = u"开源优测"
    80.           # 期望验证的标题
    81.           assert_title = u"开源优测_百度搜索"
    82.           print assert_title
    83.           
    84.           search_Page = SearchPage(driver, url)  
    85.            
    86.           # 启动浏览器,访问百度首页
    87.           search_Page.gotoBaiduHomePage()   
    88.                 
    89.           # 输入 搜索词
    90.           search_Page.input_search_text(text)
    91.                        
    92.           # 单击 百度一下 按钮进行搜索
    93.           search_Page.click_search_btn()   
    94.                           
    95.           # 验证标题
    96.           self.assertEqual(search_Page.get_title(), assert_title)  
    97.                                 
    98.       def tearDown(self):
    99.           self.driver.quit()
    100.   # 主入口程序代码如下
    101.   # _*_ coding:utf-8 _*_
    102.   __author__ = '苦叶子'
    103.   import unittest
    104.   import sys
    105.   from common import HTMLTestRunner
    106.   from testcase.testSearchPage
    107.   import TestSearchPage
    108.   reload(sys)
    109.   sys.setdefaultencoding("utf-8")
    110.   if __name__ == '__main__':
    111.       testunit = unittest.TestSuite()
    112.       testunit.addTest(TestSearchPage('testSearch'))  
    113.   
    114.       # 定义报告输出路径
    115.       htmlPath = u"page_demo_Report.html"
    116.       fp = file(htmlPath, "wb")
    117.      
    118.       runner = HTMLTestRunner.HTMLTestRunner(stream=fp,
    119.              title=u"百度测试",
    120.              description=u"测试用例结果")
    121.      
    122.       runner.run(testunit)
    123.      
    124.       fp.close()
    复制代码
    按照如图所示组织代码结构,输入如上代码,执行以下命令运行,会在当前目录生成测试报告:
    1.   python main.py
    复制代码





    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    该用户从未签到

    2#
    发表于 2022-11-10 17:24:55 | 只看该作者
    感谢分享,这么好的帖子为啥没有人顶呢
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-11 20:19 , Processed in 0.067066 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表