使用Selenium的webdriverjs运行Webdriver测试时,截屏的正确方法是什么?
我已经启动了独立的selenium服务器,并且可以看到在selenium服务器上记录了用于截屏的命令,但是没有保存该截屏。
我的代码如下:
var webdriver = require('selenium-webdriver'); var driver = new webdriver.Builder().usingServer('http://localURL:4444/wd/hub').withCapabilities({'browserName': 'chrome'}).build(); driver.get([URL to webserver on my local machine]) driver.takeScreenshot("c:\\selenium_local_map\\out1.png");
拍摄屏幕快照会返回一个Promise,它将以Base64编码的png解析。要写入数据,您需要执行以下操作:
function writeScreenshot(data, name) { name = name || 'ss.png'; var screenshotPath = 'C:\\selenium_local_map\\'; fs.writeFileSync(screenshotPath + name, data, 'base64'); }; driver.takeScreenshot().then(function(data) { writeScreenshot(data, 'out1.png'); });
更多文档可以在这里找到