aboutsummaryrefslogtreecommitdiff
path: root/t/t5609-clone-branch.sh
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2016-04-14 18:37:16 -0700
committerJunio C Hamano <gitster@pobox.com>2016-04-14 18:37:17 -0700
commit5859f04f0807264c03951a2e7be9192e00487039 (patch)
tree241dfd0263feae8ecd818beface814cfae7cffc5 /t/t5609-clone-branch.sh
parent485c7ade03c219e1b6003d566b6d0eae7bd44e1b (diff)
parent8fbb03a180c7113d311988693e96fe016ff59c6d (diff)
downloadgit-5859f04f0807264c03951a2e7be9192e00487039.tar.gz
git-5859f04f0807264c03951a2e7be9192e00487039.tar.xz
Merge branch 'sb/clone-t57-t56' into maint
Rename bunch of tests on "git clone" for better organization. * sb/clone-t57-t56: clone tests: rename t57* => t56*
Diffstat (limited to 't/t5609-clone-branch.sh')
-rwxr-xr-xt/t5609-clone-branch.sh70
1 files changed, 70 insertions, 0 deletions
diff --git a/t/t5609-clone-branch.sh b/t/t5609-clone-branch.sh
new file mode 100755
index 000000000..6e7a7be05
--- /dev/null
+++ b/t/t5609-clone-branch.sh
@@ -0,0 +1,70 @@
+#!/bin/sh
+
+test_description='clone --branch option'
+. ./test-lib.sh
+
+check_HEAD() {
+ echo refs/heads/"$1" >expect &&
+ git symbolic-ref HEAD >actual &&
+ test_cmp expect actual
+}
+
+check_file() {
+ echo "$1" >expect &&
+ test_cmp expect file
+}
+
+test_expect_success 'setup' '
+ mkdir parent &&
+ (cd parent && git init &&
+ echo one >file && git add file && git commit -m one &&
+ git checkout -b two &&
+ echo two >file && git add file && git commit -m two &&
+ git checkout master) &&
+ mkdir empty &&
+ (cd empty && git init)
+'
+
+test_expect_success 'vanilla clone chooses HEAD' '
+ git clone parent clone &&
+ (cd clone &&
+ check_HEAD master &&
+ check_file one
+ )
+'
+
+test_expect_success 'clone -b chooses specified branch' '
+ git clone -b two parent clone-two &&
+ (cd clone-two &&
+ check_HEAD two &&
+ check_file two
+ )
+'
+
+test_expect_success 'clone -b sets up tracking' '
+ (cd clone-two &&
+ echo origin >expect &&
+ git config branch.two.remote >actual &&
+ echo refs/heads/two >>expect &&
+ git config branch.two.merge >>actual &&
+ test_cmp expect actual
+ )
+'
+
+test_expect_success 'clone -b does not munge remotes/origin/HEAD' '
+ (cd clone-two &&
+ echo refs/remotes/origin/master >expect &&
+ git symbolic-ref refs/remotes/origin/HEAD >actual &&
+ test_cmp expect actual
+ )
+'
+
+test_expect_success 'clone -b with bogus branch' '
+ test_must_fail git clone -b bogus parent clone-bogus
+'
+
+test_expect_success 'clone -b not allowed with empty repos' '
+ test_must_fail git clone -b branch empty clone-branch-empty
+'
+
+test_done