t7502: perform commits using alternate editor in a subshell

These tests call test_set_editor to set an alternate editor script, but
they appear to presume that the assignment is of a temporary nature and
will not have any effect outside of each individual test.  That is not
the case.  All of the test functions within a test script share a single
environment, so any variables modified in one, are visible in the ones
that follow.

So, let's protect the test functions that follow these, which set an
alternate editor, by performing the test_set_editor and 'git commit'
in a subshell.

Signed-off-by: Brandon Casey <drafnel@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Brandon Casey 2013-02-22 15:13:00 -08:00 committed by Junio C Hamano
parent 51fb3a3dfa
commit 24e099f475

View File

@ -255,32 +255,40 @@ test_expect_success 'cleanup commit message (fail on invalid cleanup mode config
test_expect_success 'cleanup commit message (no config and no option uses default)' ' test_expect_success 'cleanup commit message (no config and no option uses default)' '
echo content >>file && echo content >>file &&
git add file && git add file &&
test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && (
git commit --no-status && test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment &&
git commit --no-status
) &&
commit_msg_is "commit message" commit_msg_is "commit message"
' '
test_expect_success 'cleanup commit message (option overrides default)' ' test_expect_success 'cleanup commit message (option overrides default)' '
echo content >>file && echo content >>file &&
git add file && git add file &&
test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && (
git commit --cleanup=whitespace --no-status && test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment &&
git commit --cleanup=whitespace --no-status
) &&
commit_msg_is "commit message # comment" commit_msg_is "commit message # comment"
' '
test_expect_success 'cleanup commit message (config overrides default)' ' test_expect_success 'cleanup commit message (config overrides default)' '
echo content >>file && echo content >>file &&
git add file && git add file &&
test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && (
git -c commit.cleanup=whitespace commit --no-status && test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment &&
git -c commit.cleanup=whitespace commit --no-status
) &&
commit_msg_is "commit message # comment" commit_msg_is "commit message # comment"
' '
test_expect_success 'cleanup commit message (option overrides config)' ' test_expect_success 'cleanup commit message (option overrides config)' '
echo content >>file && echo content >>file &&
git add file && git add file &&
test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment && (
git -c commit.cleanup=whitespace commit --cleanup=default && test_set_editor "$TEST_DIRECTORY"/t7500/add-content-and-comment &&
git -c commit.cleanup=whitespace commit --cleanup=default
) &&
commit_msg_is "commit message" commit_msg_is "commit message"
' '