laruence                                 Thu, 17 Nov 2011 02:22:06 +0000

Revision: http://svn.php.net/viewvc?view=revision&revision=319382

Log:
improve the test,  let it say about errors

Changed paths:
    U   php/php-src/branches/PHP_5_4/sapi/cli/tests/php_cli_server.inc
    U   php/php-src/trunk/sapi/cli/tests/php_cli_server.inc

Modified: php/php-src/branches/PHP_5_4/sapi/cli/tests/php_cli_server.inc
===================================================================
--- php/php-src/branches/PHP_5_4/sapi/cli/tests/php_cli_server.inc      
2011-11-17 00:17:22 UTC (rev 319381)
+++ php/php-src/branches/PHP_5_4/sapi/cli/tests/php_cli_server.inc      
2011-11-17 02:22:06 UTC (rev 319382)
@@ -12,7 +12,7 @@
        $descriptorspec = array(
                0 => STDIN,
                1 => STDOUT,
-               2 => STDERR,
+               2 => array("pipe", "w"),
        );

        if (substr(PHP_OS, 0, 3) == 'WIN') {
@@ -21,25 +21,35 @@
                        $cmd .= " {$router}";
                }

-               $handle = proc_open(addslashes($cmd), $descriptorspec, $pipes, 
$doc_root, NULL, array("bypass_shell" => true,  "suppress_errors" => true));
+               $handle = proc_open(addslashes($cmd), $descriptorspec, $pipes, 
$doc_root, NULL, array("bypass_shell" => true));
        } else {
                $cmd = "exec {$php_executable} -t {$doc_root} -S " . 
PHP_CLI_SERVER_ADDRESS;
                if (!$no_router) {
                        $cmd .= " {$router}";
                }
-               $cmd .= " 2>/dev/null";

                $handle = proc_open($cmd, $descriptorspec, $pipes, $doc_root);
        }

+       //@FIXME is there a better way to make sure the process is ready?
+       usleep(50000);
+
+       stream_set_blocking($pipes[2], 0);
+       if ($err = stream_get_contents($pipes[2])) {
+               fclose($pipes[2]);
+               proc_terminate($handle);
+               @unlink(__DIR__ . "/{$router}");
+               die("Cli sever could not be started: " . $err);
+       }
+
        register_shutdown_function(
-               function($handle) use($router) {
+               function($handle, $router, $pipes) {
+                       stream_get_contents($pipes[2]);
+                       fclose($pipes[2]);
                        proc_terminate($handle);
                        @unlink(__DIR__ . "/{$router}");
                },
-                       $handle
+                       $handle, $router, $pipes
                );
-       usleep(50000);
 }
 ?>
-

Modified: php/php-src/trunk/sapi/cli/tests/php_cli_server.inc
===================================================================
--- php/php-src/trunk/sapi/cli/tests/php_cli_server.inc 2011-11-17 00:17:22 UTC 
(rev 319381)
+++ php/php-src/trunk/sapi/cli/tests/php_cli_server.inc 2011-11-17 02:22:06 UTC 
(rev 319382)
@@ -12,7 +12,7 @@
        $descriptorspec = array(
                0 => STDIN,
                1 => STDOUT,
-               2 => STDERR,
+               2 => array("pipe", "w"),
        );

        if (substr(PHP_OS, 0, 3) == 'WIN') {
@@ -21,25 +21,35 @@
                        $cmd .= " {$router}";
                }

-               $handle = proc_open(addslashes($cmd), $descriptorspec, $pipes, 
$doc_root, NULL, array("bypass_shell" => true,  "suppress_errors" => true));
+               $handle = proc_open(addslashes($cmd), $descriptorspec, $pipes, 
$doc_root, NULL, array("bypass_shell" => true));
        } else {
                $cmd = "exec {$php_executable} -t {$doc_root} -S " . 
PHP_CLI_SERVER_ADDRESS;
                if (!$no_router) {
                        $cmd .= " {$router}";
                }
-               $cmd .= " 2>/dev/null";

                $handle = proc_open($cmd, $descriptorspec, $pipes, $doc_root);
        }

+       //@FIXME is there a better way to make sure the process is ready?
+       usleep(50000);
+
+       stream_set_blocking($pipes[2], 0);
+       if ($err = stream_get_contents($pipes[2])) {
+               fclose($pipes[2]);
+               proc_terminate($handle);
+               @unlink(__DIR__ . "/{$router}");
+               die("Cli sever could not be started: " . $err);
+       }
+
        register_shutdown_function(
-               function($handle) use($router) {
+               function($handle, $router, $pipes) {
+                       stream_get_contents($pipes[2]);
+                       fclose($pipes[2]);
                        proc_terminate($handle);
                        @unlink(__DIR__ . "/{$router}");
                },
-                       $handle
+                       $handle, $router, $pipes
                );
-       usleep(50000);
 }
 ?>
-

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to