zoukankan      html  css  js  c++  java
  • splinter python浏览器自动化操作,模拟浏览器的行为

    Splinter可以非常棒的模拟浏览器的行为,Splinter提供了丰富的API,可以获取页面的信息判断当前的行为所产生的结果
     
    最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有不少介绍,例如使用pamie,但是只是支持IE,而且项目也较久没有更新了。还 有就是利用selenium,可支持多种浏览器。网上资料比较多。经过比较,我选择了Splinter模块,因为利用Splinter开发浏览器自动化操 作,编写代码比较简单。
    一、Splinter的安装
    Splinter的使用必修依靠Cython、lxml、selenium这三个软件。所以,安装前请提前安装
    Cython、lxml、selenium。以下给出链接地址:
    1)http://download.csdn.net/detail/feisan/4301293
    2)http://code.google.com/p/pythonxy/wiki/AdditionalPlugins#Installation_no
    3)http://pypi.python.org/pypi/selenium/2.25.0#downloads
    4)http://splinter.cobrateam.info/

    二、Splinter的使用
      这里,我给出自动登录126邮箱的案例。难点是要找到页面的账户、密码、登录的页面元素,这里需要查看126邮箱登录页面的源码,才能找到相关控件的id.
      例如:输入密码,密码的文本控件id是pwdInput.可以使用browser.find_by_id()方法定位到密码的文本框,
    接着使用fill()方法,填写密码。至于模拟点击按钮,也是要先找到按钮控件的id,然后使用click()方法。
    由于代码较简单,我就只在代码中给出注解说明工作原理。
    (测试环境win7+python2.7.3+firefox)

    1)登录截图
    Python实现浏览器自动化操作

    2)代码
    ----------------------------------------
    #coding=utf-8
    import time
    from splinter import Browser

    def splinter(url):
        browser = Browser()
        #login 126 email websize
        browser.visit(url)
        #wait web element loading
        time.sleep(5)
        #fill in account and password
        browser.find_by_id('idInput').fill('xxxxxx')
        browser.find_by_id('pwdInput').fill('xxxxx')
        #click the button of login
        browser.find_by_id('loginBtn').click()
        time.sleep(8)
        #close the window of brower
        browser.quit()

    if __name__ == '__main__':
        websize3 ='http://www.126.com'
        splinter(websize3)
    -------------------------------------------
     
     
     

    通常对于一个稍具规模的系统,一些新的改动势必会带来一些额外的功能回归测试工作,而这个工作是非常繁杂的,人肉的方式一次又一次的重复将会非常的枯燥乏味。

             而我们所希望的,是一种自动化回归脚本的方式,可以重复性的回归现有功能,并给出回归测试报告。

             Python的世界有一个开源框架Splinter,可以非常棒的模拟浏览器的行为(从某种意义上也可以说是人的访问点击行为)。Splinter提供了丰富的API,可以获取页面的信息,以判断当前的行为所产生的结果

    最简单的例子

    browser = Browser(‘firefox’) 模拟一个浏览器

    browser.visit(‘http://waptest.taobao.com/login/login.htm’) 访问指定URL

    browser.fill('TPL_username',’test_04’) 填充表单用户名

    browser.fill('TPL_password',’taobao1234’) 填充表单密码

    browser.find_by_value('登录').first.click()表单提交

    运行代码,splinter会打开你所指定的浏览器然后进行各种操作,像放电影一样的根据你的代码逻辑在你面前一步一步执行。

             举个例子,现在我们要回归登录功能,以前我们从未开发过这样的脚本,所以现在我们首先要开发一个用于模拟登录行为的脚本。

    如下面代码(其实是非常简短的一个代码):

    1. #!/user/bin/python  
    2. # -*- coding: utf8 -*-  
    3.   
    4. import sys  
    5. import re  
    6. from splinter.browser import Browser  
    7.   
    8. #####################################################  
    9. # global instance  
    10. CLOASE_AFTER_TEST = False  
    11. GBK = "gbk"  
    12. UTF8 = "utf8"  
    13.   
    14. #####################################################  
    15. # encoding for console  
    16. reload(sys)  
    17. sys.setdefaultencoding(UTF8)  
    18.   
    19. #####################################################  
    20. # small method  
    21. encoding = lambda x:x.encode('gbk')  
    22.   
    23. #####################################################  
    24. def output(x):  
    25.     """ 
    26.         encode and print 
    27.     """  
    28.     print encoding(x)  
    29.   
    30. def resultMsg(x):  
    31.     """ 
    32.         judge result and print, x : True or False 
    33.     """  
    34.     if x == True:  
    35.         print 'pass'  
    36.     else:  
    37.         print '[X]not pass'  
    38.     print '--------------------------'  
    39.   
    40. def checkresult(x):  
    41.     """ 
    42.         check result message, x : the error message u want 
    43.     """  
    44.     resultMsg(browser.is_text_present(x))  
    45.   
    46. def testLogin(desc, username, password, result):  
    47.     """ 
    48.         fill login form message and submit, check result message and print 
    49.     """  
    50.     output(desc)  
    51.     browser.fill('TPL_username',username.decode(UTF8))  
    52.     browser.fill('TPL_password',password.decode(UTF8))  
    53.     browser.find_by_value('登录').first.click()  
    54.     checkresult(result)  
    55.   
    56. __testUrl = 'http://waptest.taobao.com/login/login.htm?tpl_redirect_url=http%3A%2F%2Fm.taobao.com%2F'  
    57.   
    58. # chrome driver : http://code.google.com/p/selenium/wiki/ChromeDriver  
    59. # already support firefox  
    60. browser = Browser()  
    61. browser.visit(__testUrl)  
    62.   
    63. output("测试页面:"+browser.title)  
    64.   
    65. try:  
    66.     # test login  
    67.     testLogin('测试未输入用户名','','','请输入会员名')  
    68.     testLogin('测试未输入密码','qd_test_001','','请输入密码')  
    69.     testLogin('测试帐户不存在','这是一个不存在的名字哦','xxxxxxx','该账户名不存在')  
    70.     testLogin('测试成功登录','qd_test_001','taobao1234','继续登录前操作')  
    71.   
    72.     # test find password  
    73.     output("测试[找回密码]链接")  
    74.     browser.visit(__testUrl)  
    75.     backPasswordLink = browser.find_link_by_text('取回密码')  
    76.     if 1 == len(backPasswordLink):  
    77.         backPasswordLink.first.click()  
    78.         ru = re.findall(re.compile(".*(reg/gp.htm).*", re.IGNORECASE), browser.url)  
    79.         if ru is not None:  
    80.             checkresult('找回密码')  
    81.         else:  
    82.             output("测试找回密码链接失败")  
    83.   
    84. except Exception,x:  
    85.     print x  
    86.   
    87. if CLOASE_AFTER_TEST:  
    88.     browser.quit()  

    从这几句我们可以看到,我们大致要测试的几种登录情况:

    testLogin('测试未输入用户名','','','请输入会员名')

       testLogin('测试未输入密码','qd_test_001','','请输入密码')

       testLogin('测试帐户不存在','这是一个不存在的名字哦','xxxxxxx','该账户名不存在')

       testLogin('测试成功登录','qd_test_001','taobao1234','继续登录前操作')

    跑一下脚本,可以得到结果:

    --------------------------------------------------------------------------

    测试页面:用户登录 - 手机淘宝网

    测试未输入用户名

    pass

    --------------------------

    测试未输入密码

    pass

    --------------------------

    测试帐户不存在

    pass

    --------------------------

    测试成功登录

    pass

    --------------------------

    测试[找回密码]链接

    pass

    -------------------------------------------------------------------------

    这里的输出是我们代码控制的,你也可以将结果保存到文件中发送到某个监控系统或者邮箱。

    首次开发完自动化回归脚本后,以后的功能调整,我们就不再需要人肉去操作,跑一下脚本,就可以得到结果。

    附:

    Splinter 快速介绍

    官方网站:http://splinter.cobrateam.info/

    官方介绍:

    Splinter is an open source tool for testingweb applications using Python. It lets you automate browser actions, such asvisiting URLs and interacting with their items

    特性:

    1、  可以模拟浏览器行为,访问指定的URL,并且可以指定不同的浏览器类型。比如firefox或者chrome等。不同的浏览器只要在本地安装对应的驱动,就可以在代码中通过名称指定来访问。

    2、  支持cookie操作,可以很方便的添加和删除cookie;

    3、  支持模拟鼠标的动作,比如滑动到某个按钮上,焦点离开某个按钮等等,对于带有动态提示的页面,如搜索引擎的关键字输入框的动态提示,可以非常方便的测试。

    4、  支持模拟键盘的输入操作,对input等控件的输入可以模拟用户的type过程。

    5、  支持直接运行js或者调用页面的js。

    6、  支持模拟上传文件。

    7、  对radio和checkbox有专门的api支持,非常方便;

    8、  支持快速的获取页面的元素或者判断是否存在文本,用于开发判断页面提示信息是否准确非常方便。

    9、  最重要的,splinter的API非常简单,配合官方的文档学习成本几乎是0,当然你得懂一些python语法。如果你比较了解js和css,你可能会像喜欢jquery一样喜欢它;

    功能:

    Splinter执行的时候会自动打开你指定的浏览器,访问指定的URL。

    然后你所开发的模拟的任何行为,都会自动完成,你只需要坐在电脑面前,像看电影一样看着屏幕上各种动作自动完成然后收集结果即可。

    Splinter 快速介绍
    官方网站:http://splinter.cobrateam.info/
    官方介绍:
    Splinter is an open source tool for testingweb applications using Python. It lets you automate browser actions, such asvisiting URLs and interacting with their items
    特性:
    1、可以模拟浏览器行为,访问指定的URL,并且可以指定不同的浏览器类型。比如firefox或者chrome等。不同的浏览器只要在本地安装对应的驱动,就可以在代码中通过名称指定来访问。
    2、支持cookie操作,可以很方便的添加和删除cookie;
    3、支持模拟鼠标的动作,比如滑动到某个按钮上,焦点离开某个按钮等等,对于带有动态提示的页面,如搜索引擎的关键字输入框的动态提示,可以非常方便的测试。
    4、支持模拟键盘的输入操作,对input等控件的输入可以模拟用户的type过程。
    5、支持直接运行js或者调用页面的js。
    6、支持模拟上传文件。
    7、对radio和checkbox有专门的api支持,非常方便;
    8、支持快速的获取页面的元素或者判断是否存在文本,用于开发判断页面提示信息是否准确非常方便。
    9、最重要的,splinter的API非常简单,配合官方的文档学习成本几乎是0,当然你得懂一些python语法。如果你比较了解js和css,你可能会像喜欢jquery一样喜欢它;
    
    功能:
    
    Splinter执行的时候会自动打开你指定的浏览器,访问指定的URL。
    然后你所开发的模拟的任何行为,都会自动完成,你只需要坐在电脑面前,像看电影一样看着屏幕上各种动作自动完成然后收集结果即可。
    
    
    举个例子,我们要回归登录功能,首先要开发如下模拟登录行为的脚本:
    复制代码 代码如下:
    
    #!/usr/bin/py2
    # -*- coding: utf-8 -*-
    #encoding=utf-8
    
    import sys, re
    from splinter.browser import Browser 
    
    CLOASE_AFTER_TEST = False
    reload(sys)
    sys.setdefaultencoding('utf8')
    encoding = lambda x:x.encode('gbk') 
    
    def testLogin(desc, username, password, result):
        output(desc)      
        browser.fill('TPL_username',username.decode('utf8'))
        browser.fill('TPL_password',password.decode('utf8'))
        browser.find_by_value('登录').first.click()
        checkresult(result) 
    
    def output(x):
        print encoding(x) 
    
    def resultMsg(x):
        if x == True:
            print 'pass'
        else:
            print '[X]not pass'
    
    def checkresult(x):
        """  check result message, x : the error message u want  """
        resultMsg(browser.is_text_present(x)) 
    
    __testUrl = 'http://waptest.taobao.com/login/login.htm?tpl_redirect_url=http%3A%2F%2Fm.taobao.com%2F' 
    
    # chrome driver : http://code.google.com/p/selenium/wiki/ChromeDriver
    browser = Browser()  # already support firefox
    browser.visit(__testUrl)
    output("测试页面:"+browser.title) 
    
    try:
        # test login
        testLogin('测试未输入用户名','','','请输入会员名')
        testLogin('测试未输入密码','qd_test_001','','请输入密码')
        testLogin('测试帐户不存在','这是一个不存在的名字哦','xxxxxxx','该账户名不存在')
        testLogin('测试成功登录','qd_test_001','taobao1234','继续登录前操作') 
    
        # test find password
        output("测试[找回密码]链接")
        browser.visit(__testUrl)
        backPasswordLink = browser.find_link_by_text('取回密码')
        if 1 == len(backPasswordLink):
            backPasswordLink.first.click()
            ru = re.findall(re.compile(".*(reg/gp.htm).*", re.IGNORECASE), browser.url)
            if ru is not None:
                checkresult('找回密码')
            else:
                output("测试找回密码链接失败") 
    
    except Exception,x:
        print x 
    
    if CLOASE_AFTER_TEST:
        browser.quit()
     
     
     
  • 相关阅读:
    ES基础(五十五)在私有云与公有云上管理与部署 Elasticsearch 集群
    ES基础(五十四)如何对集群进行容量规划
    ES基础(五十二)Hot & Warm 架构与 Shard Filtering
    ES基础(四十九)集群内部安全通信
    ES基础(四十八)集群身份认证与用户鉴权
    kata + docker run & star
    libcontainer nsexec + unshare + syscall(SYS_setns
    docker createHooks
    mount namespace
    exec.Command("/proc/self/exe", "child")
  • 原文地址:https://www.cnblogs.com/timssd/p/4735151.html
Copyright © 2011-2022 走看看