2 . ./wvtest-bup.sh || exit $?
7 top="$(WVPASS pwd)" || exit $?
8 tmpdir="$(WVPASS wvmktempdir)" || exit $?
10 export BUP_DIR="$tmpdir/bup"
11 export GIT_DIR="$tmpdir/bup"
13 if test "$BUP_TEST_REMOTE_REPO"; then
19 bup() { "$top/bup" "$@"; }
22 if test "$BUP_TEST_REMOTE_REPO"; then
23 "$top/bup" ls -r "$BUP_DIR" "$@"
36 WVPASS touch src/.dotfile src/executable
37 WVPASS mkfifo src/fifo
38 WVPASS "$top"/t/mksock src/socket
39 WVPASS bup random 1k > src/file
40 WVPASS chmod u+x src/executable
41 WVPASS chmod -R u=rwX,g-rwx,o-rwx .
42 WVPASS touch -t 200910032348 src/.dotfile src/*
43 (WVPASS cd src; WVPASS ln -s file symlink) || exit $?
44 (WVPASS cd src; WVPASS ln -s not-there bad-symlink) || exit $?
45 WVPASS touch -t 200910032348 src
46 WVPASS touch -t 200910032348 .
48 WVPASS bup save -n src -d 242312160 --strip src
49 WVPASS bup tag some-tag src
51 uid="$(WVPASS id -u)" || exit $?
52 gid="$(WVPASS bup-python -c 'import os; print os.stat("src").st_gid')" || exit $?
53 user="$(WVPASS id -un)" || exit $?
54 group="$(WVPASS bup-python -c 'import grp, os;
55 print grp.getgrgid(os.stat("src").st_gid)[0]')" || exit $?
56 src_commit_hash=$(git log --format=%H -n1 src)
57 src_tree_hash=$(git log --format=%T -n1 src)
60 WVSTART "$ls_cmd_desc (short)"
62 (export BUP_FORCE_TTY=1; WVPASSEQ "$(WVPASS bup-ls | tr -d ' ')" src)
64 WVPASSEQ "$(WVPASS bup-ls /)" "src"
66 WVPASSEQ "$(WVPASS bup-ls -A /)" ".tag
69 WVPASSEQ "$(WVPASS bup-ls -AF /)" ".tag/
72 WVPASSEQ "$(WVPASS bup-ls -a /)" ".
77 WVPASSEQ "$(WVPASS bup-ls -aF /)" "./
82 WVPASSEQ "$(WVPASS bup-ls /.tag)" "some-tag"
84 WVPASSEQ "$(WVPASS bup-ls /src)" \
88 WVPASSEQ "$(WVPASS bup-ls src/latest)" "bad-symlink
95 WVPASSEQ "$(WVPASS bup-ls -A src/latest)" ".dotfile
103 WVPASSEQ "$(WVPASS bup-ls -a src/latest)" ".
113 WVPASSEQ "$(WVPASS bup-ls -F src/latest)" "bad-symlink@
120 WVPASSEQ "$(WVPASS bup-ls --file-type src/latest)" "bad-symlink@
127 WVPASSEQ "$(WVPASS bup-ls -d src/latest)" "src/latest"
130 WVSTART "$ls_cmd_desc (long)"
132 WVPASSEQ "$(WVPASS bup-ls -l / | tr -s ' ' ' ')" \
133 "drwx------ $user/$group 0 2009-10-03 23:48 src"
135 WVPASSEQ "$(WVPASS bup-ls -lA / | tr -s ' ' ' ')" \
136 "drwxr-xr-x 0/0 0 1970-01-01 00:00 .tag
137 drwx------ $user/$group 0 2009-10-03 23:48 src"
139 WVPASSEQ "$(WVPASS bup-ls -lAF / | tr -s ' ' ' ')" \
140 "drwxr-xr-x 0/0 0 1970-01-01 00:00 .tag/
141 drwx------ $user/$group 0 2009-10-03 23:48 src/"
143 WVPASSEQ "$(WVPASS bup-ls -la / | tr -s ' ' ' ')" \
144 "drwxr-xr-x 0/0 0 1970-01-01 00:00 .
145 drwxr-xr-x 0/0 0 1970-01-01 00:00 ..
146 drwxr-xr-x 0/0 0 1970-01-01 00:00 .tag
147 drwx------ $user/$group 0 2009-10-03 23:48 src"
149 WVPASSEQ "$(WVPASS bup-ls -laF / | tr -s ' ' ' ')" \
150 "drwxr-xr-x 0/0 0 1970-01-01 00:00 ./
151 drwxr-xr-x 0/0 0 1970-01-01 00:00 ../
152 drwxr-xr-x 0/0 0 1970-01-01 00:00 .tag/
153 drwx------ $user/$group 0 2009-10-03 23:48 src/"
155 socket_mode="$(WVPASS ls -l src/socket | cut -b -10)" || exit $?
158 bad_symlink_mode="$(WVPASS ls -l src/bad-symlink | cut -b -10)" || exit $?
160 bad_symlink_bup_info="$(WVPASS bup-ls -l src/latest | grep bad-symlink)" \
162 bad_symlink_date="$(WVPASS echo "$bad_symlink_bup_info" \
163 | WVPASS perl -ne 'm/.*? (\d+) (\d\d\d\d-\d\d-\d\d \d\d:\d\d)/ and print $2')" \
166 test "$bad_symlink_date" || exit 1
168 if test "$(uname -s)" != NetBSD; then
169 bad_symlink_size="$(WVPASS bup-python -c "import os
170 print os.lstat('src/bad-symlink').st_size")" || exit $?
172 # NetBSD appears to return varying sizes, so for now, just ignore it.
173 bad_symlink_size="$(WVPASS echo "$bad_symlink_bup_info" \
174 | WVPASS perl -ne 'm/.*? (\d+) (\d\d\d\d-\d\d-\d\d \d\d:\d\d)/ and print $1')" \
179 symlink_mode="$(WVPASS ls -l src/symlink | cut -b -10)" || exit $?
181 symlink_bup_info="$(WVPASS bup-ls -l src/latest | grep -E '[^-]symlink')" \
183 symlink_date="$(WVPASS echo "$symlink_bup_info" \
184 | WVPASS perl -ne 'm/.*? (\d+) (\d\d\d\d-\d\d-\d\d \d\d:\d\d)/ and print $2')" \
187 test "$symlink_date" || exit 1
189 if test "$(uname -s)" != NetBSD; then
190 symlink_size="$(WVPASS bup-python -c "import os
191 print os.lstat('src/symlink').st_size")" || exit $?
193 # NetBSD appears to return varying sizes, so for now, just ignore it.
194 symlink_size="$(WVPASS echo "$symlink_bup_info" \
195 | WVPASS perl -ne 'm/.*? (\d+) (\d\d\d\d-\d\d-\d\d \d\d:\d\d)/ and print $1')" \
199 WVPASSEQ "$(bup-ls -l src/latest | tr -s ' ' ' ')" \
200 "$bad_symlink_mode $user/$group $bad_symlink_size $bad_symlink_date bad-symlink -> not-there
201 -rwx------ $user/$group 0 2009-10-03 23:48 executable
202 prw------- $user/$group 0 2009-10-03 23:48 fifo
203 -rw------- $user/$group 1024 2009-10-03 23:48 file
204 $socket_mode $user/$group 0 2009-10-03 23:48 socket
205 $symlink_mode $user/$group $symlink_size $symlink_date symlink -> file"
207 WVPASSEQ "$(bup-ls -la src/latest | tr -s ' ' ' ')" \
208 "drwx------ $user/$group 0 2009-10-03 23:48 .
209 drwx------ $user/$group 0 2009-10-03 23:48 ..
210 -rw------- $user/$group 0 2009-10-03 23:48 .dotfile
211 $bad_symlink_mode $user/$group $bad_symlink_size $bad_symlink_date bad-symlink -> not-there
212 -rwx------ $user/$group 0 2009-10-03 23:48 executable
213 prw------- $user/$group 0 2009-10-03 23:48 fifo
214 -rw------- $user/$group 1024 2009-10-03 23:48 file
215 $socket_mode $user/$group 0 2009-10-03 23:48 socket
216 $symlink_mode $user/$group $symlink_size $symlink_date symlink -> file"
218 WVPASSEQ "$(bup-ls -lA src/latest | tr -s ' ' ' ')" \
219 "-rw------- $user/$group 0 2009-10-03 23:48 .dotfile
220 $bad_symlink_mode $user/$group $bad_symlink_size $bad_symlink_date bad-symlink -> not-there
221 -rwx------ $user/$group 0 2009-10-03 23:48 executable
222 prw------- $user/$group 0 2009-10-03 23:48 fifo
223 -rw------- $user/$group 1024 2009-10-03 23:48 file
224 $socket_mode $user/$group 0 2009-10-03 23:48 socket
225 $symlink_mode $user/$group $symlink_size $symlink_date symlink -> file"
227 WVPASSEQ "$(bup-ls -lF src/latest | tr -s ' ' ' ')" \
228 "$bad_symlink_mode $user/$group $bad_symlink_size $bad_symlink_date bad-symlink@ -> not-there
229 -rwx------ $user/$group 0 2009-10-03 23:48 executable*
230 prw------- $user/$group 0 2009-10-03 23:48 fifo|
231 -rw------- $user/$group 1024 2009-10-03 23:48 file
232 $socket_mode $user/$group 0 2009-10-03 23:48 socket=
233 $symlink_mode $user/$group $symlink_size $symlink_date symlink@ -> file"
235 WVPASSEQ "$(bup-ls -l --file-type src/latest | tr -s ' ' ' ')" \
236 "$bad_symlink_mode $user/$group $bad_symlink_size $bad_symlink_date bad-symlink@ -> not-there
237 -rwx------ $user/$group 0 2009-10-03 23:48 executable
238 prw------- $user/$group 0 2009-10-03 23:48 fifo|
239 -rw------- $user/$group 1024 2009-10-03 23:48 file
240 $socket_mode $user/$group 0 2009-10-03 23:48 socket=
241 $symlink_mode $user/$group $symlink_size $symlink_date symlink@ -> file"
243 WVPASSEQ "$(bup-ls -ln src/latest | tr -s ' ' ' ')" \
244 "$bad_symlink_mode $uid/$gid $bad_symlink_size $bad_symlink_date bad-symlink -> not-there
245 -rwx------ $uid/$gid 0 2009-10-03 23:48 executable
246 prw------- $uid/$gid 0 2009-10-03 23:48 fifo
247 -rw------- $uid/$gid 1024 2009-10-03 23:48 file
248 $socket_mode $uid/$gid 0 2009-10-03 23:48 socket
249 $symlink_mode $uid/$gid $symlink_size $symlink_date symlink -> file"
251 WVPASSEQ "$(bup-ls -ld "src/latest" | tr -s ' ' ' ')" \
252 "drwx------ $user/$group 0 2009-10-03 23:48 src/latest"
255 WVSTART "$ls_cmd_desc (backup set - long)"
256 WVPASSEQ "$(bup-ls -l --numeric-ids src | cut -d' ' -f 1-2)" \
257 "drwx------ $uid/$gid
258 drwx------ $uid/$gid"
260 WVPASSEQ "$(bup-ls -ds "src/latest" | tr -s ' ' ' ')" \
261 "$src_tree_hash src/latest"
263 WVPASSEQ "$(bup-ls -ds --commit-hash "src/latest" | tr -s ' ' ' ')" \
264 "$src_commit_hash src/latest"
267 WVSTART "$ls_cmd_desc (dates TZ != UTC)"
268 export TZ=America/Chicago
269 bad_symlink_date_central="$(bup-ls -l src/latest | grep bad-symlink)"
270 bad_symlink_date_central="$(echo "$bad_symlink_date_central" \
271 | perl -ne 'm/.*? (\d+) (\d\d\d\d-\d\d-\d\d \d\d:\d\d)/ and print $2')"
272 symlink_date_central="$(bup-ls -l src/latest | grep -E '[^-]symlink')"
273 symlink_date_central="$(echo "$symlink_date_central" \
274 | perl -ne 'm/.*? (\d+) (\d\d\d\d-\d\d-\d\d \d\d:\d\d)/ and print $2')"
275 WVPASSEQ "$(bup-ls -ln src/latest | tr -s ' ' ' ')" \
276 "$bad_symlink_mode $uid/$gid $bad_symlink_size $bad_symlink_date_central bad-symlink -> not-there
277 -rwx------ $uid/$gid 0 2009-10-03 18:48 executable
278 prw------- $uid/$gid 0 2009-10-03 18:48 fifo
279 -rw------- $uid/$gid 1024 2009-10-03 18:48 file
280 $socket_mode $uid/$gid 0 2009-10-03 18:48 socket
281 $symlink_mode $uid/$gid $symlink_size $symlink_date_central symlink -> file"
285 WVSTART "$ls_cmd_desc bad-symlink"
286 WVPASSEQ "$(bup-ls "src/latest/bad-symlink")" "src/latest/bad-symlink"
288 WVSTART "$ls_cmd_desc -l bad-symlink"
289 WVPASSEQ "$(bup-ls -l src/latest/bad-symlink | tr -s ' ' ' ')" \
290 "$bad_symlink_mode $user/$group $bad_symlink_size $bad_symlink_date src/latest/bad-symlink -> not-there"
293 WVPASS rm -rf "$tmpdir"