X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=tests%2Fhelper%2Fserver.inc;h=78a63eee3098f71de890ad2dce7e88956b4ecda5;hp=aa8559f8c41fbb3480f1e6dbcf6a02de0a3659b6;hb=53a654ed6e112b2766b41c01a1c2bb79373c59e4;hpb=5016399a1e84ca8d23fa74934300e703155e586b diff --git a/tests/helper/server.inc b/tests/helper/server.inc index aa8559f..78a63ee 100644 --- a/tests/helper/server.inc +++ b/tests/helper/server.inc @@ -1,26 +1,68 @@ -getMessage()); /* ignore disconnect */ if ($ex->getMessage() !== "Empty message received from stream") { fprintf(STDERR, "%s\n", $ex); @@ -28,19 +70,25 @@ function serve($cb) { break; } } - } while ($select !== false); + } while ($select); return; } } } function server($handler, $cb) { - proc(PHP_BINARY, array(__DIR__."/$handler"), $cb); + $args = explode(' ', getenv('TEST_PHP_ARGS')); + $args[] = __DIR__."/$handler"; + foreach ($args as $k => $v) { + if (!$v) unset($args[$k]); + } + proc(PHP_BIN, $args, $cb); } function nghttpd($cb) { $spec = array(array("pipe","r"), array("pipe","w"), array("pipe","w")); - foreach (range(8000, 9000) as $port) { + $offset = rand(0,2000); + foreach (range(8000+$offset, 9000+$offset) as $port) { $comm = "exec nghttpd -d html $port http2.key http2.crt"; if (($proc = proc_open($comm, $spec, $pipes, __DIR__))) { $stdin = $pipes[0]; @@ -77,7 +125,7 @@ function proc($bin, $args, $cb) { $stdin = $pipes[0]; $stdout = $pipes[1]; $stderr = $pipes[2]; - + do { $port = trim(fgets($stderr)); $R = array($stderr); $W = array(); $E = array(); @@ -96,4 +144,4 @@ function proc($bin, $args, $cb) { fpassthru($stderr); fpassthru($stdout); } -} \ No newline at end of file +}