312efe9b58
This is a stop-gap to work around problem with git-init without intrusive changes. Signed-off-by: Junio C Hamano <gitster@pobox.com>
67 lines
1.3 KiB
Bash
Executable File
67 lines
1.3 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
test_description='test local clone'
|
|
. ./test-lib.sh
|
|
|
|
D=`pwd`
|
|
|
|
test_expect_success 'preparing origin repository' '
|
|
: >file && git add . && git commit -m1 &&
|
|
git clone --bare . a.git &&
|
|
git clone --bare . x &&
|
|
test "$(GIT_CONFIG=a.git/config git config --bool core.bare)" = true &&
|
|
test "$(GIT_CONFIG=x/config git config --bool core.bare)" = true
|
|
'
|
|
|
|
test_expect_success 'local clone without .git suffix' '
|
|
cd "$D" &&
|
|
git clone -l -s a b &&
|
|
cd b &&
|
|
test "$(GIT_CONFIG=.git/config git config --bool core.bare)" = false &&
|
|
git fetch
|
|
'
|
|
|
|
test_expect_success 'local clone with .git suffix' '
|
|
cd "$D" &&
|
|
git clone -l -s a.git c &&
|
|
cd c &&
|
|
git fetch
|
|
'
|
|
|
|
test_expect_success 'local clone from x' '
|
|
cd "$D" &&
|
|
git clone -l -s x y &&
|
|
cd y &&
|
|
git fetch
|
|
'
|
|
|
|
test_expect_success 'local clone from x.git that does not exist' '
|
|
cd "$D" &&
|
|
if git clone -l -s x.git z
|
|
then
|
|
echo "Oops, should have failed"
|
|
false
|
|
else
|
|
echo happy
|
|
fi
|
|
'
|
|
|
|
test_expect_success 'With -no-hardlinks, local will make a copy' '
|
|
cd "$D" &&
|
|
git clone --bare --no-hardlinks x w &&
|
|
cd w &&
|
|
linked=$(find objects -type f ! -links 1 | wc -l) &&
|
|
test 0 = $linked
|
|
'
|
|
|
|
test_expect_success 'Even without -l, local will make a hardlink' '
|
|
cd "$D" &&
|
|
rm -fr w &&
|
|
git clone -l --bare x w &&
|
|
cd w &&
|
|
copied=$(find objects -type f -links 1 | wc -l) &&
|
|
test 0 = $copied
|
|
'
|
|
|
|
test_done
|