CasperJS跳过超时

时间:2013-12-05 12:00:18

标签: javascript casperjs

我的casperjs测试中有一个页面有图像,我不要等到这个页面加载到下一步。我该怎么做 ? 我试过这种方式

var casper = require("casper").create({
   onStepTimeout: function() {
                        this.echo("TIMEOUT" + this.requestUrl,"RED_BAR");
   // Some skip page controlling code 
   },
);
var timeout = ~~casper.cli.get(0);

casper.start("http://127.0.0.1/index2.php", function () {
    this.echo("FIRST GOOD PAGE", "GREEN_BAR");
    casper.options.stepTimeout = timeout;
});

casper.thenOpen("http://127.0.0.1/slowpage.php", function() {
        this.echo("SECOND PAGE LOADED - I want to be called even  have received Timeout!", "GREEN_BAR");
});

casper.then(function() {
    this.echo("THEN!", "GREEN_BAR"); 
});

但是casper只是调用onStepTimeout,直到加载了slopage.php。

2 个答案:

答案 0 :(得分:8)

您可以在casper步骤中添加request.abort();以结束步骤并继续执行下一步:

casper.then(function() {
  request.abort();
  this.echo('You will never see me');
});

casper.then(function() {
  this.echo('I execute next');
});

您还可以根据open请求检查是否要中止。此函数将检查匹配的URL,然后在打开之前中止,并将返回http状态代码:

casper.on('page.resource.requested', function(requestData, request) {
    if (requestData.url.indexOf('slowpage.php') !== -1) {
        request.abort();
    }
});

您可以更改waitTimeoutstepTimeout设置。此外,在pageSettings下,您可以使casper不加载图像。例如:

var casper = require('casper').create ({
    waitTimeout: 10000,
    stepTimeout: 10000,
    verbose: true,
    viewportSize: {
      width: 1400,
      height: 768
    },
    pageSettings: {
      "userAgent": 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.10 (KHTML, like Gecko) Chrome/23.0.1262.0 Safari/537.10',
      "loadImages": false,
      "loadPlugins": false,         
      "webSecurityEnabled": false,
      "ignoreSslErrors": true
    },
    onWaitTimeout: function() {
        //throw new Error
    },
    onStepTimeout: function() {
        //throw new Error
    }
});

您可以使用casper waitFor等待页面完全加载。只需return true。它甚至有自己的timeout功能。所以你可以这样做:

casper.waitFor(function check() {
    casper.thenOpen("http://127.0.0.1/slowpage.php", function() {
        //+++ casper will wait until this returns true to move forward. 
        //+++ The default timeout is set to 5000ms
        this.evaluate(function() {
          //checks for element exist
          if (document.getElementById('someElement')) {
            console.log('Im loaded!');
            return true;
          }
        });
    });   
}, function then() {    // step to execute when function check() is ok
    //+++ executes ONLY after the 'casper.thenOpen' returns true.
    this.echo("THEN!", "GREEN_BAR");
}, function timeout() { // step to execute if check has failed
    //+++ code for on timeout.  This is different than onStepTimeOut.
},1000);// custom timeOut setting.

答案 1 :(得分:6)

实际上,在某些情况下,由于连接问题,CasperJS的步骤有时会因超时(如果在设置中指定stepTimeout)而到期。默认行为是通过this.die停止CasperJS。如果需要不停止CasperJS,而是继续执行后续步骤,则应提供自定义onStepTimeout。遗憾的是,request.abort未在此上下文中定义,因为request只能在onResourceRequested处理程序中访问(这就是为什么@Topher Ellis的答案有问题)。换句话说,request.abort对于防止发出新请求很有用,但无法阻止正在进行的请求(并且可能会超时)。对于这种情况,我使用以下代码:

var casper = require("casper").create(
{
  ...
  onStepTimeout: function(timeout, step)
  {
    this.echo('step timeout');
    this.clear();
    this.page.stop();
  }
});

希望这有帮助。