如何从 gulp-esdoc 内部触发错误

How can I trigger an error from inside gulp-esdoc?

本文关键字:错误 内部 gulp-esdoc      更新时间:2023-09-26

我正在使用gulp-esdoc来生成我的文档(它已经可以工作了)。

今天我添加了一个 git 预提交钩子,它会启动多个 gulp 任务,并在其中一个任务返回错误时阻止任何提交。

为我的大部分任务工作,但对于 gulp-esdoc,我不知道如何返回这样的错误来防止提交。

我以这种方式配置了我的 esdoc:

gulp.task('documentation', function() {
gulp.src("./client/")
    .pipe(esdoc({
        destination: "./docs",
        "title": "SOMETHING",
        index: "./README.md",
        "plugins": [{
            "name": "./README/docplugins/on-complete.js"
        }]
    }));
});

如您所见,一旦生成文档,我正在使用 esdoc 插件来执行一些代码,这是该插件的代码:

var colors = require('colors'),
gutil = require('gulp-util');
exports.onComplete = function(ev) {
    var output = require('../../docs/coverage.json');
    var expectedCoverage = 100; // todo : get from option instead
    var percentCovered = (output.actualCount / output.expectCount) * 100;
    if (percentCovered < expectedCoverage) {
        console.log('Code coverage is not sufficient (expected ' + expectedCoverage + '%, received only ' + percentCovered + '%) !!! Write some documentation or get out !'.red);
        // return false; // todo
    } else {
        console.log('Code coverage is complete, well done :)'.green);
        // return true;
    }
};

这里的主要目标是如果我的代码文档不是 100% 覆盖,则返回错误(代码逻辑正常工作,如果我的 JS 代码中缺少注释,我会使用"todo"进入行。

最后,这是我的(简化的)git-hook(在我的gulpfile中):

gulp.task('pre-commit', function () {
    gulp.start('lint');
    gulp.start('documentation');
});

"lint"部分有效,如果我的代码中有错误,它会阻止提交。但是使用 gulp-esdoc 的"文档"代码不会返回任何错误,因此提交:(我不知道该怎么做才能返回错误并阻止 git 提交。

我需要这样做,因为我希望加入我团队的初级开发人员被迫记录他们的代码:p

感谢您的帮助!

一种选择是抛出一个PluginError

throw new gutil.PluginError('esdoc', 'Something broke');

这将导致您的 gulp 进程以非零退出代码退出。然而,它会在STDERR上留下一个相当丑陋的堆栈痕迹(特别是因为gulp-esdoc从插件中重新抛出错误)。

另一种选择是使用特定的退出代码显式退出进程:

process.exit(1);

Node.js 中的process对象是一个全局对象,可以从任何地方访问,而无需require()它。