aboutsummaryrefslogtreecommitdiff
path: root/t/t5600-clone-fail-cleanup.sh
diff options
context:
space:
mode:
Diffstat (limited to 't/t5600-clone-fail-cleanup.sh')
-rwxr-xr-xt/t5600-clone-fail-cleanup.sh42
1 files changed, 42 insertions, 0 deletions
diff --git a/t/t5600-clone-fail-cleanup.sh b/t/t5600-clone-fail-cleanup.sh
new file mode 100755
index 000000000..ee06d2864
--- /dev/null
+++ b/t/t5600-clone-fail-cleanup.sh
@@ -0,0 +1,42 @@
+#!/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' \
+ 'test_must_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' \
+ 'test_must_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