module.exports = function(config, specificOptions) { config.set({ frameworks: ['jasmine'], autoWatch: true, logLevel: config.LOG_INFO, logColors: true, browsers: ['Chrome'], browserDisconnectTimeout: 10000, browserDisconnectTolerance: 2, browserNoActivityTimeout: 20000, // SauceLabs config for local development. sauceLabs: { testName: specificOptions.testName || 'AngularJS', startConnect: true, options: { 'selenium-version': '2.37.0' } }, // BrowserStack config for local development. browserStack: { project: 'AngularJS', name: specificOptions.testName, startTunnel: true, timeout: 600 // 10min }, // For more browsers on Sauce Labs see: // https://saucelabs.com/docs/platforms/webdriver customLaunchers: { 'SL_Chrome': { base: 'SauceLabs', browserName: 'chrome' }, 'SL_Firefox': { base: 'SauceLabs', browserName: 'firefox', version: '26' }, 'SL_Safari': { base: 'SauceLabs', browserName: 'safari', platform: 'OS X 10.9', version: '7' }, 'SL_IE_9': { base: 'SauceLabs', browserName: 'internet explorer', platform: 'Windows 2008', version: '9' }, 'SL_IE_10': { base: 'SauceLabs', browserName: 'internet explorer', platform: 'Windows 2012', version: '10' }, 'SL_IE_11': { base: 'SauceLabs', browserName: 'internet explorer', platform: 'Windows 8.1', version: '11' }, 'BS_Chrome': { base: 'BrowserStack', browser: 'chrome', os: 'OS X', os_version: 'Mountain Lion' }, 'BS_Safari': { base: 'BrowserStack', browser: 'safari', os: 'OS X', os_version: 'Mountain Lion' }, 'BS_Firefox': { base: 'BrowserStack', browser: 'firefox', os: 'Windows', os_version: '8' }, 'BS_IE_9': { base: 'BrowserStack', browser: 'ie', browser_version: '9.0', os: 'Windows', os_version: '7' }, 'BS_IE_10': { base: 'BrowserStack', browser: 'ie', browser_version: '10.0', os: 'Windows', os_version: '8' }, 'BS_IE_11': { base: 'BrowserStack', browser: 'ie', browser_version: '11.0', os: 'Windows', os_version: '8.1' } } }); if (process.env.TRAVIS) { var buildLabel = 'TRAVIS #' + process.env.TRAVIS_BUILD_NUMBER + ' (' + process.env.TRAVIS_BUILD_ID + ')'; config.logLevel = config.LOG_DEBUG; config.transports = ['websocket', 'xhr-polling']; config.browserStack.build = buildLabel; config.browserStack.startTunnel = false; config.sauceLabs.build = buildLabel; config.sauceLabs.startConnect = false; config.sauceLabs.tunnelIdentifier = process.env.TRAVIS_JOB_NUMBER; // TODO(vojta): remove once SauceLabs supports websockets. // This speeds up the capturing a bit, as browsers don't even try to use websocket. config.transports = ['xhr-polling']; // Debug logging into a file, that we print out at the end of the build. config.loggers.push({ type: 'file', filename: process.env.LOGS_DIR + '/' + (specificOptions.logFile || 'karma.log') }); } // Terrible hack to workaround inflexibility of log4js: // - ignore web-server's 404 warnings, // - ignore DEBUG logs (on Travis), we log them into a file instead. var IGNORED_404 = [ '/favicon.ico', '/%7B%7BtestUrl%7D%7D', '/someSanitizedUrl', '/{{testUrl}}' ]; var log4js = require('./node_modules/karma/node_modules/log4js'); var layouts = require('./node_modules/karma/node_modules/log4js/lib/layouts'); var originalConfigure = log4js.configure; log4js.configure = function(log4jsConfig) { var consoleAppender = log4jsConfig.appenders.shift(); var originalResult = originalConfigure.call(log4js, log4jsConfig); var layout = layouts.layout(consoleAppender.layout.type, consoleAppender.layout); log4js.addAppender(function(log) { var msg = log.data[0]; // ignore web-server's 404s if (log.categoryName === 'web-server' && log.level.levelStr === config.LOG_WARN && IGNORED_404.some(function(ignoredLog) {return msg.indexOf(ignoredLog) !== -1})) { return; } // on Travis, ignore DEBUG statements if (process.env.TRAVIS && log.level.levelStr === config.LOG_DEBUG) { return; } console.log(layout(log)); }); return originalResult; }; };