X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=tests%2Fhelper%2Fserver.inc;fp=tests%2Fhelper%2Fserver.inc;h=6cf6acf996c49698c0a9d35ed83fb553b6fb71f4;hp=1bf5eb8f1978e9005c8ed57e62be48f95ece144e;hb=2b63830bc0d382339ce5f56e2ccfc18903eee8db;hpb=85f8ab89e48ddd69f827ff4c012509caa2079c51 diff --git a/tests/helper/server.inc b/tests/helper/server.inc index 1bf5eb8..6cf6acf 100644 --- a/tests/helper/server.inc +++ b/tests/helper/server.inc @@ -3,6 +3,11 @@ ini_set("log_errors", true); ini_set("error_log", __DIR__."/server.log"); +function log() { + error_log(sprintf("%s: %s\n", date("[Y-m-d H:i:s]"), + call_user_func_array("sprintf", func_get_args()))); +} + $php = getenv('TEST_PHP_EXECUTABLE'); if ($php) { define('PHP_BIN', $php); @@ -19,20 +24,26 @@ function serve($cb) { */ $offset = rand(0,2000); foreach (range(8000+$offset, 9000+$offset) as $port) { + log("serve: Trying port %d", $port); if (($server = @stream_socket_server("tcp://localhost:$port"))) { fprintf(STDERR, "%s\n", $port); + log("serve: Using port %d", $port); do { $R = array($server); $W = array(); $E = array(); $select = stream_select($R, $E, $E, 0, 10000); if ($select && ($client = stream_socket_accept($server, 1))) { + log("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)) { + log("serve: Handle client %d", (int) $client); $cb($client); } + log("serve: EOF on client %d", (int) $client); } catch (Exception $ex) { + log("serve: Exception on client %d", (int) $client); /* ignore disconnect */ if ($ex->getMessage() !== "Empty message received from stream") { fprintf(STDERR, "%s\n", $ex);