|  | #!/bin/sh | 
|  | # Copyright (c) 2006 Eric Wong | 
|  | test_description='git-svn metadata migrations from previous versions' | 
|  | . ./lib-git-svn.sh | 
|  |  | 
|  | test_expect_success 'setup old-looking metadata' " | 
|  | cp $GIT_DIR/config $GIT_DIR/config-old-git-svn && | 
|  | mkdir import && | 
|  | cd import && | 
|  | for i in trunk branches/a branches/b \ | 
|  | tags/0.1 tags/0.2 tags/0.3; do | 
|  | mkdir -p \$i && \ | 
|  | echo hello >> \$i/README || exit 1 | 
|  | done && \ | 
|  | svn import -m test . $svnrepo | 
|  | cd .. && | 
|  | git-svn init $svnrepo && | 
|  | git-svn fetch && | 
|  | mv $GIT_DIR/svn/* $GIT_DIR/ && | 
|  | mv $GIT_DIR/svn/.metadata $GIT_DIR/ && | 
|  | rmdir $GIT_DIR/svn && | 
|  | git update-ref refs/heads/git-svn-HEAD refs/remotes/git-svn && | 
|  | git update-ref refs/heads/svn-HEAD refs/remotes/git-svn && | 
|  | git update-ref -d refs/remotes/git-svn refs/remotes/git-svn | 
|  | " | 
|  |  | 
|  | head=`git rev-parse --verify refs/heads/git-svn-HEAD^0` | 
|  | test_expect_success 'git-svn-HEAD is a real HEAD' "test -n '$head'" | 
|  |  | 
|  | test_expect_success 'initialize old-style (v0) git-svn layout' " | 
|  | mkdir -p $GIT_DIR/git-svn/info $GIT_DIR/svn/info && | 
|  | echo $svnrepo > $GIT_DIR/git-svn/info/url && | 
|  | echo $svnrepo > $GIT_DIR/svn/info/url && | 
|  | git-svn migrate && | 
|  | ! test -d $GIT_DIR/git-svn && | 
|  | git rev-parse --verify refs/remotes/git-svn^0 && | 
|  | git rev-parse --verify refs/remotes/svn^0 && | 
|  | test \`git config --get svn-remote.svn.url\` = '$svnrepo' && | 
|  | test \`git config --get svn-remote.svn.fetch\` = \ | 
|  | ':refs/remotes/git-svn' | 
|  | " | 
|  |  | 
|  | test_expect_success 'initialize a multi-repository repo' " | 
|  | git-svn init $svnrepo -T trunk -t tags -b branches && | 
|  | git config --get-all svn-remote.svn.fetch > fetch.out && | 
|  | grep '^trunk:refs/remotes/trunk$' fetch.out && | 
|  | test -n \"\`git config --get svn-remote.svn.branches \ | 
|  | '^branches/\*:refs/remotes/\*$'\`\" && | 
|  | test -n \"\`git config --get svn-remote.svn.tags \ | 
|  | '^tags/\*:refs/remotes/tags/\*$'\`\" && | 
|  | git config --unset svn-remote.svn.branches \ | 
|  | '^branches/\*:refs/remotes/\*$' && | 
|  | git config --unset svn-remote.svn.tags \ | 
|  | '^tags/\*:refs/remotes/tags/\*$' && | 
|  | git config --add svn-remote.svn.fetch 'branches/a:refs/remotes/a' && | 
|  | git config --add svn-remote.svn.fetch 'branches/b:refs/remotes/b' && | 
|  | for i in tags/0.1 tags/0.2 tags/0.3; do | 
|  | git config --add svn-remote.svn.fetch \ | 
|  | \$i:refs/remotes/\$i || exit 1; done | 
|  | " | 
|  |  | 
|  | # refs should all be different, but the trees should all be the same: | 
|  | test_expect_success 'multi-fetch works on partial urls + paths' " | 
|  | git-svn multi-fetch && | 
|  | for i in trunk a b tags/0.1 tags/0.2 tags/0.3; do | 
|  | git rev-parse --verify refs/remotes/\$i^0 >> refs.out || exit 1; | 
|  | done && | 
|  | test -z \"\`sort < refs.out | uniq -d\`\" && | 
|  | for i in trunk a b tags/0.1 tags/0.2 tags/0.3; do | 
|  | for j in trunk a b tags/0.1 tags/0.2 tags/0.3; do | 
|  | if test \$j != \$i; then continue; fi | 
|  | test -z \"\`git diff refs/remotes/\$i \ | 
|  | refs/remotes/\$j\`\" ||exit 1; done; done | 
|  | " | 
|  |  | 
|  | test_expect_success 'migrate --minimize on old inited layout' " | 
|  | git config --unset-all svn-remote.svn.fetch && | 
|  | git config --unset-all svn-remote.svn.url && | 
|  | rm -rf $GIT_DIR/svn && | 
|  | for i in \`cat fetch.out\`; do | 
|  | path=\`expr \$i : '\\([^:]*\\):.*$'\` | 
|  | ref=\`expr \$i : '[^:]*:refs/remotes/\\(.*\\)$'\` | 
|  | if test -z \"\$ref\"; then continue; fi | 
|  | if test -n \"\$path\"; then path=\"/\$path\"; fi | 
|  | ( mkdir -p $GIT_DIR/svn/\$ref/info/ && | 
|  | echo $svnrepo\$path > $GIT_DIR/svn/\$ref/info/url ) || exit 1; | 
|  | done && | 
|  | git-svn migrate --minimize && | 
|  | test -z \"\`git config -l |grep -v '^svn-remote\.git-svn\.'\`\" && | 
|  | git config --get-all svn-remote.svn.fetch > fetch.out && | 
|  | grep '^trunk:refs/remotes/trunk$' fetch.out && | 
|  | grep '^branches/a:refs/remotes/a$' fetch.out && | 
|  | grep '^branches/b:refs/remotes/b$' fetch.out && | 
|  | grep '^tags/0\.1:refs/remotes/tags/0\.1$' fetch.out && | 
|  | grep '^tags/0\.2:refs/remotes/tags/0\.2$' fetch.out && | 
|  | grep '^tags/0\.3:refs/remotes/tags/0\.3$' fetch.out | 
|  | grep '^:refs/remotes/git-svn' fetch.out | 
|  | " | 
|  |  | 
|  | test_expect_success  ".rev_db auto-converted to .rev_db.UUID" " | 
|  | git-svn fetch -i trunk && | 
|  | expect=$GIT_DIR/svn/trunk/.rev_db.* && | 
|  | test -n \"\$expect\" && | 
|  | mv \$expect $GIT_DIR/svn/trunk/.rev_db && | 
|  | git-svn fetch -i trunk && | 
|  | test -L $GIT_DIR/svn/trunk/.rev_db && | 
|  | test -f \$expect && | 
|  | cmp \$expect $GIT_DIR/svn/trunk/.rev_db | 
|  | " | 
|  |  | 
|  | test_done |