| #!/bin/sh |
| # |
| # Copyright (C) 2006 Carl D. Worth <cworth@cworth.org> |
| # |
| |
| test_description='test git-clone to cleanup after failure |
| |
| This test covers the fact that if git-clone fails, it should remove |
| the directory it created, to avoid the user having to manually |
| remove the directory before attempting a clone again.' |
| |
| . ./test-lib.sh |
| |
| test_expect_success \ |
| 'clone of non-existent source should fail' \ |
| '! git-clone foo bar' |
| |
| test_expect_success \ |
| 'failed clone should not leave a directory' \ |
| '! test -d bar' |
| |
| # Need a repo to clone |
| test_create_repo foo |
| |
| # clone doesn't like it if there is no HEAD. Is that a bug? |
| (cd foo && touch file && git add file && git commit -m 'add file' >/dev/null 2>&1) |
| |
| # source repository given to git-clone should be relative to the |
| # current path not to the target dir |
| test_expect_success \ |
| 'clone of non-existent (relative to $PWD) source should fail' \ |
| '! git-clone ../foo baz' |
| |
| test_expect_success \ |
| 'clone should work now that source exists' \ |
| 'git-clone foo bar' |
| |
| test_expect_success \ |
| 'successful clone must leave the directory' \ |
| 'cd bar' |
| |
| test_done |