X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=tests%2Fhelper%2Fserver.inc;h=f203ed6c50f1696253e1a06d6e3439e0db95cc7c;hp=70fb7cfcac77f89d84765bc96fc1d594f87b7c55;hb=HEAD;hpb=aba1f7d332d866ca1f0397d46751864e430985f3 diff --git a/tests/helper/server.inc b/tests/helper/server.inc index 70fb7cf..b5bc3b7 100644 --- a/tests/helper/server.inc +++ b/tests/helper/server.inc @@ -1,40 +1,202 @@ -getMessage()); + /* ignore disconnect */ + if ($ex->getMessage() !== "Empty message received from stream") { + fprintf(STDERR, "%s\n", $ex); + } + break; } } - } while ($select !== false); + } while ($select); return; } } } -function server($handler, callable $cb) { +function server($handler, $cb) { + $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' . $argList[++$i]; + continue; + } + if (substr($argList[$i], 0, 2) === '-d') { + $args[] = $argList[$i]; + } + } + foreach (['raphf', 'http'] as $ext) { + if (null !== $arg = get_extension_load_arg(PHP_BIN, $args, $ext)) { + $args[] = $arg; + } + } + $args[] = __DIR__ . '/' . $handler; + proc(PHP_BIN, $args, $cb); +} + +function nghttpd($cb) { $spec = array(array("pipe","r"), array("pipe","w"), array("pipe","w")); - $comm = sprintf("%s %s/%s", PHP_BINARY, __DIR__, $handler); + $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]; + $stdout = $pipes[1]; + $stderr = $pipes[2]; + + sleep(1); + $status = proc_get_status($proc); + logger("nghttpd: %s", new http\Params($status)); + if (!$status["running"]) { + continue; + } + + try { + $cb($port, $stdin, $stdout, $stderr); + } catch (Exception $e) { + echo $e,"\n"; + } + + proc_terminate($proc); + + fpassthru($stderr); + fpassthru($stdout); + return; + } + } + +} + +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__))) { - $port = trim(fgets($pipes[2])); - - try { - $cb($port, $stdin = $pipes[0], $stdout = $pipes[1], $stderr = $pipes[2]); - } catch (Exception $e) { - echo $e,"\n"; - } - + $stdin = $pipes[0]; + $stdout = $pipes[1]; + $stderr = $pipes[2]; + + do { + $port = trim(fgets($stderr)); + $R = array($stderr); $W = array(); $E = array(); + } while (is_numeric($port) && stream_select($R, $W, $E, 0, 10000)); + + if (is_numeric($port)) { + try { + $cb($port, $stdin, $stdout, $stderr); + } catch (Exception $e) { + echo $e,"\n"; + } + } + proc_terminate($proc); - + fpassthru($stderr); fpassthru($stdout); }