如何为不同的浏览器和测试套件参数化量角器配置文件

ssh*_*rma 1 protractor

我正在从命令运行我的量角器测试 npm run e2e

我想要一种方法,如果我通过,npm run e2e firefox那么我的测试将在 Firefox 浏览器上执行。

或者,如果我运行,npm run e2e chrome那么它应该在 chrome 上运行

如果我都通过了,npm run e2e firefox chrome那么我的测试应该在两个浏览器上并行运行。

是否可以参数化量角器配置文件?

同样,如果我可以通过命令传递测试套件名称,并且它应该只在该特定测试套件下执行测试。

这是我的配置文件,这就是我想要实现的目标:

`//var HtmlReporter = require('protractor-html-screenshot-reporter');

exports.config = {

allScriptsTimeout: 30000,
//Add parameters for browser names
params:{
  pass: {
      browserName : 'chrome',
      testSuitName : 'e2e/TestSuites/_BVT/*.js',
  }
 },  
suites: {    
//Define here List of Sanity Test Scenarios:
  BVT : testSuitName,   
}, 
// configure multiple browsers to run tests
multiCapabilities: [
 shardTestFiles: true,
 maxInstances: 2   
{'browserName': browserName}
],
baseUrl: 'http://mytestUrl/',
 framework: 'jasmine2',
jasmineNodeOpts: {
 defaultTimeoutInterval: 30000
},  
onPrepare: function() {  
var jasmineReporters = require('jasmine-reporters');
browser.driver.manage().window().maximize();
return browser.getProcessedConfig().then(function(config) {   
  var browserName = config.capabilities.browserName;
  var junitReporter = new jasmineReporters.JUnitXmlReporter({
         consolidateAll: true,
         savePath: 'tests/test-results',            
         filePrefix: browserName + '-xmloutput',
         modifySuiteName: function(generatedSuiteName, suite) {             
             return browserName + '.' + generatedSuiteName;
         }              
     });
     jasmine.getEnv().addReporter(junitReporter);
  });    
}, 
resultJsonOutputFile: 'tests/test-results/output.json'    
};`
Run Code Online (Sandbox Code Playgroud)

将不胜感激这方面的任何帮助。
提前致谢。

use*_*259 5

我知道这篇文章现在有点旧了,但是这个解决方案可能会帮助遇到类似问题的人。

使用多个配置文件,每个浏览器类型一个,设置一个基本配置文件,并将其添加到每个其他配置文件中,然后为每个配置文件创建一个 npm 脚本。不需要参数,一切都很好地堆叠。

所以基本配置(称为“protractor_base.js”之类的东西)看起来像:

exports.config = {
  seleniumAddress: 'http://localhost:4444/wd/hub',
  rootElement: '[ng-app]',

  allScriptsTimeout: 60000,

  framework: 'jasmine',

  specs: ['example-spec.js']
};
Run Code Online (Sandbox Code Playgroud)

然后你的其他配置(即“protractor_chrome.conf.js”)看起来像:

protractor = require('./protractor_base.js');
var config = protractor.config;

config.capabilities: {
  'browserName': 'chrome'
};


exports.config = config;
Run Code Online (Sandbox Code Playgroud)

然后你可以指定一个多浏览器配置,只是一个 chrome 配置,等等。