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)登录截图

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. import sys
  4. import re
  5. from splinter.browser import Browser
  6. #####################################################
  7. # global instance
  8. CLOASE_AFTER_TEST = False
  9. GBK = "gbk"
  10. UTF8 = "utf8"
  11. #####################################################
  12. # encoding for console
  13. reload(sys)
  14. sys.setdefaultencoding(UTF8)
  15. #####################################################
  16. # small method
  17. encoding = lambda x:x.encode('gbk')
  18. #####################################################
  19. def output(x):
  20. """
  21. encode and print
  22. """
  23. print encoding(x)
  24. def resultMsg(x):
  25. """
  26. judge result and print, x : True or False
  27. """
  28. if x == True:
  29. print 'pass'
  30. else:
  31. print '[X]not pass'
  32. print '--------------------------'
  33. def checkresult(x):
  34. """
  35. check result message, x : the error message u want
  36. """
  37. resultMsg(browser.is_text_present(x))
  38. def testLogin(desc, username, password, result):
  39. """
  40. fill login form message and submit, check result message and print
  41. """
  42. output(desc)
  43. browser.fill('TPL_username',username.decode(UTF8))
  44. browser.fill('TPL_password',password.decode(UTF8))
  45. browser.find_by_value('登录').first.click()
  46. checkresult(result)
  47. __testUrl = 'http://waptest.taobao.com/login/login.htm?tpl_redirect_url=http%3A%2F%2Fm.taobao.com%2F'
  48. # chrome driver : http://code.google.com/p/selenium/wiki/ChromeDriver
  49. # already support firefox
  50. browser = Browser()
  51. browser.visit(__testUrl)
  52. output("测试页面:"+browser.title)
  53. try:
  54. # test login
  55. testLogin('测试未输入用户名','','','请输入会员名')
  56. testLogin('测试未输入密码','qd_test_001','','请输入密码')
  57. testLogin('测试帐户不存在','这是一个不存在的名字哦','xxxxxxx','该账户名不存在')
  58. testLogin('测试成功登录','qd_test_001','taobao1234','继续登录前操作')
  59. # test find password
  60. output("测试[找回密码]链接")
  61. browser.visit(__testUrl)
  62. backPasswordLink = browser.find_link_by_text('取回密码')
  63. if 1 == len(backPasswordLink):
  64. backPasswordLink.first.click()
  65. ru = re.findall(re.compile(".*(reg/gp.htm).*", re.IGNORECASE), browser.url)
  66. if ru is not None:
  67. checkresult('找回密码')
  68. else:
  69. output("测试找回密码链接失败")
  70. except Exception,x:
  71. print x
  72. if CLOASE_AFTER_TEST:
  73. 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
特性:
、可以模拟浏览器行为,访问指定的URL,并且可以指定不同的浏览器类型。比如firefox或者chrome等。不同的浏览器只要在本地安装对应的驱动,就可以在代码中通过名称指定来访问。
、支持cookie操作,可以很方便的添加和删除cookie;
、支持模拟鼠标的动作,比如滑动到某个按钮上,焦点离开某个按钮等等,对于带有动态提示的页面,如搜索引擎的关键字输入框的动态提示,可以非常方便的测试。
、支持模拟键盘的输入操作,对input等控件的输入可以模拟用户的type过程。
、支持直接运行js或者调用页面的js。
、支持模拟上传文件。
、对radio和checkbox有专门的api支持,非常方便;
、支持快速的获取页面的元素或者判断是否存在文本,用于开发判断页面提示信息是否准确非常方便。
、最重要的,splinter的API非常简单,配合官方的文档学习成本几乎是0,当然你得懂一些python语法。如果你比较了解js和css,你可能会像喜欢jquery一样喜欢它;

功能:

Splinter执行的时候会自动打开你指定的浏览器,访问指定的URL。
然后你所开发的模拟的任何行为,都会自动完成,你只需要坐在电脑面前,像看电影一样看着屏幕上各种动作自动完成然后收集结果即可。

举个例子,我们要回归登录功能,首先要开发如下模拟登录行为的脚本:
复制代码 代码如下:

#!/usr/bin/py2
# -*- coding: utf- -*-
#encoding=utf-

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('取回密码')
     == 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()
 
 
 

