2015-04-27 31 views
2

您好!在BrowserStack中运行量角器的截图

我试图采取量角器和browserstack截图,我下面conf.js文件:

var HtmlReporter = require('protractor-html-screenshot-reporter'); 
var reporter=new HtmlReporter({ 
    baseDirectory: './protractor-result', // a location to store screen shots. 
    docTitle: 'Report Test Summary', 
    docName: 'protractor-tests-report.html' 
}); 

// An example configuration file. 
exports.config = { 
    // The address of a running selenium server. 
    seleniumAddress: 'http://hub.browserstack.com/wd/hub', 

    // Capabilities to be passed to the webdriver instance. 
    capabilities: { 
    'browserName': 'chrome', 
    'version': '22.0', 
    'browserstack.user' : 'user_name', 
    'browserstack.key' : 'user_key', 
    'browserstack.debug' : 'true' 

    }, 

    // Spec patterns are relative to the current working directly when 
    // protractor is called. 
    specs: ['./specs/home_page_spec.js'], 

    // Options to be passed to Jasmine-node. 
    jasmineNodeOpts: { 
    showColors: true, 
    defaultTimeoutInterval: 30000 
    }, 
onPrepare: function() { 
     jasmine.getEnv().addReporter(reporter); 
     } 

    }; 

而且browserstack帮助说,我需要添加following lines

var fs = require('fs'); 

webdriver.WebDriver.prototype.saveScreenshot = function(filename) { 
    return driver.takeScreenshot().then(function(data) { 
     fs.writeFile(filename, data.replace(/^data:image\/png;base64,/,''), 'base64', function(err) { 
      if(err) throw err; 
     }); 
    }) 
}; 

driver.saveScreenshot('snapshot1.png'); 

有没有人可以指向我在哪里添加这些行?如何? (我也使用PageObject模式)

回答

0

我想你是在谈论两件事,一个是制作截图的插件,第二个是在测试代码中手动创建screeshots,无论插件如何。

理论上,插件应该为你制作截图。如果没有,您可以使用从browserstack提供的代码手动创建它们,只需在某些需求后放入测试代码中的任何位置即可。

总之,使从量角器的截图,我建议使用protractor-screenshoter-plugin (免责声明:我是作者),你也可以看看Protractor-Screenshots-Alernatives

现在的一个分支我有并行化的新支持。看看https://github.com/azachar/protractor-screenshoter-plugin/tree/feat-parallel-support

要安装包含并行支持使用

npm install azachar/protractor-screenshoter-plugin#feat-parallel-support

安装稳定的版本,而平行的支撑不稳定的版本,只需键入像往常一样:

npm install protractor-screenshoter-plugin

让我知道如果它按预期工作!

干杯, Andrej