#!/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 ' maybe_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 )' # Without this, LC_ALL=C as set in test-lib.sh, and Cygwin converts # non-ASCII characters in filenames unexpectedly, and causes errors. # https://cygwin.com/cygwin-ug-net/using-specialnames.html#pathnames-specialchars # > Some characters are disallowed in filenames on Windows filesystems. ... # ... # > ... All of the above characters, except for the backslash, are converted # > to special UNICODE characters in the range 0xf000 to 0xf0ff (the # > "Private use area") when creating or accessing files. prepare_a_utf8_locale test_expect_success UTF8,!MINGW,!UTF8_NFD_TO_NFC 'svn.pathnameencoding=cp932 new file on dcommit' ' LC_ALL=$a_utf8_locale && export LC_ALL && neq=$(printf "\201\202") && git config svn.pathnameencoding cp932 && echo neq >"$neq" && git add "$neq" && git commit -m "neq" && git svn dcommit ' # See the comment on the above test for setting of LC_ALL. test_expect_success !MINGW,!UTF8_NFD_TO_NFC 'svn.pathnameencoding=cp932 rename on dcommit' ' LC_ALL=$a_utf8_locale && export LC_ALL && inf=$(printf "\201\207") && git config svn.pathnameencoding cp932 && echo inf >"$inf" && git add "$inf" && git commit -m "inf" && git svn dcommit && git mv "$inf" inf && git commit -m "inf rename" && git svn dcommit ' test_done