diff options
author | Johannes Schindelin <Johannes.Schindelin@gmx.de> | 2009-01-16 13:52:53 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-01-17 22:01:37 -0800 |
commit | f0298cf1c6a7b5cc8b79d84a03b0ce07df2d9e6b (patch) | |
tree | 175e8320de176634d0eb695c56c6e8ebf056d50a /t/t6014-rev-list-all.sh | |
parent | bf474e2402e51843e8230c064da6ccfdf3a8ff54 (diff) | |
download | git-f0298cf1c6a7b5cc8b79d84a03b0ce07df2d9e6b.tar.gz |
revision walker: include a detached HEAD in --all
When HEAD is detached, --all should list it, too, logically, as a
detached HEAD is by definition a temporary, unnamed branch.
It is especially necessary to list it when garbage collecting, as
the detached HEAD would be trashed.
Noticed by Thomas Rast.
Note that this affects creating bundles with --all; I contend that it
is a good change to add the HEAD, so that cloning from such a bundle
will give you a current branch. However, I had to fix t5701 as it
assumed that --all does not imply HEAD.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t6014-rev-list-all.sh')
-rwxr-xr-x | t/t6014-rev-list-all.sh | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/t/t6014-rev-list-all.sh b/t/t6014-rev-list-all.sh new file mode 100755 index 0000000000..991ab4a65b --- /dev/null +++ b/t/t6014-rev-list-all.sh @@ -0,0 +1,38 @@ +#!/bin/sh + +test_description='--all includes detached HEADs' + +. ./test-lib.sh + + +commit () { + test_tick && + echo $1 > foo && + git add foo && + git commit -m "$1" +} + +test_expect_success 'setup' ' + + commit one && + commit two && + git checkout HEAD^ && + commit detached + +' + +test_expect_success 'rev-list --all lists detached HEAD' ' + + test 3 = $(git rev-list --all | wc -l) + +' + +test_expect_success 'repack does not lose detached HEAD' ' + + git gc && + git prune --expire=now && + git show HEAD + +' + +test_done |