我使用以下类型的代码截取屏幕截图:
var promise = driver.takeScreenshot();
promise.then(function (data) {
var base64Data = data.replace(/^data:image\/png;base64,/, '');
fs.writeFileSync('screenshot.png', base64Data, 'base64');
});
由于takeScreenshot的异步特性,不幸的是屏幕截图将在任意时间点拍摄,如果在此期间应用程序抛出异常,则根本不会写入屏幕截图。
使用webdriverjs同步截屏的正确方法是什么?
答案 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.