From fc9401f04a3aca5abb22f87ebc210de8afe11d32 Mon Sep 17 00:00:00 2001 From: marvin-borner@live.com Date: Tue, 10 Apr 2018 21:50:16 +0200 Subject: Initial Commit --- .../stream/examples/91-benchmark-throughput.php | 62 ++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 assets/php/vendor/react/stream/examples/91-benchmark-throughput.php (limited to 'assets/php/vendor/react/stream/examples/91-benchmark-throughput.php') diff --git a/assets/php/vendor/react/stream/examples/91-benchmark-throughput.php b/assets/php/vendor/react/stream/examples/91-benchmark-throughput.php new file mode 100644 index 0000000..ecf695c --- /dev/null +++ b/assets/php/vendor/react/stream/examples/91-benchmark-throughput.php @@ -0,0 +1,62 @@ +write('NOTICE: The "xdebug" extension is loaded, this has a major impact on performance.' . PHP_EOL); +} +$info->write('piping from ' . $if . ' to ' . $of . ' (for max ' . $t . ' second(s)) ...'. PHP_EOL); + +// setup input and output streams and pipe inbetween +$fh = fopen($if, 'r'); +$in = new React\Stream\ReadableResourceStream($fh, $loop); +$out = new React\Stream\WritableResourceStream(fopen($of, 'w'), $loop); +$in->pipe($out); + +// stop input stream in $t seconds +$start = microtime(true); +$timeout = $loop->addTimer($t, function () use ($in, &$bytes) { + $in->close(); +}); + +// print stream position once stream closes +$in->on('close', function () use ($fh, $start, $loop, $timeout, $info) { + $t = microtime(true) - $start; + $loop->cancelTimer($timeout); + + $bytes = ftell($fh); + + $info->write('read ' . $bytes . ' byte(s) in ' . round($t, 3) . ' second(s) => ' . round($bytes / 1024 / 1024 / $t, 1) . ' MiB/s' . PHP_EOL); + $info->write('peak memory usage of ' . round(memory_get_peak_usage(true) / 1024 / 1024, 1) . ' MiB' . PHP_EOL); +}); + +$loop->run(); -- cgit v1.2.3