diff options
author | Jeff King <peff@peff.net> | 2016-09-05 17:52:17 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-09-07 11:45:28 -0700 |
commit | 948a7fd242a28e61e454f62001716af2c9d614b0 (patch) | |
tree | 498ad3d7792789755e4733692948722489b0587a /t | |
parent | 2076353f473aa3cbcbd2623f1765432fa275acec (diff) | |
download | git-948a7fd242a28e61e454f62001716af2c9d614b0.tar.gz git-948a7fd242a28e61e454f62001716af2c9d614b0.tar.xz |
t5305: use "git -C"
This test unpacks objects into a separate repository, and
accesses it by setting GIT_DIR in a subshell. We can do the
same thing these days by using "git init <repo>" and "git
-C". In most cases this is shorter, though when there are
multiple commands, we may end up repeating the "-C".
However, this repetition can actually be a good thing. This
patch also fixes a bug introduced by 512477b (tests: use
"env" to run commands with temporary env-var settings,
2014-03-18). That commit essentially converted:
(GIT_DIR=...; export GIT_DIR
cmd1 &&
cmd2)
into:
(GIT_DIR=... cmd1 &&
cmd2)
which obviously loses the GIT_DIR setting for cmd2 (we never
noticed the bug because it simply runs "cmd2" in the parent
repo, which means we were simply failing to test anything
interesting). By using "git -C" rather than a subshell, it
becomes quite obvious where each command is supposed to be
running.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't')
-rwxr-xr-x | t/t5305-include-tag.sh | 28 |
1 files changed, 7 insertions, 21 deletions
diff --git a/t/t5305-include-tag.sh b/t/t5305-include-tag.sh index 787fc831e..089a3e9e8 100755 --- a/t/t5305-include-tag.sh +++ b/t/t5305-include-tag.sh @@ -33,20 +33,14 @@ test_expect_success 'pack without --include-tag' ' test_expect_success 'unpack objects' ' rm -rf clone.git && - ( - GIT_DIR=clone.git && - export GIT_DIR && - git init && - git unpack-objects <test-1-${packname_1}.pack - ) + git init clone.git && + git -C clone.git unpack-objects <test-1-${packname_1}.pack ' test_expect_success 'check unpacked result (have commit, no tag)' ' git rev-list --objects $commit >list.expect && - ( - test_must_fail env GIT_DIR=clone.git git cat-file -e $tag && - git rev-list --objects $commit - ) >list.actual && + test_must_fail git -C clone.git cat-file -e $tag && + git -C clone.git rev-list --objects $commit >list.actual && test_cmp list.expect list.actual ' @@ -59,21 +53,13 @@ test_expect_success 'pack with --include-tag' ' test_expect_success 'unpack objects' ' rm -rf clone.git && - ( - GIT_DIR=clone.git && - export GIT_DIR && - git init && - git unpack-objects <test-2-${packname_1}.pack - ) + git init clone.git && + git -C clone.git unpack-objects <test-2-${packname_1}.pack ' test_expect_success 'check unpacked result (have commit, have tag)' ' git rev-list --objects mytag >list.expect && - ( - GIT_DIR=clone.git && - export GIT_DIR && - git rev-list --objects $tag - ) >list.actual && + git -C clone.git rev-list --objects $tag >list.actual && test_cmp list.expect list.actual ' |