]> git.ipfire.org Git - thirdparty/git.git/blob - t/t9600-cvsimport.sh
Several tests: cd inside subshell instead of around
[thirdparty/git.git] / t / t9600-cvsimport.sh
1 #!/bin/sh
2
3 test_description='git cvsimport basic tests'
4 . ./lib-cvs.sh
5
6 if ! test_have_prereq PERL; then
7 skip_all='skipping git cvsimport tests, perl not available'
8 test_done
9 fi
10
11 CVSROOT=$(pwd)/cvsroot
12 export CVSROOT
13
14 test_expect_success 'setup cvsroot' '$CVS init'
15
16 test_expect_success 'setup a cvs module' '
17
18 mkdir "$CVSROOT/module" &&
19 $CVS co -d module-cvs module &&
20 (cd module-cvs &&
21 cat <<EOF >o_fortuna &&
22 O Fortuna
23 velut luna
24 statu variabilis,
25
26 semper crescis
27 aut decrescis;
28 vita detestabilis
29
30 nunc obdurat
31 et tunc curat
32 ludo mentis aciem,
33
34 egestatem,
35 potestatem
36 dissolvit ut glaciem.
37 EOF
38 $CVS add o_fortuna &&
39 cat <<EOF >message &&
40 add "O Fortuna" lyrics
41
42 These public domain lyrics make an excellent sample text.
43 EOF
44 $CVS commit -F message
45 )
46 '
47
48 test_expect_success 'import a trivial module' '
49
50 git cvsimport -a -R -z 0 -C module-git module &&
51 test_cmp module-cvs/o_fortuna module-git/o_fortuna
52
53 '
54
55 test_expect_success 'pack refs' '(cd module-git && git gc)'
56
57 test_expect_success 'initial import has correct .git/cvs-revisions' '
58
59 (cd module-git &&
60 git log --format="o_fortuna 1.1 %H" -1) > expected &&
61 test_cmp expected module-git/.git/cvs-revisions
62 '
63
64 test_expect_success 'update cvs module' '
65 (cd module-cvs &&
66 cat <<EOF >o_fortuna &&
67 O Fortune,
68 like the moon
69 you are changeable,
70
71 ever waxing
72 and waning;
73 hateful life
74
75 first oppresses
76 and then soothes
77 as fancy takes it;
78
79 poverty
80 and power
81 it melts them like ice.
82 EOF
83 cat <<EOF >message &&
84 translate to English
85
86 My Latin is terrible.
87 EOF
88 $CVS commit -F message
89 )
90 '
91
92 test_expect_success 'update git module' '
93
94 (cd module-git &&
95 git cvsimport -a -R -z 0 module &&
96 git merge origin
97 ) &&
98 test_cmp module-cvs/o_fortuna module-git/o_fortuna
99
100 '
101
102 test_expect_success 'update has correct .git/cvs-revisions' '
103
104 (cd module-git &&
105 git log --format="o_fortuna 1.1 %H" -1 HEAD^ &&
106 git log --format="o_fortuna 1.2 %H" -1 HEAD) > expected &&
107 test_cmp expected module-git/.git/cvs-revisions
108 '
109
110 test_expect_success 'update cvs module' '
111
112 (cd module-cvs &&
113 echo 1 >tick &&
114 $CVS add tick &&
115 $CVS commit -m 1
116 )
117 '
118
119 test_expect_success 'cvsimport.module config works' '
120
121 (cd module-git &&
122 git config cvsimport.module module &&
123 git cvsimport -a -R -z0 &&
124 git merge origin
125 ) &&
126 test_cmp module-cvs/tick module-git/tick
127
128 '
129
130 test_expect_success 'second update has correct .git/cvs-revisions' '
131
132 (cd module-git &&
133 git log --format="o_fortuna 1.1 %H" -1 HEAD^^ &&
134 git log --format="o_fortuna 1.2 %H" -1 HEAD^
135 git log --format="tick 1.1 %H" -1 HEAD) > expected &&
136 test_cmp expected module-git/.git/cvs-revisions
137 '
138
139 test_expect_success 'import from a CVS working tree' '
140
141 $CVS co -d import-from-wt module &&
142 (cd import-from-wt &&
143 git cvsimport -a -z0 &&
144 echo 1 >expect &&
145 git log -1 --pretty=format:%s%n >actual &&
146 test_cmp actual expect
147 )
148
149 '
150
151 test_expect_success 'no .git/cvs-revisions created by default' '
152
153 ! test -e import-from-wt/.git/cvs-revisions
154
155 '
156
157 test_expect_success 'test entire HEAD' 'test_cmp_branch_tree master'
158
159 test_done