3 # Run a backup of the Bacula build directory with some acls then restore it.
6 # Your filesystem must be mounted with the acl option (mount -o remount,acl,user_xattr /tmp)
7 # on ubuntu, the attr package must be installed
9 # For this script to work, you will also need a number of acl packages loaded
10 # not default on Debian derivatives:
11 # apt-get install acl libacl1 libacl1-dev attr
13 # For OSX and Solaris:
15 # Defaults should be ok
19 # Your filesystem must have acls enabled and needs to be mounted with acls.
20 # tunefs -a enable <device>
21 # acls mountoption in /etc/fstab
25 # Defaults should be ok (As NetBSD doesn't support native acls we skip that test).
27 TestName="acl-xattr-test"
32 # See if the right software is installed.
36 # Require getfacl to be installed
37 getfacl Makefile 2>&1 >/dev/null
38 if test $? -ne 0; then
39 echo "$TestName skipped: getfacl not installed"
43 # Require getfattr to be installed
44 getfattr -d Makefile 2>&1 >/dev/null
45 if test $? -ne 0; then
46 echo "$TestName skipped: getfattr not installed"
55 # Require getfacl to be installed
56 getfacl Makefile 2>&1 >/dev/null
57 if test $? -ne 0; then
58 echo "$TestName skipped: getfacl not installed"
62 # Require lsextattr to be installed
63 lsextattr user Makefile 2>&1 >/dev/null
64 if test $? -ne 0; then
65 echo "$TestName skipped: lsextattr not installed"
70 # Require lsextattr to be installed
71 lsextattr user Makefile 2>&1 >/dev/null
72 if test $? -ne 0; then
73 echo "$TestName skipped: lsextattr not installed"
87 # Zap out any schedule in default conf file so that
88 # it doesn't start during our test
91 echo "s% Schedule =%# Schedule =%g" > $outf
92 echo "s/Options {/Options { aclsupport=yes; xattrsupport = yes/" >> $outf
93 cp ${cwd}/bin/bacula-dir.conf $cwd/tmp/1
94 sed -f ${outf} ${cwd}/tmp/1 >${cwd}/bin/bacula-dir.conf
102 cp ${cwd}/bin/bconsole $d
106 setfacl -m d:user:$uid:r-x $d/acl-dir
107 setfacl -m d:user:root:-wx $d/acl-dir
108 setfacl -m user:nobody:--- $d/acl-dir
109 setfacl -m user:nobody:--- $d/bconsole
110 setfacl -m group:nogroup:--x $d/bconsole
111 cp ${cwd}/bin/bconsole $d/acl-dir
112 cp ${cwd}/bin/bconsole $d/other
113 setfattr -h -n user.bacula.test -v rulez $d/other 2>/dev/null 1>/dev/null
116 getfacl -R acl > $cwd/tmp/org
117 getfattr -h -n user.bacula.test $d/other > $cwd/tmp/attr.org
121 chmod +a "user:$uid allow read execute" $d/acl-dir
122 chmod +a "user:root allow write execute" $d/acl-dir
123 chmod +a "user:nobody deny read write execute" $d/acl-dir
124 chmod +a "user:nobody deny read write execute" $d/bconsole
125 chmod +a "group:nogroup allow execute" $d/bconsole
126 cp ${cwd}/bin/bconsole $d/acl-dir
127 cp ${cwd}/bin/bconsole $d/other
128 xattr -w bacula.test "rulez" $d/other 2>/dev/null 1>/dev/null
131 ls -lde -R acl > $cwd/tmp/org
132 xattr -p bacula.test $d/other > $cwd/tmp/attr.org
137 # See if we need to set ZFS or POSIX acls
139 df -F zfs $d > /dev/null 2>&1
141 /bin/chmod A+user:$uid:rx:allow $d/acl-dir
142 /bin/chmod A+user:root:wx:allow $d/acl-dir
143 /bin/chmod A+user:nobody:rwx:deny $d/acl-dir
144 /bin/chmod A+user:nobody:rwx:deny $d/bconsole
145 /bin/chmod A+group:nogroup:x:allow $d/bconsole
147 /bin/chmod A+user:$uid:r-x $d/acl-dir
148 /bin/chmod A+user:root:-wx $d/acl-dir
149 /bin/chmod A+user:nobody:--- $d/acl-dir
150 /bin/chmod A+user:nobody:--- $d/bconsole
151 /bin/chmod A+group:nogroup:--x $d/bconsole
153 cp ${cwd}/bin/bconsole $d/other
154 /bin/runat $d/other 'cat > bacula.test' << EOF
158 /bin/ls -ldv -R acl > $cwd/tmp/org
159 /bin/runat $d/other 'cat bacula.test' > $cwd/tmp/attr.org
163 setfacl -m d:user:$uid:r-x $d/acl-dir
164 setfacl -m d:user:root:-wx $d/acl-dir
165 setfacl -m user:nobody:--- $d/acl-dir
166 setfacl -m user:nobody:--- $d/bconsole
167 setfacl -m group:nogroup:--x $d/bconsole
168 cp ${cwd}/bin/bconsole $d/acl-dir
169 cp ${cwd}/bin/bconsole $d/other
170 setextattr user bacula.test rulez $d/other 2>/dev/null 1>/dev/null
177 getextattr user bacula.test $d/other > $cwd/tmp/attr.org
181 cp ${cwd}/bin/bconsole $d/other
182 setextattr user bacula.test rulez $d/other 2>/dev/null 1>/dev/null
185 cp /dev/null $cwd/tmp/org
186 getextattr user bacula.test $d/other > $cwd/tmp/attr.org
191 change_jobname BackupClient1 $JobName
194 cat <<END_OF_DATA >${cwd}/tmp/bconcmds
197 @$out ${cwd}/tmp/log1.out
198 label volume=TestVolume001 storage=File pool=File
199 setdebug level=400 trace=1 client
200 setdebug level=300 trace=1 director
201 setdebug level=300 trace=1 storage
208 @$out ${cwd}/tmp/log2.out
209 restore where=${cwd}/tmp/bacula-restores select all done
217 check_for_zombie_jobs storage=File
222 ( cd $cwd/tmp/bacula-restores/$cwd/build
223 getfacl -R acl > $cwd/tmp/new
224 getfattr -h -n user.bacula.test $d/other > $cwd/tmp/attr.new
228 ( cd $cwd/tmp/bacula-restores/$cwd/build
229 ls -lde -R acl > $cwd/tmp/new
230 xattr -p bacula.test $d/other > $cwd/tmp/attr.new
234 ( cd $cwd/tmp/bacula-restores/$cwd/build
235 /bin/ls -ldv -R acl > $cwd/tmp/new
236 /bin/runat $d/other 'cat bacula.test' > $cwd/tmp/attr.new
240 ( cd $cwd/tmp/bacula-restores/$cwd/build
245 getextattr user bacula.test $d/other > $cwd/tmp/attr.new
249 ( cd $cwd/tmp/bacula-restores/$cwd/build
250 cp /dev/null $cwd/tmp/new
251 getextattr user bacula.test $d/other > $cwd/tmp/attr.new
256 diff -u $cwd/tmp/org $cwd/tmp/new
257 if [ $? -ne 0 ]; then
261 diff $cwd/tmp/attr.org $cwd/tmp/attr.new
262 if [ $? -ne 0 ]; then
269 if [ x$REGRESS_DEBUG != x ]; then