Merge branch 'sb/submodule-helper-clone-regression-fix' into maint
A partial rewrite of "git submodule" in the 2.7 timeframe changed the way the gitdir: pointer in the submodules point at the real repository location to use absolute paths by accident. This has been corrected. * sb/submodule-helper-clone-regression-fix: submodule--helper, module_clone: catch fprintf failure submodule--helper: do not borrow absolute_path() result for too long submodule--helper, module_clone: always operate on absolute paths submodule--helper clone: create the submodule path just once submodule--helper: fix potential NULL-dereference recursive submodules: test for relative paths
This commit is contained in:
@ -818,6 +818,47 @@ test_expect_success 'submodule add --name allows to replace a submodule with ano
|
||||
)
|
||||
'
|
||||
|
||||
test_expect_success 'recursive relative submodules stay relative' '
|
||||
test_when_finished "rm -rf super clone2 subsub sub3" &&
|
||||
mkdir subsub &&
|
||||
(
|
||||
cd subsub &&
|
||||
git init &&
|
||||
>t &&
|
||||
git add t &&
|
||||
git commit -m "initial commit"
|
||||
) &&
|
||||
mkdir sub3 &&
|
||||
(
|
||||
cd sub3 &&
|
||||
git init &&
|
||||
>t &&
|
||||
git add t &&
|
||||
git commit -m "initial commit" &&
|
||||
git submodule add ../subsub dirdir/subsub &&
|
||||
git commit -m "add submodule subsub"
|
||||
) &&
|
||||
mkdir super &&
|
||||
(
|
||||
cd super &&
|
||||
git init &&
|
||||
>t &&
|
||||
git add t &&
|
||||
git commit -m "initial commit" &&
|
||||
git submodule add ../sub3 &&
|
||||
git commit -m "add submodule sub"
|
||||
) &&
|
||||
git clone super clone2 &&
|
||||
(
|
||||
cd clone2 &&
|
||||
git submodule update --init --recursive &&
|
||||
echo "gitdir: ../.git/modules/sub3" >./sub3/.git_expect &&
|
||||
echo "gitdir: ../../../.git/modules/sub3/modules/dirdir/subsub" >./sub3/dirdir/subsub/.git_expect
|
||||
) &&
|
||||
test_cmp clone2/sub3/.git_expect clone2/sub3/.git &&
|
||||
test_cmp clone2/sub3/dirdir/subsub/.git_expect clone2/sub3/dirdir/subsub/.git
|
||||
'
|
||||
|
||||
test_expect_success 'submodule add with an existing name fails unless forced' '
|
||||
(
|
||||
cd addtest2 &&
|
||||
|
Reference in New Issue
Block a user