forked from ml5js/ml5-library
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkarma.conf.js
83 lines (82 loc) · 2.05 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
const path = require("path");
module.exports = config => {
config.set({
client: {
model: config.model,
jasmine: {
random: false,
},
},
frameworks: ["jasmine"],
files: [
"src/index.js",
`src/${config.model ? config.model : "**"}/*_test.js`,
`src/${config.model ? config.model : "**"}/**/*_test.js`,
],
preprocessors: {
"src/index.js": ["webpack"],
},
webpack: {
// TODO: This is duplication of the webpack.common.babel.js file, but they
// use different import syntaxes so it's not easy to just require it here.
// Maybe this could be put into a JSON file, but the include in the module
// rules is dynamic.
entry: ["babel-polyfill", "./src/index.js"],
output: {
libraryTarget: "umd",
filename: "ml5.js",
library: "ml5",
},
module: {
rules: [
{
enforce: "pre",
test: /\.js$/,
exclude: /node_modules/,
loader: "eslint-loader",
},
{
test: /\.js$/,
loader: "babel-loader",
include: path.resolve(__dirname, "src"),
},
],
},
// Don't minify the webpack build for better stack traces
optimization: {
minimize: false,
},
node: {
fs: "empty",
},
},
webpackMiddleware: {
noInfo: true,
stats: "errors-only",
},
browserStack: {
username: process.env.BROWSERSTACK_USERNAME,
accessKey: process.env.BROWSERSTACK_ACCESS_KEY,
},
captureTimeout: 500000,
reportSlowerThan: 500,
browserNoActivityTimeout: 500000,
customLaunchers: {
bs_chrome_mac: {
base: "BrowserStack",
browser: "chrome",
browser_version: "latest",
os: "OS X",
os_version: "Mojave",
},
},
reporters: ["mocha"],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ["Chrome"],
singleRun: false,
concurrency: Infinity,
});
};