Как я могу использовать Gulp, чтобы показать тестовое покрытие, используя gulp-mocha
Пожалуйста, дом, я перенес мой код с es6 на es5, используя gulp в качестве бегуна задач. Я сделал свой отчет о покрытии с Стамбулом. Он не показывает тестовое покрытие после его настройки. ниже мой код
import gulp from 'gulp';
import loadPlugins from 'gulp-load-plugins';
import path from 'path';
import mocha from 'gulp-mocha';
import exit from 'gulp-exit';
import coveralls from 'gulp-coveralls';
import cover from 'gulp-coverage';
Загрузите плагины gulp в plugins
переменная
const plugins = loadPlugins();
gulp.task('tests', () => {
gulp.src('./server/tests/*.js')
.pipe(plugins.babel())
.pipe(mocha())
.pipe(exit());
});
Скомпилируйте весь Babel Javascript в ES5 и поместите в папку dist
const paths = {
js: ['./**/*.js', '!dist/**', '!node_modules/**']
};
Скомпилируйте весь Babel Javascript в ES5 и поместите его в дистрибутив
gulp.task('babel', () =>
gulp.src(paths.js, { base: '.' })
.pipe(plugins.babel())
.pipe(gulp.dest('dist'))
);
gulp.task('coverage', () => {
gulp.src('server/test/**/*.js', { read: false })
.pipe(cover.instrument({
pattern: ['server/controllers/**/*.js'],
debugDirectory: 'debug'
}))
.pipe(mocha())
.pipe(cover.gather())
.pipe(cover.format())
.pipe(gulp.dest('reports'));
});
gulp.task('coveralls', () => gulp.src('./coverage/lcov')
.pipe(coveralls()));
Перезапускать сервер при каждом изменении файла
gulp.task('nodemon', ['babel'], () =>
plugins.nodemon({
script: path.join('dist', 'index.js'),
ignore: ['README.md', 'node_modules/**/*.js', 'dist/**/*.js'],
ext: 'js',
tasks: ['babel']
})
);
gulp.task('test', ['tests']);
gulp.task('default', ['nodemon']);
gulp.task('production', ['babel']);
1 ответ
Решение
Следующие фрагменты показывают, как я решил эту проблему с небольшой модификацией.
поместите следующий код в ваш gulpfile
import gulp from 'gulp';
import loadPlugins from 'gulp-load-plugins';
import path from 'path';
import shell from 'gulp-shell';
// Load the gulp plugins into the `plugins` variable
const plugins = loadPlugins();
// Compile all Babel Javascript into ES5 and place in dist folder
const paths = {
js: ['./**/*.js', '!dist/**', '!node_modules/**',
'!./server/tests/**']
};
// Compile all Babel Javascript into ES5 and put it into the dist dir
gulp.task('babel', () =>
gulp.src(paths.js, { base: '.' })
.pipe(plugins.babel())
.pipe(gulp.dest('dist'))
);
gulp.task('migrate', shell.task([
'cross-env NODE_ENV=test sequelize db:migrate',
]));
gulp.task('coverage', shell.task([
'cross-env NODE_ENV=test nyc mocha ./server/test/**/*.js',
]));
// Restart server with on every changes made to file
gulp.task('nodemon', ['babel'], () =>
plugins.nodemon({
script: path.join('dist', 'index.js'),
ignore: ['README.md', 'node_modules/**/*.js', 'dist/**/*.js'],
ext: 'js',
tasks: ['babel']
})
);
gulp.task('test', ['migrate', 'coverage']);
gulp.task('default', ['nodemon']);
gulp.task('production', ['babel']);
затем перейдите к вашему package.json, затем добавьте следующее
"nyc": {
"require": [
"babel-register"
],
"reporter": [
"lcov",
"text",
"html"
],
"sourceMap": false,
"instrument": false,
"exclude": [
"the test file you want to exclude from coverage"
]
}
абсолютно сделано