Python Selenium设计模式及代码实现

前言

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

一、为什么要用POM

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

from selenium import webdriver
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对比图:

二、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代码示例: 看先下代码组织结构如下:

# basePage.py代码如下
 
# _*_ coding:utf-8 _*_
 
__author__ = '苦叶子'
 
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 _*_
 
__author__ = '苦叶子'
 
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 _*_
 
__author__ = '苦叶子'
import unittest
import sys
from selenium import webdriver
from pages.searchPage import SearchPage
 
reload(sys)
sys.setdefaultencoding("utf-8")
 
# 百度搜索测试
class TestSearchPage(unittest.TestCase):
    
    def setUp(self):
        self.driver = webdriver.Ie()    
    
    def testSearch(self):
        driver = self.driver        
        # 百度网址
        url = u"http://www.baidu.com"
        # 搜索文本
        text = u"开源优测"
        # 期望验证的标题
        assert_title = u"开源优测_百度搜索"
        print assert_title
        
        search_Page = SearchPage(driver, url)  
          
        # 启动浏览器,访问百度首页
        search_Page.gotoBaiduHomePage()   
              
        # 输入 搜索词
        search_Page.input_search_text(text)
                      
        # 单击 百度一下 按钮进行搜索
        search_Page.click_search_btn()    
                         
        # 验证标题
        self.assertEqual(search_Page.get_title(), assert_title)  
                              
    def tearDown(self):
        self.driver.quit()
# 主入口程序代码如下
# _*_ coding:utf-8 _*_
__author__ = '苦叶子'
 
import unittest
import sys
from common import HTMLTestRunner
from testcase.testSearchPage
import TestSearchPage
 
 
reload(sys)
sys.setdefaultencoding("utf-8")
if __name__ == '__main__':
    testunit = unittest.TestSuite()
    testunit.addTest(TestSearchPage('testSearch'))  
 
    # 定义报告输出路径
    htmlPath = u"page_demo_Report.html"
    fp = file(htmlPath, "wb")
    
    runner = HTMLTestRunner.HTMLTestRunner(stream=fp,
           title=u"百度测试",
           description=u"测试用例结果")
    
    runner.run(testunit)
    
    fp.close()

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

python main.py

总结

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

  1. POM是selenium webdriver自动化测试实践对象库设计模式

  2. POM使得测试脚本更易于维护

  3. POM通过对象库方式进一步优化了元素、用例、数据的维护组织

作为一个软件测试的过来人,我想尽自己最大的努力,帮助每一个伙伴都能顺利找到工作。所以我整理了下面这份资源,现在免费分享给大家,有需要的小伙伴可以关注【公众号:开心螺蛳粉】自提!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。在这里插入图片描述

在这里插入图片描述

行动吧,在路上总比一直观望的要好,未来的你肯定会感谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入群:1150305204,里面有各种测试开发资料和技术可以一起交流哦。

  • 11
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,以下是一个简单的 Python Selenium PO (页面对象) 模型的代码示例: ``` from selenium import webdriver class LoginPage: def __init__(self, driver): self.driver = driver self.url = "https://www.example.com/login" self.username_input_id = "username" self.password_input_id = "password" self.login_button_id = "login_btn" def navigate(self): self.driver.get(self.url) def enter_username(self, username): self.driver.find_element_by_id(self.username_input_id).send_keys(username) def enter_password(self, password): self.driver.find_element_by_id(self.password_input_id).send_keys(password) def click_login(self): self.driver.find_element_by_id(self.login_button_id).click() if __name__ == "__main__": driver = webdriver.Firefox() login_page = LoginPage(driver) login_page.navigate() login_page.enter_username("user123") login_page.enter_password("pass456") login_page.click_login() ``` 代码实现了一个页面对象模型,可以完成登录的流程。代码定义了一个 `LoginPage` 类,该类提供了登录页面上的元素的定位和操作,如输入用户名、输入密码、点击登录按钮等。 ### 回答2: Python Selenium可以通过使用Page Object模式(PO模式)来更好地组织和管理测试代码。 Page Object模式是将页面对象和页面操作分开的设计模式。具体实现步骤如下: 1. 首先,需要将页面对象定义为Python类。每个页面对象可以包含页面的元素定位和相关操作的方法。 例如,假设有一个登录页面,可以创建一个名为LoginPage的类,包含用户名输入框、密码输入框和登录按钮的元素定位和相关操作的方法。具体代码可如下: ```python from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.common.by import By class LoginPage: def __init__(self, driver): self.driver = driver def enter_username(self, username): self.driver.find_element(By.ID, "username").send_keys(username) def enter_password(self, password): self.driver.find_element(By.ID, "password").send_keys(password) def click_login_button(self): self.driver.find_element(By.ID, "login-button").click() def login(self, username, password): self.enter_username(username) self.enter_password(password) self.click_login_button() def get_alert_message(self): alert = WebDriverWait(self.driver, 10).until( EC.presence_of_element_located((By.CLASS_NAME, "alert-message")) ) return alert.text ``` 2. 在测试用例中,可以通过实例化页面对象,调用其相关方法进行测试。 例如,假设要测试登录功能,可以创建一个名为LoginTest的类,包含一个测试用例方法。 ```python from selenium import webdriver class LoginTest: def setup(self): self.driver = webdriver.Chrome() self.login_page = LoginPage(self.driver) def test_login_success(self): self.login_page.login("username", "password") alert_message = self.login_page.get_alert_message() assert "登录成功" in alert_message def teardown(self): self.driver.quit() if __name__ == "__main__": test = LoginTest() test.setup() test.test_login_success() test.teardown() ``` 通过以上步骤,将页面对象和页面操作分离开,可以提高代码的可维护性和复用性。同时,也可以更好地管理和组织自动化测试代码

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值