From 783237574169abadb236353aa397f96a84431e47 Mon Sep 17 00:00:00 2001 From: Scott Johnson Date: Sat, 20 Jun 2015 11:54:20 -0500 Subject: [PATCH] (#38): Don't prompt for deletion if there aren't any branches to delete. --- src/gitsweep/cli.py | 33 +++++++++++++++++---------------- src/gitsweep/tests/test_cli.py | 16 ++++++++++++++-- 2 files changed, 31 insertions(+), 18 deletions(-) diff --git a/src/gitsweep/cli.py b/src/gitsweep/cli.py index 6b995b5..0912e5b 100644 --- a/src/gitsweep/cli.py +++ b/src/gitsweep/cli.py @@ -140,22 +140,23 @@ def _sweep(self): deleter = Deleter(repo, remote_name=remote_name, master_branch=master_branch) - if not args.force: - sys.stdout.write('\nDelete these branches? (y/n) ') - answer = raw_input() - if args.force or answer.lower().startswith('y'): - sys.stdout.write('\n') - for ref in ok_to_delete: - sys.stdout.write(' deleting {0}'.format(ref.remote_head)) - deleter.remove_remote_refs([ref]) - sys.stdout.write(' (done)\n') - - sys.stdout.write('\nAll done!\n') - sys.stdout.write('\nTell everyone to run `git fetch --prune` ' - 'to sync with this remote.\n') - sys.stdout.write('(you don\'t have to, yours is synced)\n') - else: - sys.stdout.write('\nOK, aborting.\n') + if ok_to_delete: + if not args.force: + sys.stdout.write('\nDelete these branches? (y/n) ') + answer = raw_input() + if args.force or answer.lower().startswith('y'): + sys.stdout.write('\n') + for ref in ok_to_delete: + sys.stdout.write(' deleting {0}'.format(ref.remote_head)) + deleter.remove_remote_refs([ref]) + sys.stdout.write(' (done)\n') + + sys.stdout.write('\nAll done!\n') + sys.stdout.write('\nTell everyone to run `git fetch --prune` ' + 'to sync with this remote.\n') + sys.stdout.write('(you don\'t have to, yours is synced)\n') + else: + sys.stdout.write('\nOK, aborting.\n') elif ok_to_delete: # Replace the first argument with cleanup sysv_copy = self.args[:] diff --git a/src/gitsweep/tests/test_cli.py b/src/gitsweep/tests/test_cli.py index 9ddd6ce..9948a91 100644 --- a/src/gitsweep/tests/test_cli.py +++ b/src/gitsweep/tests/test_cli.py @@ -126,7 +126,7 @@ def test_will_preview_none_found(self): def test_will_cleanup(self): """ - Will preview the proposed deletes. + Will cleanup the proposed deletes. """ for i in range(1, 6): self.command('git checkout -b branch{0}'.format(i)) @@ -164,7 +164,7 @@ def test_will_cleanup(self): def test_will_abort_cleanup(self): """ - Will preview the proposed deletes. + Will abort cleanup on user request """ for i in range(1, 6): self.command('git checkout -b branch{0}'.format(i)) @@ -252,3 +252,15 @@ def test_will_force_clean(self): Tell everyone to run `git fetch --prune` to sync with this remote. (you don't have to, yours is synced) ''', stdout) + + def test_cleanup_no_branches_found(self): + """ + Will not prompt user if no branches are found that can be cleaned up + """ + (retcode, stdout, stderr) = self.gscommand('git-sweep cleanup --force') + + self.assertResults(''' + Fetching from the remote + No remote branches are available for cleaning up + ''', stdout) +