| #!/bin/sh |
| # |
| # Copyright (c) 2007 Eric Wong |
| |
| |
| test_description='git svn dcommit can commit renames of files with ugly names' |
| |
| . ./lib-git-svn.sh |
| |
| test_expect_success 'load repository with strange names' ' |
| svnadmin load -q "$rawsvnrepo" < "$TEST_DIRECTORY"/t9115/funky-names.dump && |
| start_httpd gtk+ |
| ' |
| |
| test_expect_success 'init and fetch repository' ' |
| git svn init "$svnrepo" && |
| git svn fetch && |
| git reset --hard git-svn |
| ' |
| |
| test_expect_success 'create file in existing ugly and empty dir' ' |
| mkdir "#{bad_directory_name}" && |
| echo hi > "#{bad_directory_name}/ foo" && |
| git update-index --add "#{bad_directory_name}/ foo" && |
| git commit -m "new file in ugly parent" && |
| git svn dcommit |
| ' |
| |
| test_expect_success 'rename ugly file' ' |
| git mv "#{bad_directory_name}/ foo" "file name with feces" && |
| git commit -m "rename ugly file" && |
| git svn dcommit |
| ' |
| |
| test_expect_success 'rename pretty file' ' |
| echo :x > pretty && |
| git update-index --add pretty && |
| git commit -m "pretty :x" && |
| git svn dcommit && |
| mkdir regular_dir_name && |
| git mv pretty regular_dir_name/pretty && |
| git commit -m "moved pretty file" && |
| git svn dcommit |
| ' |
| |
| test_expect_success 'rename pretty file into ugly one' ' |
| git mv regular_dir_name/pretty "#{bad_directory_name}/ booboo" && |
| git commit -m booboo && |
| git svn dcommit |
| ' |
| |
| test_expect_success 'add a file with plus signs' ' |
| echo .. > +_+ && |
| git update-index --add +_+ && |
| git commit -m plus && |
| mkdir gtk+ && |
| git mv +_+ gtk+/_+_ && |
| git commit -m plus_dir && |
| git svn dcommit |
| ' |
| |
| test_expect_success 'clone the repository to test rebase' ' |
| git svn clone "$svnrepo" test-rebase && |
| cd test-rebase && |
| echo test-rebase > test-rebase && |
| git add test-rebase && |
| git commit -m test-rebase && |
| cd .. |
| ' |
| |
| test_expect_success 'make a commit to test rebase' ' |
| echo test-rebase-main > test-rebase-main && |
| git add test-rebase-main && |
| git commit -m test-rebase-main && |
| git svn dcommit |
| ' |
| |
| test_expect_success 'git svn rebase works inside a fresh-cloned repository' ' |
| cd test-rebase && |
| git svn rebase && |
| test -e test-rebase-main && |
| test -e test-rebase |
| ' |
| |
| stop_httpd |
| |
| test_done |