Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Newer
Older
100644 187 lines (165 sloc) 5.042 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_8': {
49 base: 'SauceLabs',
50 browserName: 'internet explorer',
51 platform: 'Windows 7',
52 version: '8'
53 },
54 'SL_IE_9': {
55 base: 'SauceLabs',
56 browserName: 'internet explorer',
57 platform: 'Windows 2008',
58 version: '9'
59 },
60 'SL_IE_10': {
61 base: 'SauceLabs',
62 browserName: 'internet explorer',
63 platform: 'Windows 2012',
64 version: '10'
ffd075b Vojta Jina chore(travis): let's give BrowserStack a try
vojtajina authored
65 },
0410572 Vojta Jina chore(travis): define a launcher for IE11 (SauceLabs)
vojtajina authored
66 'SL_IE_11': {
67 base: 'SauceLabs',
68 browserName: 'internet explorer',
69 platform: 'Windows 8.1',
70 version: '11'
71 },
ffd075b Vojta Jina chore(travis): let's give BrowserStack a try
vojtajina authored
72
73 'BS_Chrome': {
74 base: 'BrowserStack',
75 browser: 'chrome',
76 os: 'OS X',
77 os_version: 'Mountain Lion'
78 },
79 'BS_Safari': {
80 base: 'BrowserStack',
81 browser: 'safari',
82 os: 'OS X',
83 os_version: 'Mountain Lion'
84 },
85 'BS_Firefox': {
86 base: 'BrowserStack',
87 browser: 'firefox',
88 os: 'Windows',
89 os_version: '8'
90 },
91 'BS_IE_8': {
92 base: 'BrowserStack',
93 browser: 'ie',
94 browser_version: '8.0',
95 os: 'Windows',
96 os_version: '7'
97 },
98 'BS_IE_9': {
99 base: 'BrowserStack',
100 browser: 'ie',
101 browser_version: '9.0',
102 os: 'Windows',
103 os_version: '7'
104 },
105 'BS_IE_10': {
106 base: 'BrowserStack',
107 browser: 'ie',
108 browser_version: '10.0',
109 os: 'Windows',
110 os_version: '8'
111 },
112 'BS_IE_11': {
113 base: 'BrowserStack',
114 browser: 'ie',
115 browser_version: '11.0',
116 os: 'Windows',
117 os_version: '8.1'
33223e2 Vojta Jina chore: set up Sauce Labs with Travis
vojtajina authored
118 }
119 }
29f96c8 Vojta Jina chore: update karma to 0.9.4
vojtajina authored
120 });
c64a985 Vojta Jina chore: use only polling on Travis/SL
vojtajina authored
121
122
123 if (process.env.TRAVIS) {
338f949 Vojta Jina chore(travis): set SauceLabs build id
vojtajina authored
124 var buildLabel = 'TRAVIS #' + process.env.TRAVIS_BUILD_NUMBER + ' (' + process.env.TRAVIS_BUILD_ID + ')';
125
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
126 config.logLevel = config.LOG_DEBUG;
ddff347 Vojta Jina chore(travis): use only websockets and xhr-polling
vojtajina authored
127 config.transports = ['websocket', 'xhr-polling'];
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
128
338f949 Vojta Jina chore(travis): set SauceLabs build id
vojtajina authored
129 config.browserStack.build = buildLabel;
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
130 config.browserStack.startTunnel = false;
131
338f949 Vojta Jina chore(travis): set SauceLabs build id
vojtajina authored
132 config.sauceLabs.build = buildLabel;
7615723 Vojta Jina chore: make it simpler to run tests on SL/BS during local development
vojtajina authored
133 config.sauceLabs.startConnect = false;
134 config.sauceLabs.tunnelIdentifier = process.env.TRAVIS_JOB_NUMBER;
ddff347 Vojta Jina chore(travis): use only websockets and xhr-polling
vojtajina authored
135
6127528 Vojta Jina chore(travis): switch back to SauceLabs
vojtajina authored
136 // TODO(vojta): remove once SauceLabs supports websockets.
137 // This speeds up the capturing a bit, as browsers don't even try to use websocket.
138 config.transports = ['xhr-polling'];
139
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
140 // Debug logging into a file, that we print out at the end of the build.
141 config.loggers.push({
142 type: 'file',
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
143 filename: process.env.LOGS_DIR + '/' + (specificOptions.logFile || 'karma.log')
80d0f98 Vojta Jina chore(travis): clean up logs
vojtajina authored
144 });
c64a985 Vojta Jina chore: use only polling on Travis/SL
vojtajina authored
145 }
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
146
147
148 // Terrible hack to workaround inflexibility of log4js:
149 // - ignore web-server's 404 warnings,
150 // - ignore DEBUG logs (on Travis), we log them into a file instead.
151 var IGNORED_404 = [
152 '/favicon.ico',
153 '/%7B%7BtestUrl%7D%7D',
154 '/someSanitizedUrl',
155 '/{{testUrl}}'
156 ];
157 var log4js = require('./node_modules/karma/node_modules/log4js');
158 var layouts = require('./node_modules/karma/node_modules/log4js/lib/layouts');
159 var originalConfigure = log4js.configure;
160 log4js.configure = function(log4jsConfig) {
161 var consoleAppender = log4jsConfig.appenders.shift();
162 var originalResult = originalConfigure.call(log4js, log4jsConfig);
163 var layout = layouts.layout(consoleAppender.layout.type, consoleAppender.layout);
164
165
166
167 log4js.addAppender(function(log) {
5d6482b Vojta Jina chore(karma): correct the 404 ignoring
vojtajina authored
168 var msg = log.data[0];
169
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
170 // ignore web-server's 404s
171 if (log.categoryName === 'web-server' && log.level.levelStr === config.LOG_WARN &&
5d6482b Vojta Jina chore(karma): correct the 404 ignoring
vojtajina authored
172 IGNORED_404.some(function(ignoredLog) {return msg.indexOf(ignoredLog) !== -1})) {
09271a8 Vojta Jina chore(travis): ignore 404 warnings, debug log into file
vojtajina authored
173 return;
174 }
175
176 // on Travis, ignore DEBUG statements
177 if (process.env.TRAVIS && log.level.levelStr === config.LOG_DEBUG) {
178 return;
179 }
180
181 console.log(layout(log));
182 });
183
184 return originalResult;
185 };
29f96c8 Vojta Jina chore: update karma to 0.9.4
vojtajina authored
186 };
Something went wrong with that request. Please try again.