5 export BUP_DIR="$TOP/buptest.tmp"
12 # Very simple metadata tests -- create a test tree then check that bup
13 # meta can reproduce the metadata correctly (according to bup xstat)
14 # via create, extract, start-extract, and finish-extract. The current
15 # tests are crude, and this does not fully test devices, varying
16 # users/groups, acls, attrs, etc.
21 export PATH="$TOP:$PATH" # pick up bup
22 # Skip atime (test elsewhere) to avoid the observer effect.
23 find . | sort | xargs bup xstat --exclude-fields ctime,atime
29 test "$(whoami)" == root -a -z "$FAKEROOTKEY"
34 if ! actually-root; then
37 # Go to greater lengths to deal with any test detritus.
39 test -e "$@" || continue
40 chattr -fR = "$@" || true
47 test-src-create-extract()
49 # Test bup meta create/extract for ./src -> ./src-restore.
50 # Also writes to ./src-stat and ./src-restore-stat.
52 (cd src && WVPASS genstat) > src-stat
53 WVPASS bup meta --create --recurse --file src.meta src
55 force-delete src-restore
58 WVPASS bup meta --extract --file ../src.meta
60 (cd src && genstat >../../src-restore-stat) || WVFAIL
61 WVPASS diff -U5 ../src-stat ../src-restore-stat
62 # Test start/finish extract.
64 WVPASS bup meta --start-extract --file ../src.meta
66 WVPASS bup meta --finish-extract --file ../src.meta
67 (cd src && genstat >../../src-restore-stat) || WVFAIL
68 WVPASS diff -U5 ../src-stat ../src-restore-stat
72 if actually-root; then
73 umount "$TOP/bupmeta.tmp/testfs" || true
76 force-delete "$BUP_DIR"
77 force-delete "$TOP/bupmeta.tmp"
82 rm -rf "$TOP/bupmeta.tmp/src"
83 mkdir -p "$TOP/bupmeta.tmp/src"
84 #cp -a Documentation cmd lib t "$TOP/bupmeta.tmp"/src
85 cp -pPR Documentation cmd lib t "$TOP/bupmeta.tmp"/src
86 t/mksock "$TOP/bupmeta.tmp/src/test-socket" || true
89 # Use the test tree to check bup meta.
90 WVSTART 'meta - general'
93 test-src-create-extract
96 # Root-only tests: ACLs, Linux attr, Linux xattr, etc.
97 if actually-root; then
102 umount "$TOP/bupmeta.tmp/testfs" || true
105 trap cleanup_at_exit EXIT
107 WVSTART 'meta - general (as root)'
108 WVPASS cd "$TOP/bupmeta.tmp"
109 umount testfs || true
110 dd if=/dev/zero of=testfs.img bs=1M count=32
111 mke2fs -F -j -m 0 testfs.img
113 mount -o loop,acl,user_xattr testfs.img testfs
114 # Hide, so that tests can't create risks.
115 chown root:root testfs
118 #cp -a src testfs/src
119 cp -pPR src testfs/src
120 (cd testfs && test-src-create-extract)
122 WVSTART 'meta - atime (as root)'
123 force-delete testfs/src
128 PYTHONPATH="$TOP/lib" \
129 python -c "from bup import xstat; \
130 x = xstat.timespec_to_nsecs((42, 0));\
131 xstat.utime('testfs/src/foo', (x, x));\
132 xstat.utime('testfs/src/bar', (x, x));"
134 WVPASS bup meta -v --create --recurse --file src.meta src
135 bup meta -tvf src.meta
137 force-delete src-restore
140 WVPASS bup meta --extract --file ../src.meta
141 WVPASSEQ "$(bup xstat --include-fields=atime src/foo)" "atime: 42"
142 WVPASSEQ "$(bup xstat --include-fields=atime src/bar)" "atime: 42"
143 # Test start/finish extract.
145 WVPASS bup meta --start-extract --file ../src.meta
147 WVPASS bup meta --finish-extract --file ../src.meta
148 WVPASSEQ "$(bup xstat --include-fields=atime src/foo)" "atime: 42"
149 WVPASSEQ "$(bup xstat --include-fields=atime src/bar)" "atime: 42"
152 WVSTART 'meta - Linux attr (as root)'
153 force-delete testfs/src
158 chattr +acdeijstuADST testfs/src/foo
159 chattr +acdeijstuADST testfs/src/bar
160 (cd testfs && test-src-create-extract)
163 WVSTART 'meta - Linux xattr (as root)'
164 force-delete testfs/src
169 attr -s foo -V bar testfs/src/foo
170 attr -s foo -V bar testfs/src/bar
171 (cd testfs && test-src-create-extract)
174 WVSTART 'meta - POSIX.1e ACLs (as root)'
175 force-delete testfs/src
180 setfacl -m u:root:r testfs/src/foo
181 setfacl -m u:root:r testfs/src/bar
182 (cd testfs && test-src-create-extract)