Git has a lot of hooks for client and server side but the most used and known hook is pre-commit, where you can run some validations (like linters) and cancel a commit if something fails. Gilp is a tool to define (using gulp tasks), install and run hooks.
There are 2 main reasons:
-
The regular pre-commit hook managers run using the local file's content instead of git staged content. Gulp comes with
vinyl
, a virtual file format where we can create an in-memory version of a file to use as content for the tasks. Likegulp.src
, we created a new stream provider for that:srcFromStaged
. If we need to run the same tools but over acommit
,branch
ortag
instead (e.g. in a CI), you can do it usingsrcFromCommit
without acheckout
. -
Gulp is plenty of plugins ready to use, just check it.
We recommend to use yarn
instead of npm
because the error report is less verbose
when gulp
returns a non-zero code (on error) so we can focus on the "real" error.
yarn add --dev gilp
You can use any gulp or gilp plugin.
const gulp = require('gulp');
const eslint = require('gulp-eslint');
const gilp = require('gilp')(gulp);
gilp.hook('pre-commit', function () {
return gilp.srcFromStaged(['**/*.js'])
.pipe(eslint())
.pipe(eslint.failAfterError());
});
** Get a stream of files to be committed: **
gilp.srcFromStaged();
** Get a stream of files from a commit: **
gilp.srcFromCommit('e3bca34');
yarn run gulp gilp-install
To auto-install the hooks after yarn
installation, add in your package.json
the
following postinstall
command:
{
// ...
"scripts": {
// ...
"gulp": "gulp",
"postinstall": "gulp gilp-install"
},
// ...
}
const gulp = require('gulp');
const eslint = require('gulp-eslint');
const gilp = require('gilp')(gulp);
gulp.task('check-commit', function () {
return gilp.srcFromCommit('e3bca34', ['**/*.js'])
.pipe(eslint())
.pipe(eslint.failAfterError());
});
See full working example.
Gilp is Copyright (c) 2016 sophilabs, inc. It is free software, and may be redistributed under the terms specified in the license file.
Gilp is maintained and funded by sophilabs, inc. The names and logos for sophilabs are trademarks of sophilabs, inc.