splinter python浏览器自动化操作,模拟浏览器的行为的更多相关文章

  1. Python实现浏览器自动化操作

    Python实现浏览器自动化操作 (2012-08-02 17:35:43) 转载▼     最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有不少介绍,例如使用pamie,但是只是 ...

  2. [转载]Python实现浏览器自动化操作

    原文地址:Python实现浏览器自动化操作作者:rayment   最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有不少介绍,例如使用pamie,但是只是支持IE,而且项目也较久没 ...

  3. python爬虫:使用Selenium模拟浏览器行为

    前几天有位微信读者问我一个爬虫的问题,就是在爬去百度贴吧首页的热门动态下面的图片的时候,爬取的图片总是爬取不完整,比首页看到的少.原因他也大概分析了下,就是后面的图片是动态加载的.他的问题就是这部分动 ...

  4. 使用Selenium进行浏览器自动化操作记录

    一位经验丰富的同事交给了我一个任务:将20个IP地址添加到公司系统对应的目录下. 这个任务之前做过,并且数量是远不止20个,当时就学习Selenium并且使用Python3.6写了一个脚本用来自动化地 ...

  5. C#自动化操作IE浏览器系列之一打开新的浏览器并导航到百度进行搜索

    现在OA系统.生产管理系统都是B/S结构,很多的办公室工作都要用浏览器操作.自己会一点C# winform开发,就做个小工具自动化处理一些繁琐的操作. 我的开发环境是:win7旗舰版+VS2010(或 ...

  6. java,利用Selenium调用浏览器,动态模拟浏览器事件,动态获取页面信息

    1.环境搭建 jdk1.6版本:selenium 2.4版本. jdk1.8版本:selenium3.14版本. (1)selenium的jar包下载: 地址:http://selenium-rele ...

  7. Python + Appium 自动化操作微信入门看这一篇就够了

    简介 Appium 是一个开源的自动化测试工具,支持 Android.iOS 平台上的原生应用,支持 Java.Python.PHP 等多种语言. Appium 封装了 Selenium,能够为用户提 ...

  8. Python cx_oracle自动化操作oracle数据库增删改查封装,优化返回查询数据

    # coding=utf-8 import cx_Oracle import os import json os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_C ...

  9. Python开发爬虫之动态网页抓取篇:爬取博客评论数据——通过Selenium模拟浏览器抓取

    区别于上篇动态网页抓取,这里介绍另一种方法,即使用浏览器渲染引擎.直接用浏览器在显示网页时解析 HTML.应用 CSS 样式并执行 JavaScript 的语句. 这个方法在爬虫过程中会打开一个浏览器 ...

随机推荐

  1. C指针陷阱

    问题一: #include <stdio.h> int main(int argc, char *argv[]) { ]={ ,,,, }; ); printf(),*(p-)); ; } ...

  2. Debian(Linux)系统目录简单说明

    bin:基础命令执行档 boot:引导装置器的静态链接文件 dev:设备档 etc:主机特定的系统配置 lib:基本共享库及基本内核模块 mnt:用于临时挂载一个文件系统 proc:系统信息的虚拟目录 ...

  3. 基本的编程原则SOLID

    1.单一职责原则:每个类只负责完成一个职责,当它需要完成多个职责时就需要将它拆分开来. 2.开放封闭原则:对扩展开放,对修改封闭. 3.里氏替换原则:子类对象可以替换(代替)它的所有父类(超类)对象. ...

  4. python学习之day9

    队列queue 队列是线程安全的,它保证多线程间的数据交互的一致性. 先进先出队列Queue import queue q = queue.Queue(maxsize=3) #maxsize为队列最大 ...

  5. DELPHI编写服务程序总结

    DELPHI编写服务程序总结 一.服务程序和桌面程序的区别 Windows 2000/XP/2003等支持一种叫做“系统服务程序”的进程,系统服务和桌面程序的区别是:系统服务不用登陆系统即可运行:系统 ...

  6. (step8.2.4)hdu 1846(Brave Game——巴什博奕)

    题目大意:输入一个整数t,表示测试用例是.接着输入2个整数n,m.分别表示这堆石头中石头的个数,和每次所能取得最大的石头数.判断那一方为赢家 解题思路: 1)这是一道简单的巴什博弈: 所谓巴什博弈,是 ...

  7. Binary Tree(二叉树+思维)

    Binary Tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Tota ...

  8. HDoj-1527-取石子游戏

    取石子游戏 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  9. 使用SharedPreferences即时存储之后,不能即时获取到数据

    在这里简介一下我所遇到的情况,由于情况非常特殊,所以我就来记录一下自己在这个方面的经历! 事由:在我所做的app中有一个视频的播放功能,因为之前做优化的时候.我听说对于视频这种比較耗费资源的应该给他独 ...

  10. Runtime.getRuntime().exec中命令含有括号问题

    在写批量运行bat工具的时候.想起了之前写的定时小工具里面的运行方法. 使用Runtime.getRuntime().exec方法. Runtime.getRuntime().exec("c ...