git: run in a directory given with -C option
[gitweb.git] / t / t9105-git-svn-commit-diff.sh
index f994b72f80eb9cbc6617dc1d3c9e6bbe63319b7b..5d0afeae6caf03ca34d7ef883baed512bcbcec51 100755 (executable)
@@ -1,28 +1,22 @@
 #!/bin/sh
 #
 # Copyright (c) 2006 Eric Wong
-test_description='git-svn commit-diff'
+test_description='git svn commit-diff'
 . ./lib-git-svn.sh
 
-if test -n "$GIT_SVN_NO_LIB" && test "$GIT_SVN_NO_LIB" -ne 0
-then
-       echo 'Skipping: commit-diff needs SVN libraries'
-       test_done
-       exit 0
-fi
-
-test_expect_success 'initialize repo' "
+test_expect_success 'initialize repo' '
        mkdir import &&
-       cd import &&
-       echo hello > readme &&
-       svn import -m 'initial' . $svnrepo &&
-       cd .. &&
+       (
+               cd import &&
+               echo hello >readme &&
+               svn_cmd import -m "initial" . "$svnrepo"
+       ) &&
        echo hello > readme &&
        git update-index --add readme &&
-       git commit -a -m 'initial' &&
+       git commit -a -m "initial" &&
        echo world >> readme &&
-       git commit -a -m 'another'
-       "
+       git commit -a -m "another"
+       '
 
 head=`git rev-parse --verify HEAD^0`
 prev=`git rev-parse --verify HEAD^1`
@@ -31,11 +25,20 @@ prev=`git rev-parse --verify HEAD^1`
 # commit, so only a basic test of functionality is needed since we've
 # already tested commit extensively elsewhere
 
-test_expect_success 'test the commit-diff command' "
-       test -n '$prev' && test -n '$head' &&
-       git-svn commit-diff '$prev' '$head' '$svnrepo' &&
-       svn co $svnrepo wc &&
+test_expect_success 'test the commit-diff command' '
+       test -n "$prev" && test -n "$head" &&
+       git svn commit-diff -r1 "$prev" "$head" "$svnrepo" &&
+       svn_cmd co "$svnrepo" wc &&
        cmp readme wc/readme
-       "
+       '
+
+test_expect_success 'commit-diff to a sub-directory (with git svn config)' '
+       svn_cmd import -m "sub-directory" import "$svnrepo"/subdir &&
+       git svn init --minimize-url "$svnrepo"/subdir &&
+       git svn fetch &&
+       git svn commit-diff -r3 "$prev" "$head" &&
+       svn_cmd cat "$svnrepo"/subdir/readme > readme.2 &&
+       cmp readme readme.2
+       '
 
 test_done