diff options
author | Brandon Casey <drafnel@gmail.com> | 2011-06-30 02:34:57 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-06-30 03:24:40 +0200 |
commit | 91cd7e4b426b0dc4755212fcbac3c822499ddd15 (patch) | |
tree | 070cfe76038a274cbe3b40633c80bf49c879a8aa /t/t7407-submodule-foreach.sh | |
parent | submodule: only preserve flags across recursive status/update invocations (diff) | |
download | git-91cd7e4b426b0dc4755212fcbac3c822499ddd15.tar.xz git-91cd7e4b426b0dc4755212fcbac3c822499ddd15.zip |
t/t7407: demonstrate that the command called by 'submodule foreach' loses stdin
The user-supplied command spawned by 'submodule foreach' loses its
connection to the original standard input. Instead, it is connected to the
output of a pipe within the git-submodule script. This can cause a problem
if the command requires reading from stdin or if it changes its behavior
based on whether stdin is a tty or not (e.g. git shortlog). Demonstrate
this flaw.
Signed-off-by: Brandon Casey <drafnel@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t7407-submodule-foreach.sh')
-rwxr-xr-x | t/t7407-submodule-foreach.sh | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/t/t7407-submodule-foreach.sh b/t/t7407-submodule-foreach.sh index d8ad25036f..97b7562dbf 100755 --- a/t/t7407-submodule-foreach.sh +++ b/t/t7407-submodule-foreach.sh @@ -288,4 +288,22 @@ test_expect_success 'use "update --recursive nested1" to checkout all submodules ) ' +test_expect_failure 'command passed to foreach retains notion of stdin' ' + ( + cd super && + git submodule foreach echo success >../expected && + yes | git submodule foreach "read y && test \"x\$y\" = xy && echo success" >../actual + ) && + test_cmp expected actual +' + +test_expect_failure 'command passed to foreach --recursive retains notion of stdin' ' + ( + cd clone2 && + git submodule foreach --recursive echo success >../expected && + yes | git submodule foreach --recursive "read y && test \"x\$y\" = xy && echo success" >../actual + ) && + test_cmp expected actual +' + test_done |