Squashed 'third_party/git/' content from commit cb71568594
git-subtree-dir: third_party/git git-subtree-split: cb715685942260375e1eb8153b0768a376e4ece7
This commit is contained in:
commit
1b593e1ea4
3629 changed files with 1139935 additions and 0 deletions
100
t/t5900-repo-selection.sh
Executable file
100
t/t5900-repo-selection.sh
Executable file
|
|
@ -0,0 +1,100 @@
|
|||
#!/bin/sh
|
||||
|
||||
test_description='selecting remote repo in ambiguous cases'
|
||||
. ./test-lib.sh
|
||||
|
||||
reset() {
|
||||
rm -rf foo foo.git fetch clone
|
||||
}
|
||||
|
||||
make_tree() {
|
||||
git init "$1" &&
|
||||
(cd "$1" && test_commit "$1")
|
||||
}
|
||||
|
||||
make_bare() {
|
||||
git init --bare "$1" &&
|
||||
(cd "$1" &&
|
||||
tree=$(git hash-object -w -t tree /dev/null) &&
|
||||
commit=$(echo "$1" | git commit-tree $tree) &&
|
||||
git update-ref HEAD $commit
|
||||
)
|
||||
}
|
||||
|
||||
get() {
|
||||
git init --bare fetch &&
|
||||
(cd fetch && git fetch "../$1") &&
|
||||
git clone "$1" clone
|
||||
}
|
||||
|
||||
check() {
|
||||
echo "$1" >expect &&
|
||||
(cd fetch && git log -1 --format=%s FETCH_HEAD) >actual.fetch &&
|
||||
(cd clone && git log -1 --format=%s HEAD) >actual.clone &&
|
||||
test_cmp expect actual.fetch &&
|
||||
test_cmp expect actual.clone
|
||||
}
|
||||
|
||||
test_expect_success 'find .git dir in worktree' '
|
||||
reset &&
|
||||
make_tree foo &&
|
||||
get foo &&
|
||||
check foo
|
||||
'
|
||||
|
||||
test_expect_success 'automagically add .git suffix' '
|
||||
reset &&
|
||||
make_bare foo.git &&
|
||||
get foo &&
|
||||
check foo.git
|
||||
'
|
||||
|
||||
test_expect_success 'automagically add .git suffix to worktree' '
|
||||
reset &&
|
||||
make_tree foo.git &&
|
||||
get foo &&
|
||||
check foo.git
|
||||
'
|
||||
|
||||
test_expect_success 'prefer worktree foo over bare foo.git' '
|
||||
reset &&
|
||||
make_tree foo &&
|
||||
make_bare foo.git &&
|
||||
get foo &&
|
||||
check foo
|
||||
'
|
||||
|
||||
test_expect_success 'prefer bare foo over bare foo.git' '
|
||||
reset &&
|
||||
make_bare foo &&
|
||||
make_bare foo.git &&
|
||||
get foo &&
|
||||
check foo
|
||||
'
|
||||
|
||||
test_expect_success 'disambiguate with full foo.git' '
|
||||
reset &&
|
||||
make_bare foo &&
|
||||
make_bare foo.git &&
|
||||
get foo.git &&
|
||||
check foo.git
|
||||
'
|
||||
|
||||
test_expect_success 'we are not fooled by non-git foo directory' '
|
||||
reset &&
|
||||
make_bare foo.git &&
|
||||
mkdir foo &&
|
||||
get foo &&
|
||||
check foo.git
|
||||
'
|
||||
|
||||
test_expect_success 'prefer inner .git over outer bare' '
|
||||
reset &&
|
||||
make_tree foo &&
|
||||
make_bare foo.git &&
|
||||
mv foo/.git foo.git &&
|
||||
get foo.git &&
|
||||
check foo
|
||||
'
|
||||
|
||||
test_done
|
||||
Loading…
Add table
Add a link
Reference in a new issue