Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Newer
Older
100644 174 lines (152 sloc) 4.733 kb
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
1 module.exports = function(config, specificOptions) {
29f96c8 Vojta Jina chore: update karma to 0.9.4
vojtajina authored
2 config.set({
3 frameworks: ['jasmine'],
4 autoWatch: true,
5 logLevel: config.LOG_INFO,
6 logColors: true,
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
7 browsers: ['Chrome'],
751f058 Vojta Jina chore(travis): increase disconnect timeout
vojtajina authored
8 browserDisconnectTimeout: 10000,
4ee0687 Vojta Jina chore(travis): tolerate 2 disconnects to make the build more stable
vojtajina authored
9 browserDisconnectTolerance: 2,
9a81b86 Vojta Jina chore(travis): give browsers more time to respond
vojtajina authored
10 browserNoActivityTimeout: 20000,
475eddf Vojta Jina chore(karma): longer reconnect timeout
vojtajina authored
11
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
12
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
13 // SauceLabs config for local development.
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
14 sauceLabs: {
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
15 testName: specificOptions.testName || 'AngularJS',
ed4a1fd Vojta Jina chore(travis): force the latest version of selenium
vojtajina authored
16 startConnect: true,
17 options: {
18 'selenium-version': '2.37.0'
19 }
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
20 },
21
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
22 // BrowserStack config for local development.
ffd075b Vojta Jina chore(travis): let's give BrowserStack a try
vojtajina authored
23 browserStack: {
b08427d Vojta Jina chore(travis): add some more info for BrowserStack sessions
vojtajina authored
24 project: 'AngularJS',
25 name: specificOptions.testName,
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
26 startTunnel: true,
fd4b999 Vojta Jina chore(travis): increase BrowserStack timeout to 10min
vojtajina authored
27 timeout: 600 // 10min
ffd075b Vojta Jina chore(travis): let's give BrowserStack a try
vojtajina authored
28 },
29
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
30 // For more browsers on Sauce Labs see:
31 // https://saucelabs.com/docs/platforms/webdriver
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
32 customLaunchers: {
33 'SL_Chrome': {
34 base: 'SauceLabs',
35 browserName: 'chrome'
7909ebe Vojta Jina chore: run more browsers on Travis (IE8,IE9,IE10,Safari,FF)
vojtajina authored
36 },
37 'SL_Firefox': {
38 base: 'SauceLabs',
162485d Vojta Jina chore(travis): use FF26
vojtajina authored
39 browserName: 'firefox',
40 version: '26'
7909ebe Vojta Jina chore: run more browsers on Travis (IE8,IE9,IE10,Safari,FF)
vojtajina authored
41 },
42 'SL_Safari': {
43 base: 'SauceLabs',
44 browserName: 'safari',
9693a42 Vojta Jina chore(travis): use Safari 7
vojtajina authored
45 platform: 'OS X 10.9',
46 version: '7'
7909ebe Vojta Jina chore: run more browsers on Travis (IE8,IE9,IE10,Safari,FF)
vojtajina authored
47 },
48 'SL_IE_9': {
49 base: 'SauceLabs',
50 browserName: 'internet explorer',
51 platform: 'Windows 2008',
52 version: '9'
53 },
54 'SL_IE_10': {
55 base: 'SauceLabs',
56 browserName: 'internet explorer',
57 platform: 'Windows 2012',
58 version: '10'
ffd075b Vojta Jina chore(travis): let's give BrowserStack a try
vojtajina authored
59 },
0410572 Vojta Jina chore(travis): define a launcher for IE11 (SauceLabs)
vojtajina authored
60 'SL_IE_11': {
61 base: 'SauceLabs',
62 browserName: 'internet explorer',
63 platform: 'Windows 8.1',
64 version: '11'
65 },
ffd075b Vojta Jina chore(travis): let's give BrowserStack a try
vojtajina authored
66
67 'BS_Chrome': {
68 base: 'BrowserStack',
69 browser: 'chrome',
70 os: 'OS X',
71 os_version: 'Mountain Lion'
72 },
73 'BS_Safari': {
74 base: 'BrowserStack',
75 browser: 'safari',
76 os: 'OS X',
77 os_version: 'Mountain Lion'
78 },
79 'BS_Firefox': {
80 base: 'BrowserStack',
81 browser: 'firefox',
82 os: 'Windows',
83 os_version: '8'
84 },
85 'BS_IE_9': {
86 base: 'BrowserStack',
87 browser: 'ie',
88 browser_version: '9.0',
89 os: 'Windows',
90 os_version: '7'
91 },
92 'BS_IE_10': {
93 base: 'BrowserStack',
94 browser: 'ie',
95 browser_version: '10.0',
96 os: 'Windows',
97 os_version: '8'
98 },
99 'BS_IE_11': {
100 base: 'BrowserStack',
101 browser: 'ie',
102 browser_version: '11.0',
103 os: 'Windows',
104 os_version: '8.1'
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
105 }
106 }
29f96c8 Vojta Jina chore: update karma to 0.9.4
vojtajina authored
107 });
c64a985 Vojta Jina chore: use only polling on Travis/SL
vojtajina authored
108
109
110 if (process.env.TRAVIS) {
338f949 Vojta Jina chore(travis): set SauceLabs build id
vojtajina authored
111 var buildLabel = 'TRAVIS #' + process.env.TRAVIS_BUILD_NUMBER + ' (' + process.env.TRAVIS_BUILD_ID + ')';
112
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
113 config.logLevel = config.LOG_DEBUG;
ddff347 Vojta Jina chore(travis): use only websockets and xhr-polling
vojtajina authored
114 config.transports = ['websocket', 'xhr-polling'];
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
115
338f949 Vojta Jina chore(travis): set SauceLabs build id
vojtajina authored
116 config.browserStack.build = buildLabel;
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
117 config.browserStack.startTunnel = false;
118
338f949 Vojta Jina chore(travis): set SauceLabs build id
vojtajina authored
119 config.sauceLabs.build = buildLabel;
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
120 config.sauceLabs.startConnect = false;
121 config.sauceLabs.tunnelIdentifier = process.env.TRAVIS_JOB_NUMBER;
ddff347 Vojta Jina chore(travis): use only websockets and xhr-polling
vojtajina authored
122
6127528 Vojta Jina chore(travis): switch back to SauceLabs
vojtajina authored
123 // TODO(vojta): remove once SauceLabs supports websockets.
124 // This speeds up the capturing a bit, as browsers don't even try to use websocket.
125 config.transports = ['xhr-polling'];
126
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
127 // Debug logging into a file, that we print out at the end of the build.
128 config.loggers.push({
129 type: 'file',
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
130 filename: process.env.LOGS_DIR + '/' + (specificOptions.logFile || 'karma.log')
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
131 });
c64a985 Vojta Jina chore: use only polling on Travis/SL
vojtajina authored
132 }
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
133
134
135 // Terrible hack to workaround inflexibility of log4js:
136 // - ignore web-server's 404 warnings,
137 // - ignore DEBUG logs (on Travis), we log them into a file instead.
138 var IGNORED_404 = [
139 '/favicon.ico',
140 '/%7B%7BtestUrl%7D%7D',
141 '/someSanitizedUrl',
142 '/{{testUrl}}'
143 ];
144 var log4js = require('./node_modules/karma/node_modules/log4js');
145 var layouts = require('./node_modules/karma/node_modules/log4js/lib/layouts');
146 var originalConfigure = log4js.configure;
147 log4js.configure = function(log4jsConfig) {
148 var consoleAppender = log4jsConfig.appenders.shift();
149 var originalResult = originalConfigure.call(log4js, log4jsConfig);
150 var layout = layouts.layout(consoleAppender.layout.type, consoleAppender.layout);
151
152
153
154 log4js.addAppender(function(log) {
5d6482b Vojta Jina chore(karma): correct the 404 ignoring
vojtajina authored
155 var msg = log.data[0];
156
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
157 // ignore web-server's 404s
158 if (log.categoryName === 'web-server' && log.level.levelStr === config.LOG_WARN &&
5d6482b Vojta Jina chore(karma): correct the 404 ignoring
vojtajina authored
159 IGNORED_404.some(function(ignoredLog) {return msg.indexOf(ignoredLog) !== -1})) {
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
160 return;
161 }
162
163 // on Travis, ignore DEBUG statements
164 if (process.env.TRAVIS && log.level.levelStr === config.LOG_DEBUG) {
165 return;
166 }
167
168 console.log(layout(log));
169 });
170
171 return originalResult;
172 };
29f96c8 Vojta Jina chore: update karma to 0.9.4
vojtajina authored
173 };
Something went wrong with that request. Please try again.