| #!/bin/sh |
| # Copyright (c) 2007 Eric Wong |
| test_description='git svn globbing refspecs' |
| . ./lib-git-svn.sh |
| |
| cat > expect.end <<EOF |
| the end |
| hi |
| start a new branch |
| initial |
| EOF |
| |
| test_expect_success 'test refspec globbing' ' |
| mkdir -p trunk/src/a trunk/src/b trunk/doc && |
| echo "hello world" > trunk/src/a/readme && |
| echo "goodbye world" > trunk/src/b/readme && |
| svn_cmd import -m "initial" trunk "$svnrepo"/trunk && |
| svn_cmd co "$svnrepo" tmp && |
| ( |
| cd tmp && |
| mkdir branches branches/v1 tags && |
| svn_cmd add branches tags && |
| svn_cmd cp trunk branches/v1/start && |
| svn_cmd commit -m "start a new branch" && |
| svn_cmd up && |
| echo "hi" >> branches/v1/start/src/b/readme && |
| poke branches/v1/start/src/b/readme && |
| echo "hey" >> branches/v1/start/src/a/readme && |
| poke branches/v1/start/src/a/readme && |
| svn_cmd commit -m "hi" && |
| svn_cmd up && |
| svn_cmd cp branches/v1/start tags/end && |
| echo "bye" >> tags/end/src/b/readme && |
| poke tags/end/src/b/readme && |
| echo "aye" >> tags/end/src/a/readme && |
| poke tags/end/src/a/readme && |
| svn_cmd commit -m "the end" && |
| echo "byebye" >> tags/end/src/b/readme && |
| poke tags/end/src/b/readme && |
| svn_cmd commit -m "nothing to see here" |
| ) && |
| git config --add svn-remote.svn.url "$svnrepo" && |
| git config --add svn-remote.svn.fetch \ |
| "trunk/src/a:refs/remotes/trunk" && |
| git config --add svn-remote.svn.branches \ |
| "branches/*/*/src/a:refs/remotes/branches/*/*" && |
| git config --add svn-remote.svn.tags\ |
| "tags/*/src/a:refs/remotes/tags/*" && |
| git svn multi-fetch && |
| git log --pretty=oneline refs/remotes/tags/end | \ |
| sed -e "s/^.\{41\}//" > output.end && |
| test_cmp expect.end output.end && |
| test "$(git rev-parse refs/remotes/tags/end~1)" = \ |
| "$(git rev-parse refs/remotes/branches/v1/start)" && |
| test "$(git rev-parse refs/remotes/branches/v1/start~2)" = \ |
| "$(git rev-parse refs/remotes/trunk)" && |
| test_must_fail git rev-parse refs/remotes/tags/end@3 |
| ' |
| |
| echo try to try > expect.two |
| echo nothing to see here >> expect.two |
| cat expect.end >> expect.two |
| |
| test_expect_success 'test left-hand-side only globbing' ' |
| git config --add svn-remote.two.url "$svnrepo" && |
| git config --add svn-remote.two.fetch trunk:refs/remotes/two/trunk && |
| git config --add svn-remote.two.branches \ |
| "branches/*/*:refs/remotes/two/branches/*/*" && |
| git config --add svn-remote.two.tags \ |
| "tags/*:refs/remotes/two/tags/*" && |
| ( |
| cd tmp && |
| echo "try try" >> tags/end/src/b/readme && |
| poke tags/end/src/b/readme && |
| svn_cmd commit -m "try to try" |
| ) && |
| git svn fetch two && |
| test $(git rev-list refs/remotes/two/tags/end | wc -l) -eq 6 && |
| test $(git rev-list refs/remotes/two/branches/v1/start | wc -l) -eq 3 && |
| test $(git rev-parse refs/remotes/two/branches/v1/start~2) = \ |
| $(git rev-parse refs/remotes/two/trunk) && |
| test $(git rev-parse refs/remotes/two/tags/end~3) = \ |
| $(git rev-parse refs/remotes/two/branches/v1/start) && |
| git log --pretty=oneline refs/remotes/two/tags/end | \ |
| sed -e "s/^.\{41\}//" > output.two && |
| test_cmp expect.two output.two |
| ' |
| cat > expect.four <<EOF |
| adios |
| adding more |
| Changed 2 in v2/start |
| Another versioned branch |
| initial |
| EOF |
| |
| test_expect_success 'test another branch' ' |
| ( |
| cd tmp && |
| mkdir branches/v2 && |
| svn_cmd add branches/v2 && |
| svn_cmd cp trunk branches/v2/start && |
| svn_cmd commit -m "Another versioned branch" && |
| svn_cmd up && |
| echo "hello" >> branches/v2/start/src/b/readme && |
| poke branches/v2/start/src/b/readme && |
| echo "howdy" >> branches/v2/start/src/a/readme && |
| poke branches/v2/start/src/a/readme && |
| svn_cmd commit -m "Changed 2 in v2/start" && |
| svn_cmd up && |
| svn_cmd cp branches/v2/start tags/next && |
| echo "bye" >> tags/next/src/b/readme && |
| poke tags/next/src/b/readme && |
| echo "aye" >> tags/next/src/a/readme && |
| poke tags/next/src/a/readme && |
| svn_cmd commit -m "adding more" && |
| echo "byebye" >> tags/next/src/b/readme && |
| poke tags/next/src/b/readme && |
| svn_cmd commit -m "adios" |
| ) && |
| git config --add svn-remote.four.url "$svnrepo" && |
| git config --add svn-remote.four.fetch trunk:refs/remotes/four/trunk && |
| git config --add svn-remote.four.branches \ |
| "branches/*/*:refs/remotes/four/branches/*/*" && |
| git config --add svn-remote.four.tags \ |
| "tags/*:refs/remotes/four/tags/*" && |
| git svn fetch four && |
| test $(git rev-list refs/remotes/four/tags/next | wc -l) -eq 5 && |
| test $(git rev-list refs/remotes/four/branches/v2/start | wc -l) -eq 3 && |
| test $(git rev-parse refs/remotes/four/branches/v2/start~2) = \ |
| $(git rev-parse refs/remotes/four/trunk) && |
| test $(git rev-parse refs/remotes/four/tags/next~2) = \ |
| $(git rev-parse refs/remotes/four/branches/v2/start) && |
| git log --pretty=oneline refs/remotes/four/tags/next | \ |
| sed -e "s/^.\{41\}//" > output.four && |
| test_cmp expect.four output.four |
| ' |
| |
| test_expect_success 'prepare test disallow multiple globs' " |
| cat >expect.three <<EOF |
| Only one set of wildcards (e.g. '*' or '*/*/*') is supported: branches/*/t/* |
| |
| EOF |
| " |
| |
| test_expect_success 'test disallow multiple globs' ' |
| git config --add svn-remote.three.url "$svnrepo" && |
| git config --add svn-remote.three.fetch \ |
| trunk:refs/remotes/three/trunk && |
| git config --add svn-remote.three.branches \ |
| "branches/*/t/*:refs/remotes/three/branches/*/*" && |
| git config --add svn-remote.three.tags \ |
| "tags/*:refs/remotes/three/tags/*" && |
| ( |
| cd tmp && |
| echo "try try" >> tags/end/src/b/readme && |
| poke tags/end/src/b/readme && |
| svn_cmd commit -m "try to try" |
| ) && |
| test_must_fail git svn fetch three 2> stderr.three && |
| test_cmp expect.three stderr.three |
| ' |
| |
| test_done |