2006-02-18 05:33:28 +08:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
|
|
|
# Copyright (C) 2006 Carl D. Worth <cworth@cworth.org>
|
|
|
|
#
|
|
|
|
|
2008-09-03 16:59:29 +08:00
|
|
|
test_description='test git clone to cleanup after failure
|
2006-02-18 05:33:28 +08:00
|
|
|
|
2008-09-03 16:59:29 +08:00
|
|
|
This test covers the fact that if git clone fails, it should remove
|
2006-02-18 05:33:28 +08:00
|
|
|
the directory it created, to avoid the user having to manually
|
|
|
|
remove the directory before attempting a clone again.'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
2008-02-01 17:50:53 +08:00
|
|
|
test_expect_success \
|
2006-02-18 05:33:28 +08:00
|
|
|
'clone of non-existent source should fail' \
|
2008-09-03 16:59:29 +08:00
|
|
|
'test_must_fail git clone foo bar'
|
2006-02-18 05:33:28 +08:00
|
|
|
|
2008-02-01 17:50:53 +08:00
|
|
|
test_expect_success \
|
2006-02-18 05:33:28 +08:00
|
|
|
'failed clone should not leave a directory' \
|
2008-02-01 17:50:53 +08:00
|
|
|
'! test -d bar'
|
2006-02-18 05:33:28 +08:00
|
|
|
|
|
|
|
# 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)
|
|
|
|
|
2008-09-03 16:59:29 +08:00
|
|
|
# source repository given to git clone should be relative to the
|
2006-10-14 20:02:51 +08:00
|
|
|
# current path not to the target dir
|
2008-02-01 17:50:53 +08:00
|
|
|
test_expect_success \
|
2006-10-14 20:02:51 +08:00
|
|
|
'clone of non-existent (relative to $PWD) source should fail' \
|
2008-09-03 16:59:29 +08:00
|
|
|
'test_must_fail git clone ../foo baz'
|
2006-10-14 20:02:51 +08:00
|
|
|
|
2006-02-18 05:33:28 +08:00
|
|
|
test_expect_success \
|
|
|
|
'clone should work now that source exists' \
|
2008-09-03 16:59:29 +08:00
|
|
|
'git clone foo bar'
|
2006-02-18 05:33:28 +08:00
|
|
|
|
|
|
|
test_expect_success \
|
2007-02-04 12:49:16 +08:00
|
|
|
'successful clone must leave the directory' \
|
2013-01-06 04:17:04 +08:00
|
|
|
'test -d bar'
|
|
|
|
|
|
|
|
test_expect_success 'failed clone --separate-git-dir should not leave any directories' '
|
|
|
|
mkdir foo/.git/objects.bak/ &&
|
|
|
|
mv foo/.git/objects/* foo/.git/objects.bak/ &&
|
|
|
|
test_must_fail git clone --separate-git-dir gitdir foo worktree &&
|
|
|
|
test_must_fail test -e gitdir &&
|
|
|
|
test_must_fail test -e worktree &&
|
|
|
|
mv foo/.git/objects.bak/* foo/.git/objects/ &&
|
|
|
|
rmdir foo/.git/objects.bak
|
|
|
|
'
|
2006-02-18 05:33:28 +08:00
|
|
|
|
|
|
|
test_done
|