Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

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