CasperJS / PhantomJS,某些测试随机失败

范奇

我有一些场景,其中某些测试随机地失败(可能是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();
    });
}
});

那么问题是什么,您有想法吗?->堆栈中有两个步骤函数:通常会失败,只有一个:有时会失败...

Artjom B.

加载页面时,似乎并非所有脚本都出现在DOM中。在评估内联脚本块之后window.onload至少会加载一个js资源,因此,在thenOpen将控制权交给下一步之后以及相应地之后进行加载您的情况下的资源是:

http://static.ccmbg.com/www.linternaute.com/asset/js?m=odmainsearch&v=201405201‌800

因此,如果要根据其代码采取措施,则需要等待这么晚的资源。在您的情况下,必须打开自动完成下拉列表。所以我改变了

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] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

casperjs找不到phantomjs

来自分类Dev

CasperJS / PhantomJS分段错误

来自分类Dev

Casperjs随机延迟

来自分类Dev

casperJS注入jQuery失败

来自分类Dev

casperjs和A / b测试

来自分类Dev

CasperJS测试文件中的测试套件循环导致外壳中的随机失败

来自分类Dev

PhantomJS / CasperJS IDE帮助器

来自分类Dev

通过Charles代理casperjs / phantomjs

来自分类Dev

phantomjs / casperjs计算DOM元素

来自分类Dev

网页上的Casperjs状态失败

来自分类Dev

使用casperjs测试损坏的html

来自分类Dev

什么是casperjs中的可疑测试

来自分类Dev

未使用casperJS执行的测试

来自分类Dev

在CasperJS中测试URL列表

来自分类Dev

使用slimerjs运行casperjs测试

来自分类Dev

在CasperJS中测试URL列表

来自分类Dev

CasperJS / PhantomJS在加载页面时感到窒息

来自分类Dev

在PhantomJS / CasperJS中设置屏幕大小

来自分类Dev

CasperJS / PhantomJS ES6 Promise Polyfill

来自分类Dev

如何使用casperjs / phantomjs保存当前网页?

来自分类Dev

Ruby中的PhantomJS + CasperJS-重用代码?

来自分类Dev

如何使用phantomjs / casperjs处理下载?

来自分类Dev

CasperJS / PhantomJS不加载https页面

来自分类Dev

Phantomjs / Casperjs打开bt wifi并登录

来自分类Dev

CasperJS无法识别PhantomJS网页模块

来自分类Dev

在PhantomJS / CasperJS中设置屏幕大小

来自分类Dev

暂停和恢复CasperJS,PhantomJS脚本

来自分类Dev

动态CasperJS循环在随机迭代时终止

来自分类Dev

CasperJS,测试页无法完全加载