关于,selenium 命令这一部分,为了便于像我同样的菜鸟理解,我采用经过例子讲命令的方式。javascript
菜鸟Selenium 命令一般被称为selenese,有一系列运行测试案例所需的命令构成。java
----// Actions
----// Actions浏览器
Actions描述了用户所会做出的操做。 Action 有两种形式: action和actionAndWait, action会当即执行,而actionAndWait会假设须要较长时间才能获得该action的响应,而做出等待,open则是会自动处理等待时间。安全
================= 例1 ================================================服务器
操做说明:工具
打开谷歌首页,输入“selenium 环境配置”字段,点击“搜索”按钮。测试
命令说明:url
open open(url) - 在浏览器中打开URL,能够接受相对和绝对路径两种形式 - 注意:该URL必须在与浏览器相同的安全限定范围以内 spa
Highlight(locator)firefox
- 暂时将指定元素的背景色改变为黄色,有利于调试。
pause pause(millisenconds) - 根据指定时间暂停Selenium脚本执行 - 经常使用在调试脚本或等待服务器段响应时
type type(inputLocator, value) - 模拟人手的输入过程,往指定的input中输入值 - 也适合给复选和单选框赋值
click click(elementLocator) - 点击链接,按钮,复选和单选框 - 若是点击后须要等待响应,则用"clickAndWait" - 若是是须要通过JavaScript的alert或confirm对话框后才能继续操做,则须要调用verify或assert来告诉Selenium你指望对对话框进行什么操做。
goBack() 模拟点击浏览器的后退按钮 close() 模拟点击浏览器关闭按钮
=============== 例2 =======================================
操做说明:
打开谷歌搜索首页,在左上边的选项中选择“更多”,在下拉列表中选择“博客”,而后在搜索栏内输入“虫师”,点击搜索按钮,而后打开个人博客(经过我url的方式)
命令说明:
其实本例中并无出现新命令,但有一个问题。在搜索的结果中,标红的两行做用是同样的,都能打开个人博客。
click经过页面的字符匹配,点击连接,但打开的新窗口中只有地址栏;用click的方式,若是页面发生变更,没匹配到我想到我输入的关键字,页脚本就会失败。
open直接经过连接跳转,但又失去了前面搜索操做的意义。-----固然,这里只是把它做为一个问题提出来。真实项目中,可能咱们是不会遇到这种状况的。
用兴趣的话将上面的例子验证一下,算是对第一个例子的理解和增强吧!
=============== 例3 =======================================
这个例子录制的是开心网的注册页面,这不是一个完整的注册,由于最后一项要求输入验证码。因此,就算录制完成,也没法正常回放,这里只是为了讲解几个命令。(*^__^*) 嘻嘻……
可能经过上面的表格,你依然以为不够直观。那么,看看下面的截图呢!?
相信截图仍是很清晰的说,那就根据上面的截图讲解了。。
操做说明:
打开开心网注册页面, 填写email地址,输入密码,重复密码,输入姓名,选择性别(男女)选择出生年、月、日,选择权限(都谁能够访问个人页面)
命令说明:
select select(dropDownLocator, optionSpecifier) - 根据optionSpecifier选项选择器来选择一个下拉菜单选项 - 若是有多于一个选择器的时候,如在用通配符模式,如"f*b*",或者超过一个选项有相同的文本或值,则会选择第一个匹配到的值
陌生的命令就这一个啦,关于命令target部分(就是id=...),咱们能够经过firefox的插件firebug工具,进行查看页面元素,前面有讲解,这里就很少说了。
下面的命令我尚未找到合适的例子作演示,因此,先罗列出来,有时间在作演示。
fireEvent | textField | focus |
fireEvent | dropDown | blur |
waitForCondition | var value="/selenium.getText(""foo"); value.match(/bar/); | 3000 |
waitForValue | finishIndication | isfinished |
store | Mr John Smith | fullname |
store | $.{title} $.{firstname} $.{suname} | fullname |
store | javascript.{Math.round(Math.PI*100)/100} | PI |
storeValue | inputLocator | variableName |
把指定的input中的值保存到变量中
storeValue | userName | userID |
type | userName | $.{userID} |
storeText | currentDate | expectedStartDate |
verifyValue | startDate | $.{expectedStartDate} |
storeAttribute(.{}elementLocator@attributeName,variableName.{}) 把指定元素的属性的值赋予给变量
storeAttribute | input1@class | classOfInput1 |
verifyAttribute | input2@class | $.{classOfInput1} |
chooseCancelOnNextConfirmation |
- 若是已经运行过该命令,当下一次又有confirm对话框出现时,也会一样地再次选择Cancel answerOnNextPrompt(answerString) - 在下次JavaScript弹出prompt提示框时,赋予其anweerString的值,并选择肯定
answerOnNextPrompt | Kangaroo |
关于selenium 命令,这一部分,我学的比较仔细,因此,也想讲的仔细点。关于后面,还会说到:
* 验证页面元素
* 定位页面元素
* 文字范本匹配