Code

Merge branch 'pt/gitk'
[git.git] / t / t9600-cvsimport.sh
1 #!/bin/sh
3 test_description='git cvsimport basic tests'
4 . ./lib-cvs.sh
6 test_expect_success PERL 'setup cvsroot environment' '
7         CVSROOT=$(pwd)/cvsroot &&
8         export CVSROOT
9 '
11 test_expect_success PERL 'setup cvsroot' '$CVS init'
13 test_expect_success PERL 'setup a cvs module' '
15         mkdir "$CVSROOT/module" &&
16         $CVS co -d module-cvs module &&
17         (cd module-cvs &&
18         cat <<EOF >o_fortuna &&
19 O Fortuna
20 velut luna
21 statu variabilis,
23 semper crescis
24 aut decrescis;
25 vita detestabilis
27 nunc obdurat
28 et tunc curat
29 ludo mentis aciem,
31 egestatem,
32 potestatem
33 dissolvit ut glaciem.
34 EOF
35         $CVS add o_fortuna &&
36         cat <<EOF >message &&
37 add "O Fortuna" lyrics
39 These public domain lyrics make an excellent sample text.
40 EOF
41         $CVS commit -F message
42         )
43 '
45 test_expect_success PERL 'import a trivial module' '
47         git cvsimport -a -R -z 0 -C module-git module &&
48         test_cmp module-cvs/o_fortuna module-git/o_fortuna
50 '
52 test_expect_success PERL 'pack refs' '(cd module-git && git gc)'
54 test_expect_success PERL 'initial import has correct .git/cvs-revisions' '
56         (cd module-git &&
57          git log --format="o_fortuna 1.1 %H" -1) > expected &&
58         test_cmp expected module-git/.git/cvs-revisions
59 '
61 test_expect_success PERL 'update cvs module' '
62         (cd module-cvs &&
63         cat <<EOF >o_fortuna &&
64 O Fortune,
65 like the moon
66 you are changeable,
68 ever waxing
69 and waning;
70 hateful life
72 first oppresses
73 and then soothes
74 as fancy takes it;
76 poverty
77 and power
78 it melts them like ice.
79 EOF
80         cat <<EOF >message &&
81 translate to English
83 My Latin is terrible.
84 EOF
85         $CVS commit -F message
86         )
87 '
89 test_expect_success PERL 'update git module' '
91         (cd module-git &&
92         git config cvsimport.trackRevisions true &&
93         git cvsimport -a -z 0 module &&
94         git merge origin
95         ) &&
96         test_cmp module-cvs/o_fortuna module-git/o_fortuna
98 '
100 test_expect_success PERL 'update has correct .git/cvs-revisions' '
102         (cd module-git &&
103          git log --format="o_fortuna 1.1 %H" -1 HEAD^ &&
104          git log --format="o_fortuna 1.2 %H" -1 HEAD) > expected &&
105         test_cmp expected module-git/.git/cvs-revisions
108 test_expect_success PERL 'update cvs module' '
110         (cd module-cvs &&
111                 echo 1 >tick &&
112                 $CVS add tick &&
113                 $CVS commit -m 1
114         )
117 test_expect_success PERL 'cvsimport.module config works' '
119         (cd module-git &&
120                 git config cvsimport.module module &&
121                 git config cvsimport.trackRevisions true &&
122                 git cvsimport -a -z0 &&
123                 git merge origin
124         ) &&
125         test_cmp module-cvs/tick module-git/tick
129 test_expect_success PERL 'second update has correct .git/cvs-revisions' '
131         (cd module-git &&
132          git log --format="o_fortuna 1.1 %H" -1 HEAD^^ &&
133          git log --format="o_fortuna 1.2 %H" -1 HEAD^
134          git log --format="tick 1.1 %H" -1 HEAD) > expected &&
135         test_cmp expected module-git/.git/cvs-revisions
138 test_expect_success PERL 'import from a CVS working tree' '
140         $CVS co -d import-from-wt module &&
141         (cd import-from-wt &&
142                 git config cvsimport.trackRevisions false &&
143                 git cvsimport -a -z0 &&
144                 echo 1 >expect &&
145                 git log -1 --pretty=format:%s%n >actual &&
146                 test_cmp actual expect
147         )
151 test_expect_success PERL 'no .git/cvs-revisions created by default' '
153         ! test -e import-from-wt/.git/cvs-revisions
157 test_expect_success PERL 'test entire HEAD' 'test_cmp_branch_tree master'
159 test_done