87 lines
2.1 KiB
87 lines
2.1 KiB
#!/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
|
|
|