3 # Copyright (C) 2005 Rene Scharfe
6 test_description='git tar-tree and git get-tar-commit-id test
8 This test covers the topics of file contents, commit date handling and
11 The contents of the repository is compared to the extracted tar
12 archive. The repository contains simple text files, symlinks and a
13 binary file (/bin/sh). Only paths shorter than 99 characters are
16 git tar-tree applies the commit date to every file in the archive it
17 creates. The test sets the commit date to a specific value and checks
18 if the tar archive contains that value.
20 When giving git tar-tree a commit id (in contrast to a tree id) it
21 embeds this commit id into the tar archive as a comment. The test
22 checks the ability of git get-tar-commit-id to figure it out from the
35 echo simple textfile >a/a &&
38 printf "A\$Format:%s\$O" "$SUBSTFORMAT" >a/substfile1 &&
39 printf "A not substituted O" >a/substfile2 &&
40 if test_have_prereq SYMLINKS; then
45 (p=long_path_to_a_file && cd a &&
46 for depth in 1 2 3 4 5; do mkdir $p && cd $p; done &&
47 echo text >file_with_long_path) &&
48 (cd a && find .) | sort >a.lst'
52 'echo ignore me >a/ignored &&
53 echo ignored export-ignore >.git/info/attributes'
56 'add files to repository' \
57 'find a -type f | xargs git update-index --add &&
58 find a -type l | xargs git update-index --add &&
59 treeid=`git write-tree` &&
60 echo $treeid >treeid &&
61 git update-ref HEAD $(TZ=GMT GIT_COMMITTER_DATE="2005-05-27 22:00:00" \
62 git commit-tree $treeid </dev/null)'
66 'git clone --bare . bare.git &&
67 cp .git/info/attributes bare.git/info/attributes'
70 'remove ignored file' \
75 'git archive HEAD >b.tar'
79 'git tar-tree HEAD >b2.tar'
82 'git archive vs. git tar-tree' \
83 'test_cmp b.tar b2.tar'
86 'git archive in a bare repo' \
87 '(cd bare.git && git archive HEAD) >b3.tar'
90 'git archive vs. the same in a bare repo' \
91 'test_cmp b.tar b3.tar'
93 test_expect_success 'git archive with --output' \
94 'git archive --output=b4.tar HEAD &&
95 test_cmp b.tar b4.tar'
98 'validate file modification time' \
100 "$TAR" xf b.tar -C extract a/a &&
101 test-chmtime -v +0 extract/a/a |cut -f 1 >b.mtime &&
102 echo "1117231200" >expected.mtime &&
103 test_cmp expected.mtime b.mtime'
105 test_expect_success \
106 'git get-tar-commit-id' \
107 'git get-tar-commit-id <b.tar >b.commitid &&
108 test_cmp .git/$(git symbolic-ref HEAD) b.commitid'
110 test_expect_success \
111 'extract tar archive' \
112 '(cd b && "$TAR" xf -) <b.tar'
114 test_expect_success \
115 'validate filenames' \
116 '(cd b/a && find .) | sort >b.lst &&
117 test_cmp a.lst b.lst'
119 test_expect_success \
120 'validate file contents' \
123 test_expect_success \
124 'git tar-tree with prefix' \
125 'git tar-tree HEAD prefix >c.tar'
127 test_expect_success \
128 'extract tar archive with prefix' \
129 '(cd c && "$TAR" xf -) <c.tar'
131 test_expect_success \
132 'validate filenames with prefix' \
133 '(cd c/prefix/a && find .) | sort >c.lst &&
134 test_cmp a.lst c.lst'
136 test_expect_success \
137 'validate file contents with prefix' \
138 'diff -r a c/prefix/a'
140 test_expect_success \
141 'create archives with substfiles' \
142 'cp .git/info/attributes .git/info/attributes.before &&
143 echo "substfile?" export-subst >>.git/info/attributes &&
144 git archive HEAD >f.tar &&
145 git archive --prefix=prefix/ HEAD >g.tar &&
146 mv .git/info/attributes.before .git/info/attributes'
148 test_expect_success \
149 'extract substfiles' \
150 '(mkdir f && cd f && "$TAR" xf -) <f.tar'
152 test_expect_success \
153 'validate substfile contents' \
154 'git log --max-count=1 "--pretty=format:A${SUBSTFORMAT}O" HEAD \
155 >f/a/substfile1.expected &&
156 test_cmp f/a/substfile1.expected f/a/substfile1 &&
157 test_cmp a/substfile2 f/a/substfile2
160 test_expect_success \
161 'extract substfiles from archive with prefix' \
162 '(mkdir g && cd g && "$TAR" xf -) <g.tar'
164 test_expect_success \
165 'validate substfile contents from archive with prefix' \
166 'git log --max-count=1 "--pretty=format:A${SUBSTFORMAT}O" HEAD \
167 >g/prefix/a/substfile1.expected &&
168 test_cmp g/prefix/a/substfile1.expected g/prefix/a/substfile1 &&
169 test_cmp a/substfile2 g/prefix/a/substfile2
172 test_expect_success \
173 'git archive --format=zip' \
174 'git archive --format=zip HEAD >d.zip'
176 test_expect_success \
177 'git archive --format=zip in a bare repo' \
178 '(cd bare.git && git archive --format=zip HEAD) >d1.zip'
180 test_expect_success \
181 'git archive --format=zip vs. the same in a bare repo' \
182 'test_cmp d.zip d1.zip'
184 test_expect_success 'git archive --format=zip with --output' \
185 'git archive --format=zip --output=d2.zip HEAD &&
186 test_cmp d.zip d2.zip'
188 $UNZIP -v >/dev/null 2>&1
189 if [ $? -eq 127 ]; then
190 say "Skipping ZIP tests, because unzip was not found"
192 test_set_prereq UNZIP
195 test_expect_success UNZIP \
196 'extract ZIP archive' \
197 '(mkdir d && cd d && $UNZIP ../d.zip)'
199 test_expect_success UNZIP \
200 'validate filenames' \
201 '(cd d/a && find .) | sort >d.lst &&
202 test_cmp a.lst d.lst'
204 test_expect_success UNZIP \
205 'validate file contents' \
208 test_expect_success \
209 'git archive --format=zip with prefix' \
210 'git archive --format=zip --prefix=prefix/ HEAD >e.zip'
212 test_expect_success UNZIP \
213 'extract ZIP archive with prefix' \
214 '(mkdir e && cd e && $UNZIP ../e.zip)'
216 test_expect_success UNZIP \
217 'validate filenames with prefix' \
218 '(cd e/prefix/a && find .) | sort >e.lst &&
219 test_cmp a.lst e.lst'
221 test_expect_success UNZIP \
222 'validate file contents with prefix' \
223 'diff -r a e/prefix/a'
225 test_expect_success \
226 'git archive --list outside of a git repo' \
227 'GIT_DIR=some/non-existing/directory git archive --list'