Merge branch 'jk/for-each-ref-multi-key-sort-fix'
[git] / t / t5001-archive-attr.sh
1 #!/bin/sh
2
3 test_description='git archive attribute tests'
4
5 . ./test-lib.sh
6
7 SUBSTFORMAT='%H (%h)%n'
8
9 test_expect_exists() {
10         test_expect_${2:-success} " $1 exists" "test -e $1"
11 }
12
13 test_expect_missing() {
14         test_expect_${2:-success} " $1 does not exist" "test ! -e $1"
15 }
16
17 extract_tar_to_dir () {
18         (mkdir "$1" && cd "$1" && "$TAR" xf -) <"$1.tar"
19 }
20
21 test_expect_success 'setup' '
22         echo ignored >ignored &&
23         echo ignored export-ignore >>.git/info/attributes &&
24         git add ignored &&
25
26         echo ignored by tree >ignored-by-tree &&
27         echo ignored-by-tree export-ignore >.gitattributes &&
28         mkdir ignored-by-tree.d &&
29         >ignored-by-tree.d/file &&
30         echo ignored-by-tree.d export-ignore >>.gitattributes &&
31         git add ignored-by-tree ignored-by-tree.d .gitattributes &&
32
33         echo ignored by worktree >ignored-by-worktree &&
34         echo ignored-by-worktree export-ignore >.gitattributes &&
35         git add ignored-by-worktree &&
36
37         mkdir excluded-by-pathspec.d &&
38         >excluded-by-pathspec.d/file &&
39         git add excluded-by-pathspec.d &&
40
41         printf "A\$Format:%s\$O" "$SUBSTFORMAT" >nosubstfile &&
42         printf "A\$Format:%s\$O" "$SUBSTFORMAT" >substfile1 &&
43         printf "A not substituted O" >substfile2 &&
44         echo "substfile?" export-subst >>.git/info/attributes &&
45         git add nosubstfile substfile1 substfile2 &&
46
47         git commit -m. &&
48
49         git clone --bare . bare &&
50         cp .git/info/attributes bare/info/attributes
51 '
52
53 test_expect_success 'git archive' '
54         git archive HEAD >archive.tar &&
55         (mkdir archive && cd archive && "$TAR" xf -) <archive.tar
56 '
57
58 test_expect_missing     archive/ignored
59 test_expect_missing     archive/ignored-by-tree
60 test_expect_missing     archive/ignored-by-tree.d
61 test_expect_missing     archive/ignored-by-tree.d/file
62 test_expect_exists      archive/ignored-by-worktree
63 test_expect_exists      archive/excluded-by-pathspec.d
64 test_expect_exists      archive/excluded-by-pathspec.d/file
65
66 test_expect_success 'git archive with pathspec' '
67         git archive HEAD ":!excluded-by-pathspec.d" >archive-pathspec.tar &&
68         extract_tar_to_dir archive-pathspec
69 '
70
71 test_expect_missing     archive-pathspec/ignored
72 test_expect_missing     archive-pathspec/ignored-by-tree
73 test_expect_missing     archive-pathspec/ignored-by-tree.d
74 test_expect_missing     archive-pathspec/ignored-by-tree.d/file
75 test_expect_exists      archive-pathspec/ignored-by-worktree
76 test_expect_missing     archive-pathspec/excluded-by-pathspec.d
77 test_expect_missing     archive-pathspec/excluded-by-pathspec.d/file
78
79 test_expect_success 'git archive with wildcard pathspec' '
80         git archive HEAD ":!excluded-by-p*" >archive-pathspec-wildcard.tar &&
81         extract_tar_to_dir archive-pathspec-wildcard
82 '
83
84 test_expect_missing     archive-pathspec-wildcard/ignored
85 test_expect_missing     archive-pathspec-wildcard/ignored-by-tree
86 test_expect_missing     archive-pathspec-wildcard/ignored-by-tree.d
87 test_expect_missing     archive-pathspec-wildcard/ignored-by-tree.d/file
88 test_expect_exists      archive-pathspec-wildcard/ignored-by-worktree
89 test_expect_missing     archive-pathspec-wildcard/excluded-by-pathspec.d
90 test_expect_missing     archive-pathspec-wildcard/excluded-by-pathspec.d/file
91
92 test_expect_success 'git archive with worktree attributes' '
93         git archive --worktree-attributes HEAD >worktree.tar &&
94         (mkdir worktree && cd worktree && "$TAR" xf -) <worktree.tar
95 '
96
97 test_expect_missing     worktree/ignored
98 test_expect_exists      worktree/ignored-by-tree
99 test_expect_missing     worktree/ignored-by-worktree
100
101 test_expect_success 'git archive --worktree-attributes option' '
102         git archive --worktree-attributes --worktree-attributes HEAD >worktree.tar &&
103         (mkdir worktree2 && cd worktree2 && "$TAR" xf -) <worktree.tar
104 '
105
106 test_expect_missing     worktree2/ignored
107 test_expect_exists      worktree2/ignored-by-tree
108 test_expect_missing     worktree2/ignored-by-worktree
109
110 test_expect_success 'git archive vs. bare' '
111         (cd bare && git archive HEAD) >bare-archive.tar &&
112         test_cmp_bin archive.tar bare-archive.tar
113 '
114
115 test_expect_success 'git archive with worktree attributes, bare' '
116         (cd bare && git archive --worktree-attributes HEAD) >bare-worktree.tar &&
117         (mkdir bare-worktree && cd bare-worktree && "$TAR" xf -) <bare-worktree.tar
118 '
119
120 test_expect_missing     bare-worktree/ignored
121 test_expect_exists      bare-worktree/ignored-by-tree
122 test_expect_exists      bare-worktree/ignored-by-worktree
123
124 test_expect_success 'export-subst' '
125         git log "--pretty=format:A${SUBSTFORMAT}O" HEAD >substfile1.expected &&
126         test_cmp nosubstfile archive/nosubstfile &&
127         test_cmp substfile1.expected archive/substfile1 &&
128         test_cmp substfile2 archive/substfile2
129 '
130
131 test_done