#!/bin/sh setglobal test_description = ''Test Git when git repository is located at root This test requires write access in root. Do not bother if you do not have a throwaway chroot or VM. Script t1509/prepare-chroot.sh may help you setup chroot, then you can chroot in and execute this test from there. '' source ./test-lib.sh proc test_cmp_val { echo $1 > expected echo $2 > result test_cmp expected result } proc test_vars { test_expect_success "$1: gitdir" ' test_cmp_val "'"$2"'" "$(git rev-parse --git-dir)" ' test_expect_success "$1: worktree" ' test_cmp_val "'"$3"'" "$(git rev-parse --show-toplevel)" ' test_expect_success "$1: prefix" ' test_cmp_val "'"$4"'" "$(git rev-parse --show-prefix)" ' } proc test_foobar_root { test_expect_success 'add relative' ' test -z "$(cd / && git ls-files)" && git add foo/foome && git add foo/bar/barme && git add me && ( cd / && git ls-files --stage ) > result && test_cmp /ls.expected result && rm "$(git rev-parse --git-dir)/index" ' test_expect_success 'add absolute' ' test -z "$(cd / && git ls-files)" && git add /foo/foome && git add /foo/bar/barme && git add /me && ( cd / && git ls-files --stage ) > result && test_cmp /ls.expected result && rm "$(git rev-parse --git-dir)/index" ' } proc test_foobar_foo { test_expect_success 'add relative' ' test -z "$(cd / && git ls-files)" && git add foome && git add bar/barme && git add ../me && ( cd / && git ls-files --stage ) > result && test_cmp /ls.expected result && rm "$(git rev-parse --git-dir)/index" ' test_expect_success 'add absolute' ' test -z "$(cd / && git ls-files)" && git add /foo/foome && git add /foo/bar/barme && git add /me && ( cd / && git ls-files --stage ) > result && test_cmp /ls.expected result && rm "$(git rev-parse --git-dir)/index" ' } proc test_foobar_foobar { test_expect_success 'add relative' ' test -z "$(cd / && git ls-files)" && git add ../foome && git add barme && git add ../../me && ( cd / && git ls-files --stage ) > result && test_cmp /ls.expected result && rm "$(git rev-parse --git-dir)/index" ' test_expect_success 'add absolute' ' test -z "$(cd / && git ls-files)" && git add /foo/foome && git add /foo/bar/barme && git add /me && ( cd / && git ls-files --stage ) > result && test_cmp /ls.expected result && rm "$(git rev-parse --git-dir)/index" ' } if ! test -w / { setglobal skip_all = '"Test requiring writable / skipped. Read this test if you want to run it'" test_done } if test -e /refs || test -e /objects || test -e /info || test -e /hooks || test -e /.git || test -e /foo || test -e /me { setglobal skip_all = '"Skip test that clobbers existing files in /'" test_done } if test $IKNOWWHATIAMDOING != "YES" { setglobal skip_all = '"You must set env var IKNOWWHATIAMDOING=YES in order to run this test'" test_done } if ! test_have_prereq NOT_ROOT { setglobal skip_all = '"No you can't run this as root'" test_done } setglobal ONE_SHA1 = 'd00491fd7e5bb6fa28c517a0bb32b8b506539d4d' test_expect_success 'setup' ' rm -rf /foo && mkdir /foo && mkdir /foo/bar && echo 1 > /foo/foome && echo 1 > /foo/bar/barme && echo 1 > /me ' say "GIT_DIR absolute, GIT_WORK_TREE set" test_expect_success 'go to /' 'cd /' cat >ls.expected < expected && git init > result && test_cmp expected result ' test_vars 'auto gitdir, root' ".git" "/" "" test_foobar_root test_expect_success 'go to /foo' 'cd /foo' test_vars 'auto gitdir, foo' "/.git" "/" "foo/" test_foobar_foo test_expect_success 'go to /foo/bar' 'cd /foo/bar' test_vars 'auto gitdir, foo/bar' "/.git" "/" "foo/bar/" test_foobar_foobar test_expect_success 'cleanup' 'rm -rf /.git' say "auto bare gitdir" # DESTROYYYYY!!!!! test_expect_success 'setup' ' rm -rf /refs /objects /info /hooks && rm -f /expected /ls.expected /me /result && cd / && echo "Initialized empty Git repository in /" > expected && git init --bare > result && test_cmp expected result ' test_vars 'auto gitdir, root' "." "" "" test_expect_success 'go to /foo' 'cd /foo' test_vars 'auto gitdir, root' "/" "" "" test_done