Merge branch 'jc/revision-dash-count-parsing'
[git] / t / t5003-archive-zip.sh
1 #!/bin/sh
2
3 test_description='git archive --format=zip test'
4
5 . ./test-lib.sh
6
7 SUBSTFORMAT=%H%n
8
9 test_lazy_prereq UNZIP_SYMLINKS '
10         (
11                 mkdir unzip-symlinks &&
12                 cd unzip-symlinks &&
13                 "$GIT_UNZIP" "$TEST_DIRECTORY"/t5003/infozip-symlinks.zip &&
14                 test -h symlink
15         )
16 '
17
18 check_zip() {
19         zipfile=$1.zip
20         listfile=$1.lst
21         dir=$1
22         dir_with_prefix=$dir/$2
23
24         test_expect_success UNZIP " extract ZIP archive" '
25                 (mkdir $dir && cd $dir && "$GIT_UNZIP" ../$zipfile)
26         '
27
28         test_expect_success UNZIP " validate filenames" "
29                 (cd ${dir_with_prefix}a && find .) | sort >$listfile &&
30                 test_cmp a.lst $listfile
31         "
32
33         test_expect_success UNZIP " validate file contents" "
34                 diff -r a ${dir_with_prefix}a
35         "
36 }
37
38 test_expect_success \
39     'populate workdir' \
40     'mkdir a &&
41      echo simple textfile >a/a &&
42      mkdir a/bin &&
43      cp /bin/sh a/bin &&
44      printf "A\$Format:%s\$O" "$SUBSTFORMAT" >a/substfile1 &&
45      printf "A not substituted O" >a/substfile2 &&
46      (p=long_path_to_a_file && cd a &&
47       for depth in 1 2 3 4 5; do mkdir $p && cd $p; done &&
48       echo text >file_with_long_path)
49 '
50
51 test_expect_success SYMLINKS,UNZIP_SYMLINKS 'add symlink' '
52         ln -s a a/symlink_to_a
53 '
54
55 test_expect_success 'prepare file list' '
56         (cd a && find .) | sort >a.lst
57 '
58
59 test_expect_success \
60     'add ignored file' \
61     'echo ignore me >a/ignored &&
62      echo ignored export-ignore >.git/info/attributes'
63
64 test_expect_success \
65     'add files to repository' \
66     'find a -type f | xargs git update-index --add &&
67      find a -type l | xargs git update-index --add &&
68      treeid=`git write-tree` &&
69      echo $treeid >treeid &&
70      git update-ref HEAD $(TZ=GMT GIT_COMMITTER_DATE="2005-05-27 22:00:00" \
71      git commit-tree $treeid </dev/null)'
72
73 test_expect_success 'setup export-subst' '
74         echo "substfile?" export-subst >>.git/info/attributes &&
75         git log --max-count=1 "--pretty=format:A${SUBSTFORMAT}O" HEAD \
76                 >a/substfile1
77 '
78
79 test_expect_success \
80     'create bare clone' \
81     'git clone --bare . bare.git &&
82      cp .git/info/attributes bare.git/info/attributes'
83
84 test_expect_success \
85     'remove ignored file' \
86     'rm a/ignored'
87
88 test_expect_success \
89     'git archive --format=zip' \
90     'git archive --format=zip HEAD >d.zip'
91
92 check_zip d
93
94 test_expect_success \
95     'git archive --format=zip in a bare repo' \
96     '(cd bare.git && git archive --format=zip HEAD) >d1.zip'
97
98 test_expect_success \
99     'git archive --format=zip vs. the same in a bare repo' \
100     'test_cmp_bin d.zip d1.zip'
101
102 test_expect_success 'git archive --format=zip with --output' \
103     'git archive --format=zip --output=d2.zip HEAD &&
104     test_cmp_bin d.zip d2.zip'
105
106 test_expect_success 'git archive with --output, inferring format' '
107         git archive --output=d3.zip HEAD &&
108         test_cmp_bin d.zip d3.zip
109 '
110
111 test_expect_success \
112     'git archive --format=zip with prefix' \
113     'git archive --format=zip --prefix=prefix/ HEAD >e.zip'
114
115 check_zip e prefix/
116
117 test_expect_success 'git archive -0 --format=zip on large files' '
118         test_config core.bigfilethreshold 1 &&
119         git archive -0 --format=zip HEAD >large.zip
120 '
121
122 check_zip large
123
124 test_expect_success 'git archive --format=zip on large files' '
125         test_config core.bigfilethreshold 1 &&
126         git archive --format=zip HEAD >large-compressed.zip
127 '
128
129 check_zip large-compressed
130
131 test_done