t2024: Add tests verifying current DWIM behavior of 'git checkout <branch>'
The DWIM mode of checkout allows you to run "git checkout foo" when there is no existing local ref or path called "foo", and there is exactly one remote with a remote-tracking branch called "foo". Git will then automatically create a new local branch called "foo" using the remote-tracking "foo" as its starting point and configured upstream. Improved-by: Jonathan Nieder <jrnieder@gmail.com> Signed-off-by: Johan Herland <johan@herland.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
d2949c7b3c
commit
399e4a1c56
99
t/t2024-checkout-dwim.sh
Executable file
99
t/t2024-checkout-dwim.sh
Executable file
@ -0,0 +1,99 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
test_description='checkout <branch>
|
||||||
|
|
||||||
|
Ensures that checkout on an unborn branch does what the user expects'
|
||||||
|
|
||||||
|
. ./test-lib.sh
|
||||||
|
|
||||||
|
# Is the current branch "refs/heads/$1"?
|
||||||
|
test_branch () {
|
||||||
|
printf "%s\n" "refs/heads/$1" >expect.HEAD &&
|
||||||
|
git symbolic-ref HEAD >actual.HEAD &&
|
||||||
|
test_cmp expect.HEAD actual.HEAD
|
||||||
|
}
|
||||||
|
|
||||||
|
# Is branch "refs/heads/$1" set to pull from "$2/$3"?
|
||||||
|
test_branch_upstream () {
|
||||||
|
printf "%s\n" "$2" "refs/heads/$3" >expect.upstream &&
|
||||||
|
{
|
||||||
|
git config "branch.$1.remote" &&
|
||||||
|
git config "branch.$1.merge"
|
||||||
|
} >actual.upstream &&
|
||||||
|
test_cmp expect.upstream actual.upstream
|
||||||
|
}
|
||||||
|
|
||||||
|
test_expect_success 'setup' '
|
||||||
|
git init repo_a &&
|
||||||
|
(
|
||||||
|
cd repo_a &&
|
||||||
|
test_commit a_master &&
|
||||||
|
git checkout -b foo &&
|
||||||
|
test_commit a_foo &&
|
||||||
|
git checkout -b bar &&
|
||||||
|
test_commit a_bar
|
||||||
|
) &&
|
||||||
|
git init repo_b &&
|
||||||
|
(
|
||||||
|
cd repo_b &&
|
||||||
|
test_commit b_master &&
|
||||||
|
git checkout -b foo &&
|
||||||
|
test_commit b_foo &&
|
||||||
|
git checkout -b baz &&
|
||||||
|
test_commit b_baz
|
||||||
|
) &&
|
||||||
|
git remote add repo_a repo_a &&
|
||||||
|
git remote add repo_b repo_b &&
|
||||||
|
git config remote.repo_b.fetch \
|
||||||
|
"+refs/heads/*:refs/remotes/other_b/*" &&
|
||||||
|
git fetch --all
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'checkout of non-existing branch fails' '
|
||||||
|
git checkout -B master &&
|
||||||
|
test_might_fail git branch -D xyzzy &&
|
||||||
|
|
||||||
|
test_must_fail git checkout xyzzy &&
|
||||||
|
test_must_fail git rev-parse --verify refs/heads/xyzzy &&
|
||||||
|
test_branch master
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'checkout of branch from multiple remotes fails' '
|
||||||
|
git checkout -B master &&
|
||||||
|
test_might_fail git branch -D foo &&
|
||||||
|
|
||||||
|
test_must_fail git checkout foo &&
|
||||||
|
test_must_fail git rev-parse --verify refs/heads/foo &&
|
||||||
|
test_branch master
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'checkout of branch from a single remote succeeds #1' '
|
||||||
|
git checkout -B master &&
|
||||||
|
test_might_fail git branch -D bar &&
|
||||||
|
|
||||||
|
git checkout bar &&
|
||||||
|
test_branch bar &&
|
||||||
|
test_cmp_rev remotes/repo_a/bar HEAD &&
|
||||||
|
test_branch_upstream bar repo_a bar
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success 'checkout of branch from a single remote succeeds #2' '
|
||||||
|
git checkout -B master &&
|
||||||
|
test_might_fail git branch -D baz &&
|
||||||
|
|
||||||
|
git checkout baz &&
|
||||||
|
test_branch baz &&
|
||||||
|
test_cmp_rev remotes/other_b/baz HEAD &&
|
||||||
|
test_branch_upstream baz repo_b baz
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success '--no-guess suppresses branch auto-vivification' '
|
||||||
|
git checkout -B master &&
|
||||||
|
test_might_fail git branch -D bar &&
|
||||||
|
|
||||||
|
test_must_fail git checkout --no-guess bar &&
|
||||||
|
test_must_fail git rev-parse --verify refs/heads/bar &&
|
||||||
|
test_branch master
|
||||||
|
'
|
||||||
|
|
||||||
|
test_done
|
Loading…
Reference in New Issue
Block a user