This repository has been archived by the owner on Feb 20, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathkarma.conf.js
90 lines (76 loc) · 1.76 KB
/
karma.conf.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/**
* Import the existing webpack config
*/
var webpackConfigDefault = require('./webpack.config.js');
/**
* Create a function that returns a Karma config function
* where we can choose to pass a custom webpack config to be used
*/
var configureKarma = function(webpackConfig) {
/**
* Default if a webpack config was not passed
*/
var webpackConfig = webpackConfig || webpackConfigDefault;
/**
* Return the Karma config function
*/
return function (config) {
config.set({
/**
* Run tests in Chrome and Firefox
*/
browsers: ['Chrome'],
/**
* Just run once by default
*/
singleRun: true,
/**
* Use the mocha test framework
*/
frameworks: ['mocha'],
/**
* Just load this file (contains a reference to all the tests)
*/
files: [
'./karma.tests.js'
],
/**
* Preprocess with webpack and our sourcemap loader
*/
preprocessors: {
'./karma.tests.js': ['webpack', 'sourcemap']
},
/**
* Report results in this format
*/
reporters: ['mocha'],
/**
* Kind of a copy of your webpack config
*/
webpack: {
devtool: 'inline-source-map',
module: {
loaders: webpackConfig.module.loaders
},
resolve: {
alias: webpackConfig.resolve.alias
},
node: webpackConfig.node
},
/**
* Please don't spam the console when running in karma!
*/
webpackServer: {
noInfo: true
}
});
};
};
/**
* Export the regular Karma config
*/
module.exports = configureKarma();
/**
* Export an extendable version of the Karma config
*/
module.exports.extend = configureKarma;