#!/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 < ../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