Mercurial > hg
view tests/test-clone-failure @ 9717:68a1b9d0663e
update: allow branch crossing without -c or -C, with no uncommitted changes
Update will now allow crossing branches within the same named branch,
when given a specific revision, if the working dir is clean, without
requiring the -c or -C option. Abort if no revision is given and
this would cross branches. Minor change to abort message if
uncommitted changes are found.
Modify test-update-branches and output to reflect the altered case. Modify
test-merge5.out to reflect the altered case. Modify
test-up-local-change.out with new message.
author | Stuart W Marks <smarks@smarks.org> |
---|---|
date | Thu, 05 Nov 2009 10:53:59 +0100 |
parents | 567648eab1dd |
children |
line wrap: on
line source
#!/bin/sh # No local source hg clone a b echo $? # No remote source hg clone http://127.0.0.1:3121/a b echo $? rm -rf b # work around bug with http clone # Inaccessible source mkdir a chmod 000 a hg clone a b echo $? # Inaccessible destination mkdir b cd b hg init hg clone . ../a echo $? cd .. chmod 700 a rm -r a b # Source of wrong type if "$TESTDIR/hghave" -q fifo; then mkfifo a hg clone a b echo $? rm a else echo "abort: repository a not found!" echo 255 fi # Default destination, same directory mkdir q cd q hg init cd .. hg clone q # destination directory not empty mkdir a echo stuff > a/a hg clone q a echo $? # leave existing directory in place after clone failure hg init c cd c echo c > c hg commit -A -m test chmod -rx .hg/store/data cd .. mkdir d hg clone c d 2> err echo $? test -d d && echo "dir is still here" || echo "dir is gone" test -d d/.hg && echo "repo is still here" || echo "repo is gone" # reenable perm to allow deletion chmod +rx c/.hg/store/data true