Merge branch 'jc/exclusion-doc'
[alt-git.git] / t / t1301-shared-repo.sh
blobac108754088d34758a75f14943516c4a701f0ca8
1 #!/bin/sh
3 # Copyright (c) 2007 Johannes Schindelin
6 test_description='Test shared repository initialization'
8 . ./test-lib.sh
10 # Remove a default ACL from the test dir if possible.
11 setfacl -k . 2>/dev/null
13 # User must have read permissions to the repo -> failure on --shared=0400
14 test_expect_success 'shared = 0400 (faulty permission u-w)' '
15 test_when_finished "rm -rf sub" &&
16 mkdir sub && (
17 cd sub &&
18 test_must_fail git init --shared=0400
22 modebits () {
23 ls -l "$1" | sed -e 's|^\(..........\).*|\1|'
26 for u in 002 022
28 test_expect_success POSIXPERM "shared=1 does not clear bits preset by umask $u" '
29 mkdir sub && (
30 cd sub &&
31 umask $u &&
32 git init --shared=1 &&
33 test 1 = "$(git config core.sharedrepository)"
34 ) &&
35 actual=$(ls -l sub/.git/HEAD) &&
36 case "$actual" in
37 -rw-rw-r--*)
38 : happy
41 echo Oops, .git/HEAD is not 0664 but $actual
42 false
44 esac
46 rm -rf sub
47 done
49 test_expect_success 'shared=all' '
50 mkdir sub &&
51 cd sub &&
52 git init --shared=all &&
53 test 2 = $(git config core.sharedrepository)
56 test_expect_success POSIXPERM 'update-server-info honors core.sharedRepository' '
57 : > a1 &&
58 git add a1 &&
59 test_tick &&
60 git commit -m a1 &&
61 umask 0277 &&
62 git update-server-info &&
63 actual="$(ls -l .git/info/refs)" &&
64 case "$actual" in
65 -r--r--r--*)
66 : happy
69 echo Oops, .git/info/refs is not 0444
70 false
72 esac
75 for u in 0660:rw-rw---- \
76 0640:rw-r----- \
77 0600:rw------- \
78 0666:rw-rw-rw- \
79 0664:rw-rw-r--
81 x=$(expr "$u" : ".*:\([rw-]*\)") &&
82 y=$(echo "$x" | sed -e "s/w/-/g") &&
83 u=$(expr "$u" : "\([0-7]*\)") &&
84 git config core.sharedrepository "$u" &&
85 umask 0277 &&
87 test_expect_success POSIXPERM "shared = $u ($y) ro" '
89 rm -f .git/info/refs &&
90 git update-server-info &&
91 actual="$(modebits .git/info/refs)" &&
92 verbose test "x$actual" = "x-$y"
96 umask 077 &&
97 test_expect_success POSIXPERM "shared = $u ($x) rw" '
99 rm -f .git/info/refs &&
100 git update-server-info &&
101 actual="$(modebits .git/info/refs)" &&
102 verbose test "x$actual" = "x-$x"
106 done
108 test_expect_success POSIXPERM 'info/refs respects umask in unshared repo' '
109 rm -f .git/info/refs &&
110 test_unconfig core.sharedrepository &&
111 umask 002 &&
112 git update-server-info &&
113 echo "-rw-rw-r--" >expect &&
114 modebits .git/info/refs >actual &&
115 test_cmp expect actual
118 test_expect_success POSIXPERM 'git reflog expire honors core.sharedRepository' '
119 umask 077 &&
120 git config core.sharedRepository group &&
121 git reflog expire --all &&
122 actual="$(ls -l .git/logs/refs/heads/master)" &&
123 case "$actual" in
124 -rw-rw-*)
125 : happy
128 echo Ooops, .git/logs/refs/heads/master is not 0662 [$actual]
129 false
131 esac
134 test_expect_success POSIXPERM 'forced modes' '
135 mkdir -p templates/hooks &&
136 echo update-server-info >templates/hooks/post-update &&
137 chmod +x templates/hooks/post-update &&
138 echo : >random-file &&
139 mkdir new &&
141 cd new &&
142 umask 002 &&
143 git init --shared=0660 --template=../templates &&
144 >frotz &&
145 git add frotz &&
146 git commit -a -m initial &&
147 git repack
148 ) &&
149 # List repository files meant to be protected; note that
150 # COMMIT_EDITMSG does not matter---0mode is not about a
151 # repository with a work tree.
152 find new/.git -type f -name COMMIT_EDITMSG -prune -o -print |
153 xargs ls -ld >actual &&
155 # Everything must be unaccessible to others
156 test -z "$(sed -e "/^.......---/d" actual)" &&
158 # All directories must have either 2770 or 770
159 test -z "$(sed -n -e "/^drwxrw[sx]---/d" -e "/^d/p" actual)" &&
161 # post-update hook must be 0770
162 test -z "$(sed -n -e "/post-update/{
163 /^-rwxrwx---/d
165 }" actual)" &&
167 # All files inside objects must be accessible by us
168 test -z "$(sed -n -e "/objects\//{
169 /^d/d
170 /^-r.-r.----/d
172 }" actual)"
175 test_done