X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=tests%2Fhelper%2Fserver.inc;h=ea83f70679b073f1dc75dbbf30261c14f6567ef7;hp=506e08313b2c70f71a97f494bb5097171bc7a1f0;hb=2ac8caf0e31b5dfd386c0a0b811cd918620c0a17;hpb=e438aa9ce944f8c8f175554d9aa66d152a47f780 diff --git a/tests/helper/server.inc b/tests/helper/server.inc index 506e083..ea83f70 100644 --- a/tests/helper/server.inc +++ b/tests/helper/server.inc @@ -1,5 +1,19 @@ getMessage()); /* ignore disconnect */ if ($ex->getMessage() !== "Empty message received from stream") { fprintf(STDERR, "%s\n", $ex); @@ -37,18 +105,38 @@ function serve($cb) { break; } } - } while ($select !== false); + } while ($select); return; } } } function server($handler, $cb) { - $args = explode(' ', getenv('TEST_PHP_ARGS')); - $args[] = __DIR__."/$handler"; - foreach ($args as $k => $v) { - if (!$v) unset($args[$k]); + $args = []; + $argList = preg_split('#\s+#', getenv('TEST_PHP_ARGS'), -1, PREG_SPLIT_NO_EMPTY); + for ($i = 0; isset($argList[$i]); $i++) { + if ($argList[$i] === '-c') { + array_push($args, '-c', $argList[++$i]); + continue; + } + if ($argList[$i] === '-n') { + $args[] = '-n'; + continue; + } + if ($argList[$i] === '-d') { + $args[] = '-d' . $args[++$i]; + continue; + } + if (substr($argList[$i], 0, 2) === '-d') { + $args[] = $argList[$i]; + } } + foreach (['raphf', 'propro', 'http'] as $ext) { + if (null !== $arg = get_extension_load_arg(PHP_BIN, $args, $ext)) { + $args[] = $arg; + } + } + $args[] = __DIR__ . '/' . $handler; proc(PHP_BIN, $args, $cb); } @@ -62,9 +150,9 @@ function nghttpd($cb) { $stdout = $pipes[1]; $stderr = $pipes[2]; - usleep(50000); + sleep(1); $status = proc_get_status($proc); - + logger("nghttpd: %s", new http\Params($status)); if (!$status["running"]) { continue; } @@ -88,6 +176,7 @@ function nghttpd($cb) { function proc($bin, $args, $cb) { $spec = array(array("pipe","r"), array("pipe","w"), array("pipe","w")); $comm = escapeshellcmd($bin) . " ". implode(" ", array_map("escapeshellarg", $args)); + logger("proc: %s %s", $bin, implode(" ", $args)); if (($proc = proc_open($comm, $spec, $pipes, __DIR__))) { $stdin = $pipes[0]; $stdout = $pipes[1]; @@ -111,4 +200,4 @@ function proc($bin, $args, $cb) { fpassthru($stderr); fpassthru($stdout); } -} \ No newline at end of file +}