From 65748cb67e9cc0f9eb446543f2a86ed8b1bb541b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20L=C3=BCck?= Date: Sat, 3 Sep 2022 12:06:05 +0200 Subject: [PATCH 1/2] Forward compatibility with upcoming Promise v3 --- composer.json | 4 ++-- src/ErrorHandler.php | 5 ++++- tests/AppTest.php | 4 ++++ tests/ErrorHandlerTest.php | 4 ++++ 4 files changed, 14 insertions(+), 3 deletions(-) diff --git a/composer.json b/composer.json index 77f6f4b..d59be41 100644 --- a/composer.json +++ b/composer.json @@ -14,8 +14,8 @@ "php": ">=7.1", "nikic/fast-route": "^1.3", "react/async": "^4 || ^3", - "react/http": "^1.7", - "react/promise": "^2.7" + "react/http": "^1.8@dev || ^1.7", + "react/promise": "^3@dev || ^2.7" }, "require-dev": { "phpunit/phpunit": "^9.5 || ^7.5", diff --git a/src/ErrorHandler.php b/src/ErrorHandler.php index 39d691a..b70f53c 100644 --- a/src/ErrorHandler.php +++ b/src/ErrorHandler.php @@ -48,10 +48,13 @@ public function __invoke(ServerRequestInterface $request, callable $next) return $this->errorInvalidResponse($response); } }, function ($e) { + // Promise rejected, always a `\Throwable` as of Promise v3 + assert($e instanceof \Throwable || !\method_exists(PromiseInterface::class, 'catch')); + if ($e instanceof \Throwable) { return $this->errorInvalidException($e); } else { - return $this->errorInvalidResponse(\React\Promise\reject($e)); + return $this->errorInvalidResponse(\React\Promise\reject($e)); // @codeCoverageIgnore } }); } elseif ($response instanceof \Generator) { diff --git a/tests/AppTest.php b/tests/AppTest.php index 481e52f..468f041 100644 --- a/tests/AppTest.php +++ b/tests/AppTest.php @@ -1534,6 +1534,10 @@ public function testHandleRequestWithMatchingRouteReturnsPromiseWhichFulfillsWit public function testHandleRequestWithMatchingRouteReturnsPromiseWhichFulfillsWithInternalServerErrorResponseWhenHandlerReturnsPromiseWhichRejectsWithNull() { + if (method_exists(PromiseInterface::class, 'catch')) { + $this->markTestSkipped('Only supported for legacy Promise v2, Promise v3 always rejects with Throwable'); + } + $app = $this->createAppWithoutLogger(); $app->get('/users', function () { diff --git a/tests/ErrorHandlerTest.php b/tests/ErrorHandlerTest.php index 7acc3f0..a90c366 100644 --- a/tests/ErrorHandlerTest.php +++ b/tests/ErrorHandlerTest.php @@ -273,6 +273,10 @@ public function testInvokeWithHandlerReturningPromiseResolvingWithNullReturnsPro public function testInvokeWithHandlerReturningPromiseRejectingWithNullReturnsPromiseResolvingWithError500Response() { + if (method_exists(PromiseInterface::class, 'catch')) { + $this->markTestSkipped('Only supported for legacy Promise v2, Promise v3 always rejects with Throwable'); + } + $handler = new ErrorHandler(); $request = new ServerRequest('GET', 'http://example.com/'); From 77c09a213130e000c62698fad608d96dd861674b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christian=20L=C3=BCck?= Date: Thu, 29 Sep 2022 15:18:57 +0200 Subject: [PATCH 2/2] Update to stable reactphp/http v1.8.0 --- composer.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/composer.json b/composer.json index d59be41..b914d81 100644 --- a/composer.json +++ b/composer.json @@ -14,8 +14,8 @@ "php": ">=7.1", "nikic/fast-route": "^1.3", "react/async": "^4 || ^3", - "react/http": "^1.8@dev || ^1.7", - "react/promise": "^3@dev || ^2.7" + "react/http": "^1.8", + "react/promise": "^3 || ^2.7" }, "require-dev": { "phpunit/phpunit": "^9.5 || ^7.5",