path: root/t/
diff options
authorDavid Kastrup <>2007-08-13 05:38:11 (GMT)
committerJunio C Hamano <>2007-08-14 04:19:48 (GMT)
commit30c5cd312472574f6a8d8c82ba7c4af76d43ff7c (patch)
tree2f0b7f8ef92158051aa70fcbc4ec082b32e5de7c /t/
parentb2bc9a30981ace8c18d1a73b3e10153efc5c20f7 (diff)
Add a test for git-commit being confused by relative GIT_DIR
Signed-off-by: David Kastrup <> Signed-off-by: Junio C Hamano <>
Diffstat (limited to 't/')
1 files changed, 55 insertions, 0 deletions
diff --git a/t/ b/t/
new file mode 100755
index 0000000..88f268b
--- /dev/null
+++ b/t/
@@ -0,0 +1,55 @@
+test_description='check problems with relative GIT_DIR
+This test creates a working tree state with a file and subdir:
+ top (committed several times)
+ subdir (a subdirectory)
+It creates a commit-hook and tests it, then moves .git
+into the subdir while keeping the worktree location,
+and tries commits from the top and the subdir, checking
+that the commit-hook still gets called.'
+. ./
+test_expect_success 'Setting up post-commit hook' '
+mkdir -p .git/hooks &&
+echo >.git/hooks/post-commit "#!/bin/sh
+touch \"\${COMMIT_FILE}\"
+echo Post commit hook was called." &&
+chmod +x .git/hooks/post-commit'
+test_expect_success 'post-commit hook used ordinarily' '
+echo initial >top &&
+git-add top
+git-commit -m initial &&
+test -r "${COMMIT_FILE}"
+rm -rf "${COMMIT_FILE}"
+mkdir subdir
+mv .git subdir
+test_expect_success 'post-commit-hook created and used from top dir' '
+echo changed >top &&
+git --git-dir subdir/.git add top &&
+git --git-dir subdir/.git commit -m topcommit &&
+test -r "${COMMIT_FILE}"
+rm -rf "${COMMIT_FILE}"
+test_expect_success 'post-commit-hook from sub dir' '
+echo changed again >top
+cd subdir &&
+git --git-dir .git --work-tree .. add ../top &&
+git --git-dir .git --work-tree .. commit -m subcommit &&
+test -r "${COMMIT_FILE}"