Skip to content

Commit

Permalink
Back port descriptor fix
Browse files Browse the repository at this point in the history
  • Loading branch information
donatj committed Oct 30, 2023
1 parent f632832 commit 0d8f449
Showing 1 changed file with 18 additions and 8 deletions.
26 changes: 18 additions & 8 deletions src/MockWebServer.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,13 @@ class MockWebServer {
*/
private $process;

/**
* Contains the descriptors for the process after it has been started
*
* @var resource[]
*/
private $descriptors = [];

/**
* TestWebServer constructor.
*
Expand Down Expand Up @@ -67,7 +74,7 @@ public function start() : void {

InternalServer::incrementRequestCounter($this->tmpDir, 0);

$this->process = $this->startServer($fullCmd);
[ $this->process, $this->descriptors ] = $this->startServer($fullCmd);

for( $i = 0; $i <= 20; $i++ ) {
usleep(100000);
Expand Down Expand Up @@ -123,6 +130,10 @@ public function stop() : void {
usleep(10000);
}
}

foreach( $this->descriptors as $descriptor ) {
@fclose($descriptor);
}
}

/**
Expand Down Expand Up @@ -275,9 +286,9 @@ private function isWindowsPlatform() : bool {
}

/**
* @return resource
* @return array{resource, resource[]}
*/
private function startServer( string $fullCmd ) {
private function startServer( string $fullCmd ) : array {
if( !$this->isWindowsPlatform() ) {
// We need to prefix exec to get the correct process http://php.net/manual/ru/function.proc-get-status.php#93382
$fullCmd = 'exec ' . $fullCmd;
Expand All @@ -287,14 +298,13 @@ private function startServer( string $fullCmd ) {
$env = null;
$cwd = null;

$stdin = fopen('php://stdin', 'rb');
$stdoutf = tempnam(sys_get_temp_dir(), 'MockWebServer.stdout');
$stderrf = tempnam(sys_get_temp_dir(), 'MockWebServer.stderr');

$descriptorSpec = [
0 => $stdin,
1 => [ 'file', $stdoutf, 'a' ],
2 => [ 'file', $stderrf, 'a' ],
0 => fopen('php://stdin', 'rb'),
1 => fopen($stdoutf, 'a'),
2 => fopen($stderrf, 'a'),
];

$process = proc_open($fullCmd, $descriptorSpec, $pipes, $cwd, $env, [
Expand All @@ -303,7 +313,7 @@ private function startServer( string $fullCmd ) {
]);

if( is_resource($process) ) {
return $process;
return [ $process, $descriptorSpec ];
}

throw new Exceptions\ServerException('Error starting server');
Expand Down

0 comments on commit 0d8f449

Please sign in to comment.