From aaf26a1364e10049e9e9bfddfb77935de5a8699c Mon Sep 17 00:00:00 2001 From: Alexander Tarmolov Date: Sat, 7 Apr 2018 20:32:03 +0300 Subject: [PATCH] Running --uninstall twice removes the preexisting hooks fixed #53 --- lib/git-hooks.js | 3 +-- tests/uninstall.test.js | 6 +++--- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/lib/git-hooks.js b/lib/git-hooks.js index a2c3977..f7f911c 100644 --- a/lib/git-hooks.js +++ b/lib/git-hooks.js @@ -90,9 +90,8 @@ module.exports = { throw new Error('git-hooks is not installed'); } - fsHelpers.removeDir(hooksPath); - if (fsHelpers.exists(hooksOldPath)) { + fsHelpers.removeDir(hooksPath); fs.renameSync(hooksOldPath, hooksPath); } }, diff --git a/tests/uninstall.test.js b/tests/uninstall.test.js index 25d680a..f15673e 100644 --- a/tests/uninstall.test.js +++ b/tests/uninstall.test.js @@ -38,14 +38,14 @@ describe('--uninstall', function () { }); }); - describe('when git-hooks is installed', function () { + describe('when backup is absent', function () { beforeEach(function () { fsHelpers.makeDir(GIT_HOOKS); }); - it('should remove hooks directory', function () { + it('should not remove hooks directory', function () { gitHooks.uninstall(SANDBOX_PATH); - fsHelpers.exists(GIT_HOOKS).should.be.false; + fsHelpers.exists(GIT_HOOKS).should.be.true; }); });