#!/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 -p "#{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 -p 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 ) ' 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