-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
The "--head" option to "git show-ref" was only to add "HEAD" to the list of candidate refs to be filtered by the usual rules (e.g. "--heads" that only show refs under refs/heads). Change the meaning of the option to always show "HEAD" regardless of what filtering will be applied to any other ref (this is a backward incompatible change, so I may need to add an entry to the Release Notes). * db/show-ref-head: show-ref: make --head always show the HEAD ref
- Loading branch information
Showing
3 changed files
with
179 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,167 @@ | ||
#!/bin/sh | ||
|
||
test_description='show-ref' | ||
. ./test-lib.sh | ||
|
||
test_expect_success setup ' | ||
test_commit A && | ||
git tag -f -a -m "annotated A" A && | ||
git checkout -b side && | ||
test_commit B && | ||
git tag -f -a -m "annotated B" B && | ||
git checkout master && | ||
test_commit C && | ||
git branch B A^0 | ||
' | ||
|
||
test_expect_success 'show-ref' ' | ||
echo $(git rev-parse refs/tags/A) refs/tags/A >expect && | ||
git show-ref A >actual && | ||
test_cmp expect actual && | ||
git show-ref tags/A >actual && | ||
test_cmp expect actual && | ||
git show-ref refs/tags/A >actual && | ||
test_cmp expect actual && | ||
>expect && | ||
test_must_fail git show-ref D >actual | ||
test_cmp expect actual | ||
' | ||
|
||
test_expect_success 'show-ref -q' ' | ||
>expect && | ||
git show-ref -q A >actual && | ||
test_cmp expect actual && | ||
git show-ref -q tags/A >actual && | ||
test_cmp expect actual && | ||
git show-ref -q refs/tags/A >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref -q D >actual && | ||
test_cmp expect actual | ||
' | ||
|
||
test_expect_success 'show-ref --verify' ' | ||
echo $(git rev-parse refs/tags/A) refs/tags/A >expect && | ||
git show-ref --verify refs/tags/A >actual && | ||
test_cmp expect actual && | ||
>expect && | ||
test_must_fail git show-ref --verify A >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref --verify tags/A >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref --verify D >actual | ||
test_cmp expect actual | ||
' | ||
|
||
test_expect_success 'show-ref --verify -q' ' | ||
>expect && | ||
git show-ref --verify -q refs/tags/A >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref --verify -q A >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref --verify -q tags/A >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref --verify -q D >actual | ||
test_cmp expect actual | ||
' | ||
|
||
test_expect_success 'show-ref -d' ' | ||
{ | ||
echo $(git rev-parse refs/tags/A) refs/tags/A && | ||
echo $(git rev-parse refs/tags/A^0) "refs/tags/A^{}" | ||
echo $(git rev-parse refs/tags/C) refs/tags/C | ||
} >expect && | ||
git show-ref -d A C >actual && | ||
test_cmp expect actual && | ||
git show-ref -d tags/A tags/C >actual && | ||
test_cmp expect actual && | ||
git show-ref -d refs/tags/A refs/tags/C >actual && | ||
test_cmp expect actual && | ||
echo $(git rev-parse refs/heads/master) refs/heads/master >expect && | ||
git show-ref -d master >actual && | ||
test_cmp expect actual && | ||
git show-ref -d heads/master >actual && | ||
test_cmp expect actual && | ||
git show-ref -d refs/heads/master >actual && | ||
test_cmp expect actual | ||
git show-ref -d --verify refs/heads/master >actual && | ||
test_cmp expect actual | ||
>expect && | ||
test_must_fail git show-ref -d --verify master >actual && | ||
test_cmp expect actual && | ||
test_must_fail git show-ref -d --verify heads/master >actual && | ||
test_cmp expect actual | ||
' | ||
|
||
test_expect_success 'show-ref --heads, --tags, --head, pattern' ' | ||
for branch in B master side | ||
do | ||
echo $(git rev-parse refs/heads/$branch) refs/heads/$branch | ||
done >expect.heads && | ||
git show-ref --heads >actual && | ||
test_cmp expect.heads actual && | ||
for tag in A B C | ||
do | ||
echo $(git rev-parse refs/tags/$tag) refs/tags/$tag | ||
done >expect.tags && | ||
git show-ref --tags >actual && | ||
test_cmp expect.tags actual && | ||
cat expect.heads expect.tags >expect && | ||
git show-ref --heads --tags >actual && | ||
test_cmp expect actual && | ||
{ | ||
echo $(git rev-parse HEAD) HEAD && | ||
cat expect.heads expect.tags | ||
} >expect && | ||
git show-ref --heads --tags --head >actual && | ||
test_cmp expect actual && | ||
{ | ||
echo $(git rev-parse HEAD) HEAD && | ||
echo $(git rev-parse refs/heads/B) refs/heads/B | ||
echo $(git rev-parse refs/tags/B) refs/tags/B | ||
} >expect && | ||
git show-ref --head B >actual && | ||
test_cmp expect actual && | ||
{ | ||
echo $(git rev-parse HEAD) HEAD && | ||
echo $(git rev-parse refs/heads/B) refs/heads/B | ||
echo $(git rev-parse refs/tags/B) refs/tags/B | ||
echo $(git rev-parse refs/tags/B^0) "refs/tags/B^{}" | ||
} >expect && | ||
git show-ref --head -d B >actual && | ||
test_cmp expect actual | ||
' | ||
|
||
test_done |