Browse Source
A new notation '<branch>@{upstream}' refers to the branch <branch> is set to build on top of. Missing <branch> (i.e. '@{upstream}') defaults to the current branch. This allows you to run, for example, for l in list of local branches do git log --oneline --left-right $l...$l@{upstream} done to inspect each of the local branches you are interested in for the divergence from its upstream. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
Johannes Schindelin
16 years ago
committed by
Junio C Hamano
3 changed files with 109 additions and 3 deletions
@ -0,0 +1,69 @@
@@ -0,0 +1,69 @@
|
||||
#!/bin/sh |
||||
|
||||
test_description='test <branch>@{upstream} syntax' |
||||
|
||||
. ./test-lib.sh |
||||
|
||||
|
||||
test_expect_success 'setup' ' |
||||
|
||||
test_commit 1 && |
||||
git checkout -b side && |
||||
test_commit 2 && |
||||
git checkout master && |
||||
git clone . clone && |
||||
test_commit 3 && |
||||
(cd clone && |
||||
test_commit 4 && |
||||
git branch --track my-side origin/side) |
||||
|
||||
' |
||||
|
||||
full_name () { |
||||
(cd clone && |
||||
git rev-parse --symbolic-full-name "$@") |
||||
} |
||||
|
||||
commit_subject () { |
||||
(cd clone && |
||||
git show -s --pretty=format:%s "$@") |
||||
} |
||||
|
||||
test_expect_success '@{upstream} resolves to correct full name' ' |
||||
test refs/remotes/origin/master = "$(full_name @{upstream})" |
||||
' |
||||
|
||||
test_expect_success '@{u} resolves to correct full name' ' |
||||
test refs/remotes/origin/master = "$(full_name @{u})" |
||||
' |
||||
|
||||
test_expect_success 'my-side@{upstream} resolves to correct full name' ' |
||||
test refs/remotes/origin/side = "$(full_name my-side@{u})" |
||||
' |
||||
|
||||
test_expect_success 'my-side@{u} resolves to correct commit' ' |
||||
git checkout side && |
||||
test_commit 5 && |
||||
(cd clone && git fetch) && |
||||
test 2 = "$(commit_subject my-side)" && |
||||
test 5 = "$(commit_subject my-side@{u})" |
||||
' |
||||
|
||||
test_expect_success 'not-tracking@{u} fails' ' |
||||
test_must_fail full_name non-tracking@{u} && |
||||
(cd clone && git checkout --no-track -b non-tracking) && |
||||
test_must_fail full_name non-tracking@{u} |
||||
' |
||||
|
||||
test_expect_success '<branch>@{u}@{1} resolves correctly' ' |
||||
test_commit 6 && |
||||
(cd clone && git fetch) && |
||||
test 5 = $(commit_subject my-side@{u}@{1}) |
||||
' |
||||
|
||||
test_expect_success '@{u} without specifying branch fails on a detached HEAD' ' |
||||
git checkout HEAD^0 && |
||||
test_must_fail git rev-parse @{u} |
||||
' |
||||
|
||||
test_done |
Loading…
Reference in new issue