微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

通过添加user-extension.js解决selenium-IDE中的回车和blank问题

通过添加user-extension.js解决录制回车问题


1. 编写user-extension.js(文件名可以随便取),录制回车的js代码如下:

Recorder.removeEventHandler('keyDown');

Recorder.addEventHandler('keyDown', 'keydown', function(event) {

var keynum;

if(window.event) // IE

{

keynum = event.keyCode

}

else if(event.which) // netscape/Firefox/Opera

{

keynum = event.which

}

if(keynum==13){

var _this = this;

var target = _this.findLocator(event.target);

setTimeout(function(){_this.record('keyDown', target,'\\'+keynum); },1000);//延迟1000ms再写入回车记录

}

}, { capture: true });

2. 添加脚本到IDE中(option-IDE extensions):

3. 脚本将keydown事件绑定到Selenium系统命令keyDown,并判断按键是否为13(回车),如果是就在IDE中写入一条命令,写入命令使用this.record('keyDown', this.findLocator(event.target),'\\'+keynum);,其中第一个参数是IDE中的Command列,第二个参数为Target列,第三个参数为Value列。{ capture: true }表示录制。

4. 系统命令:在command中可以查到。

5. 其他:可在火狐浏览器中输入地址:

chrome://selenium-ide/content/recorder-handlers.js查看click的系统事件。


通过添加user-extension.js解决blank跳转问题


1. 问题描述:

在使用Selenium-IDE录制时,如果录制页面有新开页,回放脚本的时候会报警告<a href="xxx.jsp" target="_blank">,并且会在新窗口打开页面,但由于无法判断新窗口的id,所以无法继续执行脚本中的其他命令。

2. 解决思路:

将原先的click命令替换成open并将href中的值取出付给open的target。这样可保证在本页面打卡,并可正常执行剩下的脚本命令。

3. 脚本代码:将如下代码写入user-extension.js中,并添加

option-IDE extensions。

Recorder.removeEventHandler('clickLocator');

Recorder.addEventHandler('clickLocator', 'click', function(event) {

if (event.button == 0) {

var clickable = this.findClickableElement(event.target);

var href = event.target.getAttribute("href");//event.target是html标签对象

var blank = event.target.getAttribute("target");

if (clickable) {

if (this.mouSEOverLocator) {

this.record('mouSEOver', this.mouSEOverLocator, '');

delete this.mouSEOverLocator;

}

if(blank!=null&&blank.indexOf("blank")>=0){

this.record("waitForElementPresent", this.findLocators(event.target), '');//等待元素加载完成

this.record("open", href, '');

}

else{

this.record("click", this.findLocators(event.target), '');

}

} else {

var target = event.target;

if(blank!=null&&blank.indexOf("blank")>=0){

this.record("waitForElementPresent", this.findLocators(event.target), '');

this.record("open", href, '');

}

else{

this.callIfMeaningfulEvent(function() {

this.record("click", this.findLocators(target), '');

});

}

}

}

}, { capture: true });

注意:回放时为保证脚本正确执行,最好将回放速度调整为slow,否则页面若未加载完成,可能导致有些命令执行失败。



版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