我有以下gulp-git任务,几乎是这里提供的任务示例的副本https://www.npmjs.com/package/gulp-git
/**
* Checkout production build branch.
*/
gulp.task('checkout-dist', function(){
git.checkout('dist', function (err) {
if (err) throw err;
});
});
/**
* Checkout pre production build branch.
*/
gulp.task('checkout-stage', function(){
git.checkout('stage', function (err) {
if (err) throw err;
});
});
/**
* Push production build branch.
*/
gulp.task('push-dist', ['checkout-dist'], function(){
git.push('origin', 'dist', {args: " -f"}, function (err) {
if (err) throw err;
});
});
/**
* Push pre production build branch.
*/
gulp.task('push-stage', ['checkout-stage'], function(){
git.push('origin', 'stage', {args: " -f"}, function (err) {
if (err) throw err;
});
});
/**
* Push production and pre production branches.
*/
gulp.task('deploy-remote', ['push-stage', 'push-dist'], function(){
git.checkout('master', function(err) {
if (err) throw err;
});
});
逻辑很简单,检查分支并将其推送到远程原点。
当我使用gulp push-stage或gulp push-dist单独运行任务时,它们工作正常。
但是我想同时推送stage和dist,所以我创建了一个名为deploy-remote的新任务。 该任务有效,它将提交推送到原始仓库,但它最终崩溃:
[17:18:56] Starting 'checkout-stage'...
[17:18:56] Finished 'checkout-stage' after 12 ms
[17:18:56] Starting 'push-stage'...
[17:18:56] Finished 'push-stage' after 9.41 ms
[17:18:56] Starting 'checkout-dist'...
[17:18:56] Finished 'checkout-dist' after 14 ms
[17:18:56] Starting 'push-dist'...
[17:18:56] Finished 'push-dist' after 14 ms
[17:18:56] Starting 'deploy-remote'...
[17:18:56] Finished 'deploy-remote' after 12 ms
gulpfile.js:483
if (err) throw err;
^
Error: Command failed: fatal: Unable to create '.git/index.lock': The file already exists.
If no other git process is currently running, this probably means a
git process crashed in this repository earlier. Make sure no other git
process is running and remove the file manually to continue.
at ChildProcess.exithandler (child_process.js:658:15)
at ChildProcess.emit (events.js:98:17)
at maybeClose (child_process.js:766:16)
at Socket.<anonymous> (child_process.js:979:11)
at Socket.emit (events.js:95:17)
at Pipe.close (net.js:466:12)
应该如何实现?
答案 0 :(得分:2)
首先,这些git操作都是异步的。这意味着你必须通过调用回调函数cb
来告诉gulp。例如:
gulp.task('push-dist', ['checkout-dist'], function(cb) {
git.push('origin', 'dist', {args: " -f"}, function (err) {
cb(err);
});
});
其次,你不能同时在同一个仓库上运行两个git进程,这就是你正在做的事情。每个git进程都会创建一个.git/index.lock
文件,以防止其他git进程访问同一个存储库。
您必须使用run-sequence
:
var runSequence = require('run-sequence');
gulp.task('checkout-master', function(cb) {
git.checkout('master', function(err) {
cb(err);
});
});
gulp.task('deploy-remote',, function(cb) {
runSequence('push-stage', 'push-dist', 'checkout-master', cb);
});