X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=tests%2Fhelper%2Fserver.inc;h=091ff5cd483834d5c88d7e6304b42270bad9fe91;hp=1bf5eb8f1978e9005c8ed57e62be48f95ece144e;hb=1f37d09e4c7f55cf6f2c3c10ea3ec2424a482671;hpb=b3eb2fdc25d712af43142e2f444e8d69d9827536 diff --git a/tests/helper/server.inc b/tests/helper/server.inc index 1bf5eb8..091ff5c 100644 --- a/tests/helper/server.inc +++ b/tests/helper/server.inc @@ -3,6 +3,17 @@ ini_set("log_errors", true); ini_set("error_log", __DIR__."/server.log"); +function logger() { + if (!ini_get("date.timezone")) { + date_default_timezone_set(@date_default_timezone_get()); + } + error_log(sprintf("%s(%s): %s", + basename(getenv("SCRIPT_FILENAME"), ".php"), + basename(current(get_included_files()), ".inc"), + call_user_func_array("sprintf", func_get_args()) + )); +} + $php = getenv('TEST_PHP_EXECUTABLE'); if ($php) { define('PHP_BIN', $php); @@ -13,26 +24,44 @@ if ($php) { define("PHP_BIN", PHP_BINDIR.DIRECTORY_SEPARATOR."php"); } +foreach (array("raphf", "propro", "http") as $ext) { + if (!extension_loaded($ext)) { + switch (PHP_SHLIB_SUFFIX) { + case "dll": + dl("php_$ext.dll"); + break; + default: + dl($ext .".". PHP_SHLIB_SUFFIX); + } + } +} + function serve($cb) { /* stream_socket_server() automatically sets SO_REUSEADDR, * which is, well, bad if the tests are run in parallel */ $offset = rand(0,2000); foreach (range(8000+$offset, 9000+$offset) as $port) { + logger("serve: Trying port %d", $port); if (($server = @stream_socket_server("tcp://localhost:$port"))) { fprintf(STDERR, "%s\n", $port); + logger("serve: Using port %d", $port); do { $R = array($server); $W = array(); $E = array(); - $select = stream_select($R, $E, $E, 0, 10000); + $select = stream_select($R, $E, $E, 10, 0); if ($select && ($client = stream_socket_accept($server, 1))) { + logger("serve: Accept client %d", (int) $client); if (getenv("PHP_HTTP_TEST_SSL")) { stream_socket_enable_crypto($client, true, STREAM_CRYPTO_METHOD_SSLv23_SERVER); } try { while (!feof($client)) { + logger("serve: Handle client %d", (int) $client); $cb($client); } + logger("serve: EOF on client %d", (int) $client); } catch (Exception $ex) { + logger("serve: Exception on client %d: %s", (int) $client, $ex->getMessage()); /* ignore disconnect */ if ($ex->getMessage() !== "Empty message received from stream") { fprintf(STDERR, "%s\n", $ex); @@ -40,7 +69,7 @@ function serve($cb) { break; } } - } while ($select !== false); + } while ($select); return; } } @@ -114,4 +143,4 @@ function proc($bin, $args, $cb) { fpassthru($stderr); fpassthru($stdout); } -} \ No newline at end of file +}