3
# Simple shell-based tests for bzr.
5
# This is meant to exercise the external behaviour, command line
6
# parsing and similar things and compliment the inwardly-turned
7
# testing done by doctest.
9
# This must already exist and be in the right place
10
if ! [ -d bzr-test.tmp ]
12
echo "please create directory bzr-test.tmp"
16
echo "testing `which bzr`"
17
bzr --version | head -n 1
23
# save it for real errors
31
echo "tests failed, look in bzr-test.log" >&3; exit 2;
42
# some information commands
46
[ $(bzr help commands | wc -l) -gt 20 ]
48
# invalid commands are detected
51
# some experiments with renames
53
echo "hello world" > test.txt
56
# should be the only unknown file
57
[ "`bzr unknowns`" = test.txt ]
59
bzr status --all > status.tmp
60
! diff -u - status.tmp <<EOF
66
bzr st --all | diff -u - status.tmp
68
# can't rename unversioned files; use the regular unix rename command
69
! bzr rename test.txt new-test.txt
71
# ok, so now add it and see what happens
73
[ -z "`bzr unknowns`" ]
75
# after adding even before committing you can rename files
76
bzr rename test.txt newname.txt
77
[ "`bzr status`" = "A newname.txt" ]
80
bzr commit -m "add first revision"
83
# now more complicated renames
85
! bzr rename newname.txt sub1
86
! bzr rename newname.txt sub1/foo.txt
88
! bzr rename newname.txt sub1
90
bzr rename newname.txt sub1/foo.txt
94
bzr rename sub1/foo.txt newname.txt
97
bzr rename newname.txt sub1/foo.txt
98
bzr rename sub1/foo.txt sub1/bar.txt
103
bzr rename bar.txt sub2/bar.txt
105
bzr rename bar.txt ../../bar.txt
108
bzr commit -m "more renames"
111
# now try pulling that file back out, checking it was stored properly
112
[ "`bzr cat -r 1 newname.txt`" = "hello world" ]
114
! bzr rename sub1 sub1/knotted-up
120
# now test hardlinked branches in subdirectories
122
[ -d branch2 ] && rm -rf branch2
123
cp -al branch1 branch2
129
echo "added in branch2" > new-in-2.txt
131
bzr commit -m "add file to branch 2 only"
141
echo "tests completed ok" >&3
b'\\ No newline at end of file'