如何在webdriverjs中等待takeScreenshot获取截图

时间:2015-02-17 19:21:48

标签: javascript node.js selenium selenium-webdriver webdriver

我使用以下类型的代码截取屏幕截图:

var promise = driver.takeScreenshot();
promise.then(function (data) {
    var base64Data = data.replace(/^data:image\/png;base64,/, '');
    fs.writeFileSync('screenshot.png', base64Data, 'base64');
});

由于takeScreenshot的异步特性,不幸的是屏幕截图将在任意时间点拍摄,如果在此期间应用程序抛出异常,则根本不会写入屏幕截图。

使用webdriverjs同步截屏的正确方法是什么?

1 个答案:

答案 0 :(得分:2)

我通常在After挂钩中截取屏幕截图。下面是cucumberjs中的Hook之后的示例代码。如果您使用的是mocha,它也有钩子。

 this.After(function (scenario, callback) {
        if(scenario.isFailed()){
            driver.takeScreenshot().then(function (buffer) {
                scenario.attach(new Buffer(buffer, 'base64').toString('binary'), 'image/png');
            });
        }
        driver.quit().then(function () {
                callback();
        });
 });

以下是WebDriverJS文档的一些摘录。因此,在获取屏幕截图之前,您可以向WebDriver发送等待命令以获取特定条件,然后也会截取屏幕截图。在一般的测试框架后,钩子工作最好

WebDriverJS uses a promise "manager" to coordinate the scheduling and execution of all commands.

The promise manager maintains a queue of scheduled tasks, executing each once the one before it in the queue is finished.