summaryrefslogtreecommitdiff
path: root/ext/standard/tests/general_functions/proc_open_sockets3.phpt
diff options
context:
space:
mode:
Diffstat (limited to 'ext/standard/tests/general_functions/proc_open_sockets3.phpt')
-rw-r--r--ext/standard/tests/general_functions/proc_open_sockets3.phpt55
1 files changed, 55 insertions, 0 deletions
diff --git a/ext/standard/tests/general_functions/proc_open_sockets3.phpt b/ext/standard/tests/general_functions/proc_open_sockets3.phpt
new file mode 100644
index 0000000000..5ee9e53b56
--- /dev/null
+++ b/ext/standard/tests/general_functions/proc_open_sockets3.phpt
@@ -0,0 +1,55 @@
+--TEST--
+proc_open() with socket and pipe
+--FILE--
+<?php
+
+function poll($pipe, $read = true)
+{
+ $r = ($read == true) ? [$pipe] : null;
+ $w = ($read == false) ? [$pipe] : null;
+ $e = null;
+
+ if (!stream_select($r, $w, $e, null, 0)) {
+ throw new \Error("Select failed");
+ }
+}
+
+function read_pipe($pipe): string
+{
+ poll($pipe);
+
+ if (false === ($chunk = @fread($pipe, 8192))) {
+ throw new Error("Failed to read: " . (error_get_last()['message'] ?? 'N/A'));
+ }
+
+ return $chunk;
+}
+
+$cmd = [
+ getenv("TEST_PHP_EXECUTABLE"),
+ __DIR__ . '/proc_open_sockets2.inc'
+];
+
+$spec = [
+ ['pipe', 'r'],
+ ['socket']
+];
+
+$proc = proc_open($cmd, $spec, $pipes);
+
+var_dump(stream_set_blocking($pipes[1], false));
+
+printf("STDOUT << %s\n", read_pipe($pipes[1]));
+printf("STDOUT << %s\n", read_pipe($pipes[1]));
+
+fwrite($pipes[0], 'done');
+fclose($pipes[0]);
+
+printf("STDOUT << %s\n", read_pipe($pipes[1]));
+
+?>
+--EXPECTF--
+bool(true)
+STDOUT << hello
+STDOUT << world
+STDOUT << DONE