diff options
| author | John Keeping <john@keeping.me.uk> | 2013-06-16 15:18:18 +0100 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2013-06-17 13:30:01 -0700 | 
| commit | 091a6eb0feed820a43663ca63dc2bc0bb247bbae (patch) | |
| tree | b4a6a61b74de57b56288d17b3613193a616c06db /t/t7400-submodule-basic.sh | |
| parent | 12b9d32790b40bf3ea49134095619700191abf1f (diff) | |
| download | git-091a6eb0feed820a43663ca63dc2bc0bb247bbae.tar.gz | |
submodule: drop the top-level requirement
Use the new rev-parse --prefix option to process all paths given to the
submodule command, dropping the requirement that it be run from the
top-level of the repository.
Since the interpretation of a relative submodule URL depends on whether
or not "remote.origin.url" is configured, explicitly block relative URLs
in "git submodule add" when not at the top level of the working tree.
Signed-off-by: John Keeping <john@keeping.me.uk>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t7400-submodule-basic.sh')
| -rwxr-xr-x | t/t7400-submodule-basic.sh | 80 | 
1 files changed, 80 insertions, 0 deletions
| diff --git a/t/t7400-submodule-basic.sh b/t/t7400-submodule-basic.sh index ff265353a3..a38fd9208e 100755 --- a/t/t7400-submodule-basic.sh +++ b/t/t7400-submodule-basic.sh @@ -212,6 +212,32 @@ test_expect_success 'submodule add with ./, /.. and // in path' '  	test_cmp empty untracked  ' +test_expect_success 'submodule add in subdirectory' ' +	echo "refs/heads/master" >expect && +	>empty && + +	mkdir addtest/sub && +	( +		cd addtest/sub && +		git submodule add "$submodurl" ../realsubmod3 && +		git submodule init +	) && + +	rm -f heads head untracked && +	inspect addtest/realsubmod3 ../.. && +	test_cmp expect heads && +	test_cmp expect head && +	test_cmp empty untracked +' + +test_expect_success 'submodule add in subdirectory with relative path should fail' ' +	( +		cd addtest/sub && +		test_must_fail git submodule add ../../ submod3 2>../../output.err +	) && +	test_i18ngrep toplevel output.err +' +  test_expect_success 'setup - add an example entry to .gitmodules' '  	GIT_CONFIG=.gitmodules \  	git config submodule.example.url git://example.com/init.git @@ -319,6 +345,26 @@ test_expect_success 'status should be "up-to-date" after update' '  	grep "^ $rev1" list  ' +test_expect_success 'status "up-to-date" from subdirectory' ' +	mkdir -p sub && +	( +		cd sub && +		git submodule status >../list +	) && +	grep "^ $rev1" list && +	grep "\\.\\./init" list +' + +test_expect_success 'status "up-to-date" from subdirectory with path' ' +	mkdir -p sub && +	( +		cd sub && +		git submodule status ../init >../list +	) && +	grep "^ $rev1" list && +	grep "\\.\\./init" list +' +  test_expect_success 'status should be "modified" after submodule commit' '  	(  		cd init && @@ -399,6 +445,25 @@ test_expect_success 'update --init' '  	git rev-parse --resolve-git-dir init/.git  ' +test_expect_success 'update --init from subdirectory' ' +	mv init init2 && +	git config -f .gitmodules submodule.example.url "$(pwd)/init2" && +	git config --remove-section submodule.example && +	test_must_fail git config submodule.example.url && + +	mkdir -p sub && +	( +		cd sub && +		git submodule update ../init >update.out && +		cat update.out && +		test_i18ngrep "not initialized" update.out && +		test_must_fail git rev-parse --resolve-git-dir ../init/.git && + +		git submodule update --init ../init +	) && +	git rev-parse --resolve-git-dir init/.git +' +  test_expect_success 'do not add files from a submodule' '  	git reset --hard && @@ -772,6 +837,21 @@ test_expect_success 'submodule deinit should remove the whole submodule section  	rmdir init  ' +test_expect_success 'submodule deinit from subdirectory' ' +	git submodule update --init && +	git config submodule.example.foo bar && +	mkdir -p sub && +	( +		cd sub && +		git submodule deinit ../init >../output +	) && +	grep "\\.\\./init" output && +	test -z "$(git config --get-regexp "submodule\.example\.")" && +	test -n "$(git config --get-regexp "submodule\.example2\.")" && +	test -f example2/.git && +	rmdir init +' +  test_expect_success 'submodule deinit . deinits all initialized submodules' '  	git submodule update --init &&  	git config submodule.example.foo bar && | 
