[摘]selenium-ide命令

系统 1451 0

关于,selenium 命令这一部分,为了便于像我一样的菜鸟理解,我采用通过例子讲命令的方式。

菜鸟Selenium  命令通常被称为 selenese ,有一系列运行测试案例所需的命令构成。

 

      ----
      
        //
        
           Actions
        
      
    

 

---- // Actions

     
  

Actions描述了用户所会作出的操作。 Action 有两种形式: action和actionAndWait, action会立即执行,而actionAndWait会假设需要较长时间才能得到该action的响应,而作出等待,open则是会自动处理等待时间。

=================    例1   ================================================

[摘]selenium-ide命令

操作说明:

打开谷歌首页,输入“ selenium  环境配置”字段,点击“搜索”按钮。

命令说明:

open open(url) 在浏览器中打开 URL, 可以接受相对和绝对路径两种形式 注意:该 URL 必须在与浏览器相同的安全限定范围之内 

Highlight(locator)

暂时将指定元素的背景色改变为黄色,有利于调试。

pause pause(millisenconds) 根据指定时间暂停 Selenium 脚本执行 常用在调试脚本或等待服务器段响应时 

type  type(inputLocator, value) 模拟人手的输入过程,往指定的 input 中输入值 也适合给复选和单选框赋值 

click click(elementLocator) 点击连接 , 按钮,复选和单选框 如果点击后需要等待响应,则用 "clickAndWait" 如果是需要经过 JavaScript alert confirm 对话框后才能继续操作,则需要调用 verify assert 来告诉 Selenium 你期望对对话框进行什么操作。 

goBack() 模拟点击浏览器的后退按钮 close() 模拟点击浏览器关闭按钮 

 

 

===============     例2   =======================================

[摘]selenium-ide命令

操作说明:

打开谷歌搜索首页,在左上边的选项中选择“更多”,在下拉列表中选择“博客”,然后在搜索栏内输入“虫师”,点击搜索按钮,然后打开我的博客(通过我 url 的方式)

命令说明:

其实本例中并没有出现新命令,但有一个问题。在搜索的结果中,标红的两行作用是一样的,都能打开我的博客。

      click 通过页面的字符匹配,点击链接,但打开的新窗口中只有地址栏;用 click 的方式,如果页面发生变动,没匹配到我想到我输入的关键字,页脚本就会失败。

     open 直接通过链接跳转,但又失去了前面搜索操作的意义。 ----- 当然,这里只是把它作为一个问题提出来。真实项目中,可能我们是不会遇到这种情况的。

 用兴趣的话将上面的例子验证一下,算是对第一个例子的理解和加强吧!

 

 

===============   例3 =======================================

这个例子录制的是开心网的注册页面,这不是一个完整的注册,因为最后一项要求输入验证码。所以,就算录制完成,也无法正常回放,这里只是为了讲解几个命令。(*^__^*) 嘻嘻…… 

可能通过上面的表格,你依然觉得不够直观。那么,看看下面的截图呢!?

[摘]selenium-ide命令

  相信截图还是很清晰的说,那就根据上面的截图讲解了。。

操作说明:

打开开心网注册页面, 填写email地址,输入密码,重复密码,输入姓名,选择性别(男女)选择出生年、月、日,选择权限(都谁可以访问我的页面)

命令说明:

select select(dropDownLocator, optionSpecifier) 根据 optionSpecifier 选项选择器来选择一个下拉菜单选项 如果有多于一个选择器的时候,如在用通配符模式,如 "f*b*", 或者超过一个选项有相同的文本或值,则会选择第一个匹配到的值

 陌生的命令就这一个啦,关于命令 target部分 (就是id=...),我们可以通过firefox的插件firebug工具,进行查看页面元素,前面有讲解,这里就不多说了。

 

---- // 例子中没提交的命令

 

下面的命令我还没有找到合适的例子做演示,所以,先罗列出来,有时间在做演示。

  • fireEvent fireEvent(elementLocatore,evenName) 模拟页面元素事件被激活的处理动作
    fireEvent textField focus
    fireEvent dropDown blur
  • waitForCondition waitForCondition(JavaScriptSnippet,time) - 在限定时间内,等待一段JavaScript代码返回true值,超时则停止等待
    waitForCondition var value="/selenium.getText(""foo"); value.match(/bar/); 3000
  • waitForValue waitForValue(inputLocator, value) - 等待某input(如hidden input)被赋予某值, - 会轮流检测该值,所以要注意如果该值长时间一直不赋予该input该值的话,可能会导致阻塞
    waitForValue finishIndication isfinished
         
  • store,stroreValue store(valueToStore, variablename) 保存一个值到变量里。 该值可以由自其他变量组合而成或通过JavaScript表达式赋值给变量
    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, storeAttribute storeText(elementLocator, variablename) 把指定元素的文本值赋予给变量
    storeText currentDate expectedStartDate
    verifyValue startDate $.{expectedStartDate}

    storeAttribute( .{ }elementLocator@attributeName,variableName.{ ) 把指定元素的属性的值赋予给变量

    storeAttribute input1@class classOfInput1
    verifyAttribute input2@class $.{classOfInput1}
  • chooseCancel.., answer.. chooseCancelOnNextConfirmation() - 当下次JavaScript弹出confirm对话框的时候,让selenium选择Cancel - 如果没有该命令时,遇到confirm对话框Selenium默认返回true,如手动选择OK按钮一样
    chooseCancelOnNextConfirmation    

    - 如果已经运行过该命令,当下一次又有confirm对话框出现时,也会同样地再次选择Cancel answerOnNextPrompt(answerString) - 在下次JavaScript弹出prompt提示框时,赋予其anweerString的值,并选择确定

    answerOnNextPrompt Kangaroo  

关于selenium 命令,这一部分,我学的比较仔细,所以,也想讲的仔细点。关于后面,还会说到:

* 验证页面元素

* 定位页面元素

* 文字范本匹配

[摘]selenium-ide命令


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论