ID:               51160
 Comment by:       binarycleric at gmail dot com
 Reported By:      poehler at interworx dot com
 Status:           Open
 Bug Type:         *General Issues
 Operating System: CentOS 5.4
 PHP Version:      5.2.13
 New Comment:

Just wanted to confirm that this also occurs on Mac OS 10.6 using
version PHP 5.3.0.


Previous Comments:
------------------------------------------------------------------------

[2010-02-26 21:15:40] poehler at interworx dot com

Description:
------------
See reproduce code and expected / actual result sections for details.

Short story is when exec'ing with a pipe to 'head', we're getting
unexpected results.

I'm aware this may be 'correct' behavior, by some definition, but for
the life of me I can't figure out where this behavior is documented, if
that is the case.  So if that is the case, please point me in the right
direction, if you could be so kind.



Reproduce code:
---------------
test.sh:
=================
#!/bin/sh

for i in 1 2 3 4 5
do
   echo "Welcome $i times"
   sleep 1
done
==================


test.php:
==================
<?
passthru( '/bin/sh test.sh | head -n1' );

==================




Expected result:
----------------
Here is the output of running the same command at the shell, which is
correct.
==================
[r...@me]# time /bin/sh test.sh | head -n1
Welcome 1 times

real    0m1.030s
user    0m0.002s
sys     0m0.027s
==================
And I would expect identical (save minor timing differences) when
test.php is run.

Actual result:
--------------
[r...@me]# php test.php
Welcome 1 times
test.sh: line 5: echo: write error: Broken pipe
test.sh: line 5: echo: write error: Broken pipe
test.sh: line 5: echo: write error: Broken pipe
test.sh: line 5: echo: write error: Broken pipe

real    0m5.191s
user    0m0.002s
sys     0m0.038s

Note that this took 5 seconds instead of 1.


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=51160&edit=1

Reply via email to