Code

Reduce value duplication in t9300-fast-import.
[git.git] / t / t9300-fast-import.sh
1 #!/bin/sh
2 #
3 # Copyright (c) 2007 Shawn Pearce
4 #
6 test_description='test git-fast-import utility'
7 . ./test-lib.sh
8 . ../diff-lib.sh ;# test-lib chdir's into trash
10 file2_data='file2
11 second line of EOF'
13 file3_data='EOF
14 in 3rd file
15  END'
17 file4_data=abcd
18 file4_len=4
20 ###
21 ### series A
22 ###
24 test_tick
25 cat >input <<INPUT_END
26 blob
27 mark :2
28 data <<EOF
29 $file2_data
30 EOF
32 blob
33 mark :3
34 data <<END
35 $file3_data
36 END
38 blob
39 mark :4
40 data $file4_len
41 $file4_data
42 commit refs/heads/master
43 mark :5
44 committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
45 data <<COMMIT
46 initial
47 COMMIT
49 M 644 :2 file2
50 M 644 :3 file3
51 M 755 :4 file4
53 INPUT_END
54 test_expect_success \
55     'A: create pack from stdin' \
56     'git-fast-import --export-marks=marks.out <input &&
57          git-whatchanged master'
58 test_expect_success \
59         'A: verify pack' \
60         'for p in .git/objects/pack/*.pack;do git-verify-pack $p||exit;done'
62 cat >expect <<EOF
63 author $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
64 committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
66 initial
67 EOF
68 test_expect_success \
69         'A: verify commit' \
70         'git-cat-file commit master | sed 1d >actual &&
71         diff -u expect actual'
73 cat >expect <<EOF
74 100644 blob file2
75 100644 blob file3
76 100755 blob file4
77 EOF
78 test_expect_success \
79         'A: verify tree' \
80         'git-cat-file -p master^{tree} | sed "s/ [0-9a-f]*      / /" >actual &&
81          diff -u expect actual'
83 echo "$file2_data" >expect
84 test_expect_success \
85         'A: verify file2' \
86         'git-cat-file blob master:file2 >actual && diff -u expect actual'
88 echo "$file3_data" >expect
89 test_expect_success \
90         'A: verify file3' \
91         'git-cat-file blob master:file3 >actual && diff -u expect actual'
93 printf "$file4_data" >expect
94 test_expect_success \
95         'A: verify file4' \
96         'git-cat-file blob master:file4 >actual && diff -u expect actual'
98 cat >expect <<EOF
99 :2 `git-rev-parse --verify master:file2`
100 :3 `git-rev-parse --verify master:file3`
101 :4 `git-rev-parse --verify master:file4`
102 :5 `git-rev-parse --verify master^0`
103 EOF
104 test_expect_success \
105         'A: verify marks output' \
106         'diff -u expect marks.out'
108 ###
109 ### series B
110 ###
112 test_tick
113 cat >input <<INPUT_END
114 commit refs/heads/branch
115 mark :1
116 committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
117 data <<COMMIT
118 corrupt
119 COMMIT
121 from refs/heads/master
122 M 755 0000000000000000000000000000000000000001 zero1
124 INPUT_END
125 test_expect_failure \
126     'B: fail on invalid blob sha1' \
127     'git-fast-import <input'
128 rm -f .git/objects/pack_* .git/objects/index_*
130 ###
131 ### series C
132 ###
134 newf=`echo hi newf | git-hash-object -w --stdin`
135 oldf=`git-rev-parse --verify master:file2`
136 test_tick
137 cat >input <<INPUT_END
138 commit refs/heads/branch
139 committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
140 data <<COMMIT
141 second
142 COMMIT
144 from refs/heads/master
145 M 644 $oldf file2/oldf
146 M 755 $newf file2/newf
147 D file3
149 INPUT_END
150 test_expect_success \
151     'C: incremental import create pack from stdin' \
152     'git-fast-import <input &&
153          git-whatchanged branch'
154 test_expect_success \
155         'C: verify pack' \
156         'for p in .git/objects/pack/*.pack;do git-verify-pack $p||exit;done'
157 test_expect_success \
158         'C: validate reuse existing blob' \
159         'test $newf = `git-rev-parse --verify branch:file2/newf`
160          test $oldf = `git-rev-parse --verify branch:file2/oldf`'
162 cat >expect <<EOF
163 parent `git-rev-parse --verify master^0`
164 author $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
165 committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE
167 second
168 EOF
169 test_expect_success \
170         'C: verify commit' \
171         'git-cat-file commit branch | sed 1d >actual &&
172          diff -u expect actual'
174 cat >expect <<EOF
175 :000000 100755 0000000000000000000000000000000000000000 f1fb5da718392694d0076d677d6d0e364c79b0bc A      file2/newf
176 :100644 100644 7123f7f44e39be127c5eb701e5968176ee9d78b1 7123f7f44e39be127c5eb701e5968176ee9d78b1 R100   file2   file2/oldf
177 :100644 000000 0d92e9f3374ae2947c23aa477cbc68ce598135f1 0000000000000000000000000000000000000000 D      file3
178 EOF
179 git-diff-tree -M -r master branch >actual
180 test_expect_success \
181         'C: validate rename result' \
182         'compare_diff_raw expect actual'
184 test_done