forked from ucdavis/wayfinding
-
Notifications
You must be signed in to change notification settings - Fork 0
/
karma.conf.js
124 lines (91 loc) · 3.2 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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
'use strict';
module.exports = function (config) {
config.set({
// base path, that will be used to resolve files and exclude
basePath: './',
// frameworks to use
frameworks: ['jasmine'],
// enable / disable watching file and executing tests whenever any file changes
autoWatch: false,
// list of files / patterns to load in the browser
files: [
// include dependencies
'bower_components/jquery/dist/jquery.js',
'bower_components/jasmine-jquery/lib/jasmine-jquery.js',
// include our JavaScript files
'src/jquery.wayfinding.js',
// simple patterns to load the needed testfiles
// equals to {pattern: 'test/*-test.js', watched: true, served: true, included: true}
'test/*-test.js',
{pattern: 'test/**/*.html', included: false, served: true, watched: true},
// fixtures should be served by the webserver but not included on
// the page with <script> tags
{
pattern: 'test/fixtures/*',
included: false,
served: true
}
],
// list of files to exclude
exclude: [
],
preprocessors: {
// disable html2js preprocessor so we can use
// jasmine-jquery fixture loader instead
// https://github.com/karma-runner/karma/issues/788
// '**/*.html': [],
// source files, that you wanna generate coverage for
// do not include tests or libraries
// (these files will be instrumented by Istanbul)
'src/**/*.js': ['coverage']
},
// test results reporter to use
// possible values: 'dots', 'progress', 'junit', 'growl', 'coverage'
reporters: ['progress', 'coverage'],
// configure the html reporter.
// this will output reports in the test/report dir which can be opened
// and viewed in your browser
htmlReporter: {
outputDir: 'test/report',
templatePath: './node_modules/karma-html-reporter/jasmine_template.html' // __dirname+'/jasmine_template.html'
},
// configure the code coverage reporter.
// this will output coverage reports in the test/coverage dir using Istanbul
coverageReporter: {
type: 'html',
dir: 'coverage/'
},
// web server port
port: 9876,
// enable / disable colors in the output (reporters and logs)
colors: true,
// level of logging
// possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
logLevel: config.LOG_INFO,
// Start these browsers, currently available:
// - Chrome
// - ChromeCanary
// - Firefox
// - Opera (has to be installed with `npm install karma-opera-launcher`)
// - Safari (only Mac; has to be installed with `npm install karma-safari-launcher`)
// - PhantomJS
// - IE (only Windows; has to be installed with `npm install karma-ie-launcher`)
browsers: [(process.env.TRAVIS ? 'Firefox' : 'Chrome'), 'PhantomJS'],
// If browser does not capture in given timeout [ms], kill it
captureTimeout: 60000,
// Continuous Integration mode
// if true, it capture browsers, run tests and exit
singleRun: false,
// report which specs are slower than 500ms
// CLI --report-slower-than 500
reportSlowerThan: 500,
plugins: [
'karma-jasmine',
'karma-chrome-launcher',
'karma-phantomjs-launcher',
'karma-firefox-launcher',
'karma-coverage',
'karma-html-reporter'
]
});
};