diff options
| author | Eric Wong <normalperson@yhbt.net> | 2009-01-11 18:23:38 -0800 | 
|---|---|---|
| committer | Eric Wong <normalperson@yhbt.net> | 2009-01-18 18:39:57 -0800 | 
| commit | b03a71a660d15d76b63d7d3c5205b896f89f34b5 (patch) | |
| tree | dc8130f50271494d32d71880753361443a1e9c49 /t/t9133-git-svn-nested-git-repo.sh | |
| parent | 1ef626b4b6c70fc13062faafdccb2f0da7578a29 (diff) | |
| download | git-b03a71a660d15d76b63d7d3c5205b896f89f34b5.tar.gz | |
git-svn: avoid importing nested git repos
Some SVN repositories contain git repositories within them
(hopefully accidentally checked in).  Since git refuses to track
nested ".git" repositories, this can be a problem when fetching
updates from SVN.
Thanks to Morgan Christiansson for the report and testing.
Signed-off-by: Eric Wong <normalperson@yhbt.net>
Diffstat (limited to 't/t9133-git-svn-nested-git-repo.sh')
| -rwxr-xr-x | t/t9133-git-svn-nested-git-repo.sh | 101 | 
1 files changed, 101 insertions, 0 deletions
| diff --git a/t/t9133-git-svn-nested-git-repo.sh b/t/t9133-git-svn-nested-git-repo.sh new file mode 100755 index 0000000000..893f57ef73 --- /dev/null +++ b/t/t9133-git-svn-nested-git-repo.sh @@ -0,0 +1,101 @@ +#!/bin/sh +# +# Copyright (c) 2009 Eric Wong +# + +test_description='git svn property tests' +. ./lib-git-svn.sh + +test_expect_success 'setup repo with a git repo inside it' ' +	svn co "$svnrepo" s && +	( +		cd s && +		git init && +		test -f .git/HEAD && +		> .git/a && +		echo a > a && +		svn add .git a && +		svn commit -m "create a nested git repo" && +		svn up && +		echo hi >> .git/a && +		svn commit -m "modify .git/a" && +		svn up +	) +' + +test_expect_success 'clone an SVN repo containing a git repo' ' +	git svn clone "$svnrepo" g && +	echo a > expect && +	test_cmp expect g/a +' + +test_expect_success 'SVN-side change outside of .git' ' +	( +		cd s && +		echo b >> a && +		svn commit -m "SVN-side change outside of .git" && +		svn up && +		svn log -v | fgrep "SVN-side change outside of .git" +	) +' + +test_expect_success 'update git svn-cloned repo' ' +	( +		cd g && +		git svn rebase && +		echo a > expect && +		echo b >> expect && +		test_cmp a expect && +		rm expect +	) +' + +test_expect_success 'SVN-side change inside of .git' ' +	( +		cd s && +		git add a && +		git commit -m "add a inside an SVN repo" && +		git log && +		svn add --force .git && +		svn commit -m "SVN-side change inside of .git" && +		svn up && +		svn log -v | fgrep "SVN-side change inside of .git" +	) +' + +test_expect_success 'update git svn-cloned repo' ' +	( +		cd g && +		git svn rebase && +		echo a > expect && +		echo b >> expect && +		test_cmp a expect && +		rm expect +	) +' + +test_expect_success 'SVN-side change in and out of .git' ' +	( +		cd s && +		echo c >> a && +		git add a && +		git commit -m "add a inside an SVN repo" && +		svn commit -m "SVN-side change in and out of .git" && +		svn up && +		svn log -v | fgrep "SVN-side change in and out of .git" +	) +' + +test_expect_success 'update git svn-cloned repo again' ' +	( +		cd g && +		git svn rebase && +		echo a > expect && +		echo b >> expect && +		echo c >> expect && +		test_cmp a expect && +		rm expect +	) +' + +test_done | 
