2007-06-06 15:14:25 +08:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='test separate work tree'
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
test_rev_parse() {
|
|
|
|
name=$1
|
|
|
|
shift
|
|
|
|
|
|
|
|
test_expect_success "$name: is-bare-repository" \
|
|
|
|
"test '$1' = \"\$(git rev-parse --is-bare-repository)\""
|
|
|
|
shift
|
|
|
|
[ $# -eq 0 ] && return
|
|
|
|
|
|
|
|
test_expect_success "$name: is-inside-git-dir" \
|
|
|
|
"test '$1' = \"\$(git rev-parse --is-inside-git-dir)\""
|
|
|
|
shift
|
|
|
|
[ $# -eq 0 ] && return
|
|
|
|
|
|
|
|
test_expect_success "$name: is-inside-work-tree" \
|
|
|
|
"test '$1' = \"\$(git rev-parse --is-inside-work-tree)\""
|
|
|
|
shift
|
|
|
|
[ $# -eq 0 ] && return
|
|
|
|
|
|
|
|
test_expect_success "$name: prefix" \
|
|
|
|
"test '$1' = \"\$(git rev-parse --show-prefix)\""
|
|
|
|
shift
|
|
|
|
[ $# -eq 0 ] && return
|
|
|
|
}
|
|
|
|
|
2008-08-28 21:02:12 +08:00
|
|
|
EMPTY_TREE=$(git write-tree)
|
2007-06-06 15:14:25 +08:00
|
|
|
mkdir -p work/sub/dir || exit 1
|
|
|
|
mv .git repo.git || exit 1
|
|
|
|
|
|
|
|
say "core.worktree = relative path"
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_DIR=repo.git
|
|
|
|
GIT_CONFIG="$(pwd)"/$GIT_DIR/config
|
|
|
|
export GIT_DIR GIT_CONFIG
|
2007-06-06 15:14:25 +08:00
|
|
|
unset GIT_WORK_TREE
|
|
|
|
git config core.worktree ../work
|
|
|
|
test_rev_parse 'outside' false false false
|
|
|
|
cd work || exit 1
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_DIR=../repo.git
|
|
|
|
GIT_CONFIG="$(pwd)"/$GIT_DIR/config
|
2007-06-06 15:14:25 +08:00
|
|
|
test_rev_parse 'inside' false false true ''
|
|
|
|
cd sub/dir || exit 1
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_DIR=../../../repo.git
|
|
|
|
GIT_CONFIG="$(pwd)"/$GIT_DIR/config
|
2007-06-06 15:14:25 +08:00
|
|
|
test_rev_parse 'subdirectory' false false true sub/dir/
|
|
|
|
cd ../../.. || exit 1
|
|
|
|
|
|
|
|
say "core.worktree = absolute path"
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_DIR=$(pwd)/repo.git
|
|
|
|
GIT_CONFIG=$GIT_DIR/config
|
2007-06-06 15:14:25 +08:00
|
|
|
git config core.worktree "$(pwd)/work"
|
|
|
|
test_rev_parse 'outside' false false false
|
|
|
|
cd work || exit 1
|
|
|
|
test_rev_parse 'inside' false false true ''
|
|
|
|
cd sub/dir || exit 1
|
|
|
|
test_rev_parse 'subdirectory' false false true sub/dir/
|
|
|
|
cd ../../.. || exit 1
|
|
|
|
|
|
|
|
say "GIT_WORK_TREE=relative path (override core.worktree)"
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_DIR=$(pwd)/repo.git
|
|
|
|
GIT_CONFIG=$GIT_DIR/config
|
2007-06-06 15:14:25 +08:00
|
|
|
git config core.worktree non-existent
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_WORK_TREE=work
|
|
|
|
export GIT_WORK_TREE
|
2007-06-06 15:14:25 +08:00
|
|
|
test_rev_parse 'outside' false false false
|
|
|
|
cd work || exit 1
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_WORK_TREE=.
|
2007-06-06 15:14:25 +08:00
|
|
|
test_rev_parse 'inside' false false true ''
|
|
|
|
cd sub/dir || exit 1
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_WORK_TREE=../..
|
2007-06-06 15:14:25 +08:00
|
|
|
test_rev_parse 'subdirectory' false false true sub/dir/
|
|
|
|
cd ../../.. || exit 1
|
|
|
|
|
|
|
|
mv work repo.git/work
|
|
|
|
|
|
|
|
say "GIT_WORK_TREE=absolute path, work tree below git dir"
|
2008-05-04 13:37:58 +08:00
|
|
|
GIT_DIR=$(pwd)/repo.git
|
|
|
|
GIT_CONFIG=$GIT_DIR/config
|
|
|
|
GIT_WORK_TREE=$(pwd)/repo.git/work
|
2007-06-06 15:14:25 +08:00
|
|
|
test_rev_parse 'outside' false false false
|
|
|
|
cd repo.git || exit 1
|
|
|
|
test_rev_parse 'in repo.git' false true false
|
|
|
|
cd objects || exit 1
|
|
|
|
test_rev_parse 'in repo.git/objects' false true false
|
|
|
|
cd ../work || exit 1
|
Clean up work-tree handling
The old version of work-tree support was an unholy mess, barely readable,
and not to the point.
For example, why do you have to provide a worktree, when it is not used?
As in "git status". Now it works.
Another riddle was: if you can have work trees inside the git dir, why
are some programs complaining that they need a work tree?
IOW it is allowed to call
$ git --git-dir=../ --work-tree=. bla
when you really want to. In this case, you are both in the git directory
and in the working tree. So, programs have to actually test for the right
thing, namely if they are inside a working tree, and not if they are
inside a git directory.
Also, GIT_DIR=../.git should behave the same as if no GIT_DIR was
specified, unless there is a repository in the current working directory.
It does now.
The logic to determine if a repository is bare, or has a work tree
(tertium non datur), is this:
--work-tree=bla overrides GIT_WORK_TREE, which overrides core.bare = true,
which overrides core.worktree, which overrides GIT_DIR/.. when GIT_DIR
ends in /.git, which overrides the directory in which .git/ was found.
In related news, a long standing bug was fixed: when in .git/bla/x.git/,
which is a bare repository, git formerly assumed ../.. to be the
appropriate git dir. This problem was reported by Shawn Pearce to have
caused much pain, where a colleague mistakenly ran "git init" in "/" a
long time ago, and bare repositories just would not work.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2007-08-01 08:30:14 +08:00
|
|
|
test_rev_parse 'in repo.git/work' false true true ''
|
2007-06-06 15:14:25 +08:00
|
|
|
cd sub/dir || exit 1
|
Clean up work-tree handling
The old version of work-tree support was an unholy mess, barely readable,
and not to the point.
For example, why do you have to provide a worktree, when it is not used?
As in "git status". Now it works.
Another riddle was: if you can have work trees inside the git dir, why
are some programs complaining that they need a work tree?
IOW it is allowed to call
$ git --git-dir=../ --work-tree=. bla
when you really want to. In this case, you are both in the git directory
and in the working tree. So, programs have to actually test for the right
thing, namely if they are inside a working tree, and not if they are
inside a git directory.
Also, GIT_DIR=../.git should behave the same as if no GIT_DIR was
specified, unless there is a repository in the current working directory.
It does now.
The logic to determine if a repository is bare, or has a work tree
(tertium non datur), is this:
--work-tree=bla overrides GIT_WORK_TREE, which overrides core.bare = true,
which overrides core.worktree, which overrides GIT_DIR/.. when GIT_DIR
ends in /.git, which overrides the directory in which .git/ was found.
In related news, a long standing bug was fixed: when in .git/bla/x.git/,
which is a bare repository, git formerly assumed ../.. to be the
appropriate git dir. This problem was reported by Shawn Pearce to have
caused much pain, where a colleague mistakenly ran "git init" in "/" a
long time ago, and bare repositories just would not work.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2007-08-01 08:30:14 +08:00
|
|
|
test_rev_parse 'in repo.git/sub/dir' false true true sub/dir/
|
2007-06-06 15:14:25 +08:00
|
|
|
cd ../../../.. || exit 1
|
|
|
|
|
Clean up work-tree handling
The old version of work-tree support was an unholy mess, barely readable,
and not to the point.
For example, why do you have to provide a worktree, when it is not used?
As in "git status". Now it works.
Another riddle was: if you can have work trees inside the git dir, why
are some programs complaining that they need a work tree?
IOW it is allowed to call
$ git --git-dir=../ --work-tree=. bla
when you really want to. In this case, you are both in the git directory
and in the working tree. So, programs have to actually test for the right
thing, namely if they are inside a working tree, and not if they are
inside a git directory.
Also, GIT_DIR=../.git should behave the same as if no GIT_DIR was
specified, unless there is a repository in the current working directory.
It does now.
The logic to determine if a repository is bare, or has a work tree
(tertium non datur), is this:
--work-tree=bla overrides GIT_WORK_TREE, which overrides core.bare = true,
which overrides core.worktree, which overrides GIT_DIR/.. when GIT_DIR
ends in /.git, which overrides the directory in which .git/ was found.
In related news, a long standing bug was fixed: when in .git/bla/x.git/,
which is a bare repository, git formerly assumed ../.. to be the
appropriate git dir. This problem was reported by Shawn Pearce to have
caused much pain, where a colleague mistakenly ran "git init" in "/" a
long time ago, and bare repositories just would not work.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2007-08-01 08:30:14 +08:00
|
|
|
test_expect_success 'repo finds its work tree' '
|
|
|
|
(cd repo.git &&
|
|
|
|
: > work/sub/dir/untracked &&
|
|
|
|
test sub/dir/untracked = "$(git ls-files --others)")
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'repo finds its work tree from work tree, too' '
|
|
|
|
(cd repo.git/work/sub/dir &&
|
|
|
|
: > tracked &&
|
|
|
|
git --git-dir=../../.. add tracked &&
|
|
|
|
cd ../../.. &&
|
|
|
|
test sub/dir/tracked = "$(git ls-files)")
|
|
|
|
'
|
|
|
|
|
2007-10-17 07:37:36 +08:00
|
|
|
test_expect_success '_gently() groks relative GIT_DIR & GIT_WORK_TREE' '
|
2008-08-28 21:02:12 +08:00
|
|
|
(cd repo.git/work/sub/dir &&
|
2007-10-17 07:37:36 +08:00
|
|
|
GIT_DIR=../../.. GIT_WORK_TREE=../.. GIT_PAGER= \
|
|
|
|
git diff --exit-code tracked &&
|
|
|
|
echo changed > tracked &&
|
|
|
|
! GIT_DIR=../../.. GIT_WORK_TREE=../.. GIT_PAGER= \
|
2008-08-28 21:02:12 +08:00
|
|
|
git diff --exit-code tracked)
|
|
|
|
'
|
|
|
|
cat > diff-index-cached.expected <<\EOF
|
|
|
|
:000000 100644 0000000000000000000000000000000000000000 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 A sub/dir/tracked
|
|
|
|
EOF
|
|
|
|
cat > diff-index.expected <<\EOF
|
|
|
|
:000000 100644 0000000000000000000000000000000000000000 0000000000000000000000000000000000000000 A sub/dir/tracked
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
|
|
test_expect_success 'git diff-index' '
|
|
|
|
GIT_DIR=repo.git GIT_WORK_TREE=repo.git/work git diff-index $EMPTY_TREE > result &&
|
|
|
|
test_cmp diff-index.expected result &&
|
|
|
|
GIT_DIR=repo.git git diff-index --cached $EMPTY_TREE > result &&
|
|
|
|
test_cmp diff-index-cached.expected result
|
|
|
|
'
|
|
|
|
cat >diff-files.expected <<\EOF
|
|
|
|
:100644 100644 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 0000000000000000000000000000000000000000 M sub/dir/tracked
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'git diff-files' '
|
|
|
|
GIT_DIR=repo.git GIT_WORK_TREE=repo.git/work git diff-files > result &&
|
|
|
|
test_cmp diff-files.expected result
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >diff-TREE.expected <<\EOF
|
|
|
|
diff --git a/sub/dir/tracked b/sub/dir/tracked
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000..5ea2ed4
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/sub/dir/tracked
|
|
|
|
@@ -0,0 +1 @@
|
|
|
|
+changed
|
|
|
|
EOF
|
|
|
|
cat >diff-TREE-cached.expected <<\EOF
|
|
|
|
diff --git a/sub/dir/tracked b/sub/dir/tracked
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000..e69de29
|
|
|
|
EOF
|
|
|
|
cat >diff-FILES.expected <<\EOF
|
|
|
|
diff --git a/sub/dir/tracked b/sub/dir/tracked
|
|
|
|
index e69de29..5ea2ed4 100644
|
|
|
|
--- a/sub/dir/tracked
|
|
|
|
+++ b/sub/dir/tracked
|
|
|
|
@@ -0,0 +1 @@
|
|
|
|
+changed
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'git diff' '
|
|
|
|
GIT_DIR=repo.git GIT_WORK_TREE=repo.git/work git diff $EMPTY_TREE > result &&
|
|
|
|
test_cmp diff-TREE.expected result &&
|
|
|
|
GIT_DIR=repo.git git diff --cached $EMPTY_TREE > result &&
|
|
|
|
test_cmp diff-TREE-cached.expected result &&
|
|
|
|
GIT_DIR=repo.git GIT_WORK_TREE=repo.git/work git diff > result &&
|
|
|
|
test_cmp diff-FILES.expected result
|
2007-10-17 07:37:36 +08:00
|
|
|
'
|
|
|
|
|
2008-08-28 21:04:30 +08:00
|
|
|
test_expect_success 'git grep' '
|
|
|
|
(cd repo.git/work/sub &&
|
2008-09-30 16:03:55 +08:00
|
|
|
GIT_DIR=../.. GIT_WORK_TREE=.. git grep -l changed | grep dir/tracked)
|
2008-08-28 21:04:30 +08:00
|
|
|
'
|
|
|
|
|
2007-06-06 15:14:25 +08:00
|
|
|
test_done
|