#!/bin/sh test_description='selecting remote repo in ambiguous cases' . ./test-lib.sh reset() { rm -rf foo foo.git fetch clone } make_tree() { git init "$1" && (cd "$1" && test_commit "$1") } make_bare() { git init --bare "$1" && (cd "$1" && tree=$(git hash-object -w -t tree /dev/null) && commit=$(echo "$1" | git commit-tree $tree) && git update-ref HEAD $commit ) } get() { git init --bare fetch && (cd fetch && git fetch "../$1") && git clone "$1" clone } check() { echo "$1" >expect && (cd fetch && git log -1 --format=%s FETCH_HEAD) >actual.fetch && (cd clone && git log -1 --format=%s HEAD) >actual.clone && test_cmp expect actual.fetch && test_cmp expect actual.clone } test_expect_success 'find .git dir in worktree' ' reset && make_tree foo && get foo && check foo ' test_expect_success 'automagically add .git suffix' ' reset && make_bare foo.git && get foo && check foo.git ' test_expect_success 'automagically add .git suffix to worktree' ' reset && make_tree foo.git && get foo && check foo.git ' test_expect_success 'prefer worktree foo over bare foo.git' ' reset && make_tree foo && make_bare foo.git && get foo && check foo ' test_expect_success 'prefer bare foo over bare foo.git' ' reset && make_bare foo && make_bare foo.git && get foo && check foo ' test_expect_success 'disambiguate with full foo.git' ' reset && make_bare foo && make_bare foo.git && get foo.git && check foo.git ' test_expect_success 'we are not fooled by non-git foo directory' ' reset && make_bare foo.git && mkdir foo && get foo && check foo.git ' test_expect_success 'prefer inner .git over outer bare' ' reset && make_tree foo && make_bare foo.git && mv foo/.git foo.git && get foo.git && check foo ' test_done