Merge branch 'maint'
[git] / t / t9115-git-svn-dcommit-funky-renames.sh
1 #!/bin/sh
2 #
3 # Copyright (c) 2007 Eric Wong
4
5
6 test_description='git svn dcommit can commit renames of files with ugly names'
7
8 . ./lib-git-svn.sh
9
10 test_expect_success 'load repository with strange names' '
11         svnadmin load -q "$rawsvnrepo" < "$TEST_DIRECTORY"/t9115/funky-names.dump &&
12         start_httpd gtk+
13         '
14
15 test_expect_success 'init and fetch repository' '
16         git svn init "$svnrepo" &&
17         git svn fetch &&
18         git reset --hard git-svn
19         '
20
21 test_expect_success 'create file in existing ugly and empty dir' '
22         mkdir -p "#{bad_directory_name}" &&
23         echo hi > "#{bad_directory_name}/ foo" &&
24         git update-index --add "#{bad_directory_name}/ foo" &&
25         git commit -m "new file in ugly parent" &&
26         git svn dcommit
27         '
28
29 test_expect_success 'rename ugly file' '
30         git mv "#{bad_directory_name}/ foo" "file name with feces" &&
31         git commit -m "rename ugly file" &&
32         git svn dcommit
33         '
34
35 test_expect_success 'rename pretty file' '
36         echo :x > pretty &&
37         git update-index --add pretty &&
38         git commit -m "pretty :x" &&
39         git svn dcommit &&
40         mkdir -p regular_dir_name &&
41         git mv pretty regular_dir_name/pretty &&
42         git commit -m "moved pretty file" &&
43         git svn dcommit
44         '
45
46 test_expect_success 'rename pretty file into ugly one' '
47         git mv regular_dir_name/pretty "#{bad_directory_name}/ booboo" &&
48         git commit -m booboo &&
49         git svn dcommit
50         '
51
52 test_expect_success 'add a file with plus signs' '
53         echo .. > +_+ &&
54         git update-index --add +_+ &&
55         git commit -m plus &&
56         mkdir gtk+ &&
57         git mv +_+ gtk+/_+_ &&
58         git commit -m plus_dir &&
59         git svn dcommit
60         '
61
62 test_expect_success 'clone the repository to test rebase' '
63         git svn clone "$svnrepo" test-rebase &&
64         (
65                 cd test-rebase &&
66                 echo test-rebase >test-rebase &&
67                 git add test-rebase &&
68                 git commit -m test-rebase
69         )
70         '
71
72 test_expect_success 'make a commit to test rebase' '
73                 echo test-rebase-main > test-rebase-main &&
74                 git add test-rebase-main &&
75                 git commit -m test-rebase-main &&
76                 git svn dcommit
77         '
78
79 test_expect_success 'git svn rebase works inside a fresh-cloned repository' '
80         cd test-rebase &&
81                 git svn rebase &&
82                 test -e test-rebase-main &&
83                 test -e test-rebase
84         '
85
86 stop_httpd
87
88 test_done