UT for front-end
文章目录
前段项目的UT一般可以采用karma+jasmine来搭建。jasmine做单元测试,karma自动化完成单元测试。
现在前段项目越来越多的使用webpack进行打包,所以karma-webpack不可或缺。
与此同时,因为webpack会把js打包成一个文件,因此如果要让karma生成coverage report就额外的第三方的js库。
coverage reporter
依赖的package:
- istanbul-instrumenter-loader
- karma-coverage
- karma-remap-coverage
- karma-sourcemap-loader
- karma-webpack
要生成coverage reporter,首先在karma.config.js中设置webpackconfig文件以及remap-converage
1 | module.exports = function (config) { |
在webpack.config.js中配置需要的加载器,例如css-loader, scss-loader, typescript-loader以及istanbul-instrumenter-loader
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
43module.exports = {
devtools: 'inline-source-map',
...,
modules: {
rules: [
...,
/**
* Source map loader support for *.js files
* Extracts SourceMaps for source files that as added as sourceMappingURL comment.
*
* See: https://github.com/webpack/source-map-loader
*/
{
enforce: 'pre',
test: /\.js$/,
loader: 'source-map-loader',
exclude: [
// these packages have problems with their sourcemaps
path.join(basePath, 'node_modules/rxjs'),
path.join(basePath, 'node_modules/@angular')
]
},
/**
* Instruments JS files with Istanbul for subsequent code coverage reporting.
* Instrument only testing sources.
*
* See: https://github.com/deepsweet/istanbul-instrumenter-loader
*/
{
enforce: 'post',
test: /\.(js|ts)$/,
loader: 'istanbul-instrumenter-loader',
include: path.resolve(__dirname, 'path'),
exclude: [
/\.(e2e|spec)\.ts$/,
/node_modules/
]
}
]
},
...
}