mirror of
https://github.com/git/git.git
synced 2025-01-19 14:04:07 +08:00
14a771eee9
The Git CodingGuidelines prefer the $(...) construct for command substitution instead of using the backquotes `...`. The backquoted form is the traditional method for command substitution, and is supported by POSIX. However, all but the simplest uses become complicated quickly. In particular, embedded command substitutions and/or the use of double quotes require careful escaping with the backslash character. The patch was generated by: for _f in $(find . -name "*.sh") do perl -i -pe 'BEGIN{undef $/;} s/`(.+?)`/\$(\1)/smg' "${_f}" done and then carefully proof-read. Signed-off-by: Elia Pinto <gitter.spiros@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
101 lines
1.7 KiB
Bash
Executable File
101 lines
1.7 KiB
Bash
Executable File
#!/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
|