summaryrefslogtreecommitdiff
path: root/t
diff options
context:
space:
mode:
authorDave Olszewski <cxreg@pobox.com>2010-03-14 21:48:22 -0700
committerJunio C Hamano <gitster@pobox.com>2010-03-14 23:08:09 -0700
commit2ec33cdd19bd80308fcef45828e37e79c4b56dc5 (patch)
treeb6349412abf63f39f70dc2fb4c262d72b4f86d23 /t
parent3a27f415dfa46bd9e5b693abcac708903d3134f4 (diff)
downloadgit-2ec33cdd19bd80308fcef45828e37e79c4b56dc5.tar.gz
rebase--interactive: don't require what's rebased to be a branch
git rebase allows you to specify a non-branch commit-ish as the "branch" argument, which leaves HEAD detached when it's finished. This is occasionally useful, and this patch brings the same functionality to git rebase --interactive. Signed-off-by: Dave Olszewski <cxreg@pobox.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't')
-rwxr-xr-xt/t3404-rebase-interactive.sh9
1 files changed, 9 insertions, 0 deletions
diff --git a/t/t3404-rebase-interactive.sh b/t/t3404-rebase-interactive.sh
index 4e3513709e..05708c2462 100755
--- a/t/t3404-rebase-interactive.sh
+++ b/t/t3404-rebase-interactive.sh
@@ -553,4 +553,13 @@ test_expect_success 'reword' '
git show HEAD~2 | grep "C changed"
'
+test_expect_success 'rebase while detaching HEAD' '
+ git symbolic-ref HEAD &&
+ grandparent=$(git rev-parse HEAD~2) &&
+ test_tick &&
+ FAKE_LINES="2 1" git rebase -i HEAD~2 HEAD^0 &&
+ test $grandparent = $(git rev-parse HEAD~2) &&
+ test_must_fail git symbolic-ref HEAD
+'
+
test_done