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, refrom splinter.browser import browser
cloase_after_test = falsereload(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/chromedriverbrowser = browser() # already support firefoxbrowser.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()