我有一些场景,其中某些测试随机地失败(可能是5/65),通常是svg,自动完成等。CPU很好,所以它来自于我编写脚本的方式。
但是我看不到如何更改它们以使其健壮可靠。这是我使用wait()函数的时间->有时我遇到超时错误,有时它过去了。
最奇怪的是,当我将脚本分成两个脚本时,失败的次数少于一个..
添加waitForResource尝试
感谢Artjom B.的帮助。
casper.test.begin('\n********* Navigation on directories : ***********', 4,{
setUp: function(test) {
setLevel("normal");
},
tearDown: function(test) {
getJSON();
},
test: function(test){
"use strict";
var url = 'http://www.linternaute.com/';
casper.start()
.thenOpen(url + "/ville/", function(){
if(this.exists('.ui-dialog-titlebar-close')){this.click('.ui-dialog-titlebar-close');}
if(this.exists('#top_oas')){this.click('#top_oas > .right');}
this.test.assertExists(".jODMainSearch", "Search toolbar present");
this.sendKeys(".jODMainSearch", "Ren");
this.click(".submit.search");
})
.waitForSelector(".odListGlossary", function(){
this.test.assertExists(".odListGlossary", "Search result ok");
this.clickLabel("Rennes (35000)");
})
.waitFor(function check() {
return this.fetchText('h1').indexOf("Rennes") !== -1;
}
, function then() {
this.test.assertSelectorHasText("h1", "Rennes");
}
)
//auto-completion
.thenOpen(url + "/ville/", function(){
//this.waitForResource(/odmainsearch/, function(){
/*var fs = require('fs');
fs.write("results1.html", this.getPageContent(), 'w');
this.wait(8000, function(){
var fs = require('fs');
fs.write("results2.html", this.getPageContent(), 'w');
});*/
/*casper.waitFor(function check() {
return this.fetchText('script').indexOf("fn.odMainsearch=function") !== -1;
}
, function then() {
this.echo('cc');
this.sendKeys('.jODMainSearch', 'Ren', {keepFocus: true});
}
);*/
/*** the changes ***/
this.waitForResource(function testResource(resource) {
return resource.url.indexOf("http://static.ccmbg.com/www.linternaute.com/asset/js?m=odmainsearch") !== -1;
}, function onReceived() {
this.echo('JS for auto-completion present');
this.sendKeys('.jODMainSearch', 'Ren', {keepFocus: true});
});
this.waitForSelector('ul.ui-autocomplete[viewbox="true"]', function() {
this.mouse.move('a[href="/ville/rennes/ville-35238"]');
this.click('a[href="/ville/rennes/ville-35238"]');
});
})
.waitFor(function check() {
return this.fetchText('h1').indexOf("Rennes") !== -1;
}
, function then() {
this.test.assertSelectorHasText("h1", "Rennes");
}
)
.run(function() {
this.test.comment('--- Done ---\n');
test.done();
});
}
});
第一次尝试 :
这是一个随机失败的例子:
casper.test.begin('\n********* Navigation on directories : ***********', 4,{
setUp: function(test) {
//setLevel("normal");
},
tearDown: function(test) {
//getJSON();
},
test: function(test){
"use strict";
var url = 'http://www.linternaute.com/';
casper.start()
.thenOpen(url + "/ville/", function(){
//close some ads
if(this.exists('.ui-dialog-titlebar-close')){this.click('.ui-dialog-titlebar-close');}
if(this.exists('#top_oas')){this.click('#top_oas > .right');}
this.test.assertExists(".jODMainSearch", "Search toolbar present");
this.sendKeys(".jODMainSearch", "Ren");
this.click(".submit.search");
})
.waitForSelector(".odListGlossary", function(){
this.test.assertExists(".odListGlossary", "Search result ok");
this.clickLabel("Rennes (35000)");
})
.waitFor(function check() {
return this.fetchText('h1').indexOf("Rennes") !== -1;
}
, function then() {
this.test.assertSelectorHasText("h1", "Rennes");
}
)
//auto-completion
.thenOpen(url + "/ville/", function(){
this.sendKeys('.jODMainSearch', 'Ren', {keepFocus: true});
this.waitForSelector('ul.ui-autocomplete[viewbox="true"]', function() {
this.mouse.move('a[href="/ville/rennes/ville-35238"]');
this.click('a[href="/ville/rennes/ville-35238"]');
});
})
.waitFor(function check() {
return this.fetchText('h1').indexOf("Rennes") !== -1;
}
, function then() {
this.test.assertSelectorHasText("h1", "Rennes");
}
)
.run(function() {
this.test.comment('--- Done ---\n');
test.done();
});
}
});
而且,如果我只看脚本的结尾(在第一个示例中它随机失败,那么我已经注释了开头):
casper.test.begin('\n********* Navigation on directories : ***********', 1,{
setUp: function(test) {
//setLevel("normal");
},
tearDown: function(test) {
//getJSON();
},
test: function(test){
"use strict";
var url = 'http://www.linternaute.com/';
casper.start()
/*.thenOpen(url + "/ville/", function(){
if(this.exists('.ui-dialog-titlebar-close')){this.click('.ui-dialog-titlebar-close');}
if(this.exists('#top_oas')){this.click('#top_oas > .right');}
this.test.assertExists(".jODMainSearch", "Search toolbar present");
this.sendKeys(".jODMainSearch", "Ren");
this.click(".submit.search");
})
.waitForSelector(".odListGlossary", function(){
this.test.assertExists(".odListGlossary", "Search result ok");
this.clickLabel("Rennes (35000)");
})
.waitFor(function check() {
return this.fetchText('h1').indexOf("Rennes") !== -1;
}
, function then() {
this.test.assertSelectorHasText("h1", "Rennes");
}
)*/
//auto-completion
.thenOpen(url + "/ville/", function(){
this.sendKeys('.jODMainSearch', 'Ren', {keepFocus: true});
this.waitForSelector('ul.ui-autocomplete[viewbox="true"]', function() {
this.mouse.move('a[href="/ville/rennes/ville-35238"]');
this.click('a[href="/ville/rennes/ville-35238"]');
});
})
.waitFor(function check() {
return this.fetchText('h1').indexOf("Rennes") !== -1;
}
, function then() {
this.test.assertSelectorHasText("h1", "Rennes");
}
)
.run(function() {
this.test.comment('--- Done ---\n');
test.done();
});
}
});
那么问题是什么,您有想法吗?->堆栈中有两个步骤函数:通常会失败,只有一个:有时会失败...
加载页面时,似乎并非所有脚本都出现在DOM中。在评估内联脚本块之后window.onload
,至少会加载一个js资源,因此,在thenOpen
将控制权交给下一步之后以及相应地之后进行加载。您的情况下的资源是:
http://static.ccmbg.com/www.linternaute.com/asset/js?m=odmainsearch&v=201405201800
因此,如果要根据其代码采取措施,则需要等待这么晚的资源。在您的情况下,必须打开自动完成下拉列表。所以我改变了
casper.thenOpen(url + "/ville/", function(){
this.sendKeys('.jODMainSearch', 'Ren', {keepFocus: true});
this.waitForSelector('ul.ui-autocomplete[viewbox="true"]', function() {
this.mouse.move('a[href="/ville/rennes/ville-35238"]');
this.click('a[href="/ville/rennes/ville-35238"]');
});
});
至
casper.thenOpen(url + "/ville/")
.waitForResource(/linternaute\.com\/asset\/js/, function(){
this.wait(500); // this seem necessary: maybe to wait for the script evaluation
})
.then(function(){
this.sendKeys('.jODMainSearch', 'Ren', {keepFocus: true});
})
.waitForSelector('ul.ui-autocomplete[viewbox="true"]', function() {
this.mouse.move('a[href="/ville/rennes/ville-35238"]');
this.click('a[href="/ville/rennes/ville-35238"]');
});
我使用了完整的脚本,而没有对第一部分进行注释。在casper
只有那里的方向。20次运行无错误。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句