#!/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 ' echo "Only one set of wildcard directories" \ "(e.g. '*' or '*/*/*') is supported: 'branches/*/t/*'" > expect.three echo "" >> expect.three 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