splinter python浏览器自动化操作,模拟浏览器的行为
一、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会打开你所指定的浏览器然后进行各种操作,像放电影一样的根据你的代码逻辑在你面前一步一步执行。
举个例子,现在我们要回归登录功能,以前我们从未开发过这样的脚本,所以现在我们首先要开发一个用于模拟登录行为的脚本。
如下面代码(其实是非常简短的一个代码):
- #!/user/bin/python
- # -*- coding: utf8 -*-
- import sys
- import re
- from splinter.browser import Browser
- #####################################################
- # global instance
- CLOASE_AFTER_TEST = False
- GBK = "gbk"
- UTF8 = "utf8"
- #####################################################
- # encoding for console
- reload(sys)
- sys.setdefaultencoding(UTF8)
- #####################################################
- # small method
- encoding = lambda x:x.encode('gbk')
- #####################################################
- def output(x):
- """
- encode and print
- """
- print encoding(x)
- def resultMsg(x):
- """
- judge result and print, x : True or False
- """
- if x == True:
- print 'pass'
- else:
- print '[X]not pass'
- print '--------------------------'
- def checkresult(x):
- """
- check result message, x : the error message u want
- """
- resultMsg(browser.is_text_present(x))
- def testLogin(desc, username, password, result):
- """
- fill login form message and submit, check result message and print
- """
- output(desc)
- browser.fill('TPL_username',username.decode(UTF8))
- browser.fill('TPL_password',password.decode(UTF8))
- browser.find_by_value('登录').first.click()
- checkresult(result)
- __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
- # already support firefox
- browser = Browser()
- 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()
从这几句我们可以看到,我们大致要测试的几种登录情况:
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浏览器自动化操作,模拟浏览器的行为的更多相关文章
- Python实现浏览器自动化操作
Python实现浏览器自动化操作 (2012-08-02 17:35:43) 转载▼ 最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有不少介绍,例如使用pamie,但是只是 ...
- [转载]Python实现浏览器自动化操作
原文地址:Python实现浏览器自动化操作作者:rayment 最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有不少介绍,例如使用pamie,但是只是支持IE,而且项目也较久没 ...
- python爬虫:使用Selenium模拟浏览器行为
前几天有位微信读者问我一个爬虫的问题,就是在爬去百度贴吧首页的热门动态下面的图片的时候,爬取的图片总是爬取不完整,比首页看到的少.原因他也大概分析了下,就是后面的图片是动态加载的.他的问题就是这部分动 ...
- 使用Selenium进行浏览器自动化操作记录
一位经验丰富的同事交给了我一个任务:将20个IP地址添加到公司系统对应的目录下. 这个任务之前做过,并且数量是远不止20个,当时就学习Selenium并且使用Python3.6写了一个脚本用来自动化地 ...
- C#自动化操作IE浏览器系列之一打开新的浏览器并导航到百度进行搜索
现在OA系统.生产管理系统都是B/S结构,很多的办公室工作都要用浏览器操作.自己会一点C# winform开发,就做个小工具自动化处理一些繁琐的操作. 我的开发环境是:win7旗舰版+VS2010(或 ...
- java,利用Selenium调用浏览器,动态模拟浏览器事件,动态获取页面信息
1.环境搭建 jdk1.6版本:selenium 2.4版本. jdk1.8版本:selenium3.14版本. (1)selenium的jar包下载: 地址:http://selenium-rele ...
- Python + Appium 自动化操作微信入门看这一篇就够了
简介 Appium 是一个开源的自动化测试工具,支持 Android.iOS 平台上的原生应用,支持 Java.Python.PHP 等多种语言. Appium 封装了 Selenium,能够为用户提 ...
- Python cx_oracle自动化操作oracle数据库增删改查封装,优化返回查询数据
# coding=utf-8 import cx_Oracle import os import json os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_C ...
- Python开发爬虫之动态网页抓取篇:爬取博客评论数据——通过Selenium模拟浏览器抓取
区别于上篇动态网页抓取,这里介绍另一种方法,即使用浏览器渲染引擎.直接用浏览器在显示网页时解析 HTML.应用 CSS 样式并执行 JavaScript 的语句. 这个方法在爬虫过程中会打开一个浏览器 ...
随机推荐
- virtual 关键字
virtual 关键字用于修饰方法.属性.索引器或事件声明,并且允许在派生类中重写这些对象.例如,此方法可被任何继承它的类重写. public virtual double Area() { retu ...
- awk参数详解
wk是行处理器: 相比较屏幕处理的优点,在处理庞大文件时不会出现内存溢出或是处理缓慢的问题,通常用来格式化文本信息 awk处理过程: 依次对每一行进行处理,然后输出 awk命令形式: awk [-F| ...
- 高级UNIX环境编程11 线程
<pthread.h> pthread_equal pthread_self(void) pthread_create() pthread_close() pthread_join() p ...
- 设置textarea文本域不能调整大小 resize
CSS3中新增了resize缩放属性,这个属性可以应用到任意元素.目前只有Webkit内核的浏览器才支持这个css3属性,即Google chrome和Apple safari都支持.而textare ...
- RMAN多种备份脚本分享
1.相关参数介绍: 命令行参数 描述 TARGET 为目标数据库定义的一个连接字符串,当连接到一个目标数据库时,该连续是SYSDBA连接.该用户拥有启动和关闭数据库的权利,必须属于OSDBA组,必须建 ...
- poj 1731 Orders(暴力)
题目链接:http://poj.org/problem?id=1731 思路分析:含有重复元素的全排列问题:元素个数为200个,采用暴力枚举法. 代码如下: #include <iostream ...
- Buy Tickets(线段树)
Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 16607 Accepted: 8275 Desc ...
- Lucene 实例教程(二)
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本人声明.否则将追究法律责任. 作者: 永恒の_☆ 地址: http://blog.csdn.net/chenghui031 ...
- ThinkPHP - 缓存使用
用法: 需要使用不同的缓存方式的时候 需要重新初始化,如果不初始化直接调用的话,则会按照系统配置自动初始化.初始化的返回值,可以直接操作缓存: $cache = cache(array('type'= ...
- uboot编译: uboot编译配置和编译过程
jz2440: 韦东山Linux视频第1期_裸板_UBoot_文件系统_驱动初步\第09课第2节 u-boot分析之Makefile结构分析.WMV <嵌入式linux完全开发手册> 15 ...