Skip to content

Commit

Permalink
adjust to promise template annotations
Browse files Browse the repository at this point in the history
  • Loading branch information
dbu committed Jan 3, 2024
1 parent 625ad74 commit c56232d
Show file tree
Hide file tree
Showing 6 changed files with 13 additions and 23 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/static.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@ jobs:
- name: Checkout code
uses: actions/checkout@v3

- name: Remove phpspec
run: composer remove --dev friends-of-phpspec/phpspec-code-coverage phpspec/phpspec

- name: PHPStan
uses: docker://oskarstark/phpstan-ga
with:
Expand Down
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
],
"require": {
"php": "^7.1 || ^8.0",
"php-http/promise": "^1.1",
"php-http/promise": "dev-template-exception as 1.2.2",
"psr/http-client": "^1.0",
"psr/http-message": "^1.0 || ^2.0"
},
Expand Down
3 changes: 0 additions & 3 deletions src/Exception/RequestAwareTrait.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,6 @@ private function setRequest(RequestInterface $request)
$this->request = $request;
}

/**
* {@inheritdoc}
*/
public function getRequest(): RequestInterface
{
return $this->request;
Expand Down
3 changes: 2 additions & 1 deletion src/HttpAsyncClient.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

use Http\Promise\Promise;
use Psr\Http\Message\RequestInterface;
use Psr\Http\Message\ResponseInterface;

/**
* Sends a PSR-7 Request in an asynchronous way by returning a Promise.
Expand All @@ -17,7 +18,7 @@ interface HttpAsyncClient
*
* Exceptions related to processing the request are available from the returned Promise.
*
* @return Promise resolves a PSR-7 Response or fails with an Http\Client\Exception
* @return Promise<ResponseInterface, Exception> resolves a PSR-7 Response or fails with an Http\Client\Exception
*
* @throws \Exception If processing the request is impossible (eg. bad configuration).
*/
Expand Down
12 changes: 3 additions & 9 deletions src/Promise/HttpFulfilledPromise.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@
use Http\Promise\Promise;
use Psr\Http\Message\ResponseInterface;

/**
* @implements Promise<ResponseInterface, Exception>
*/
final class HttpFulfilledPromise implements Promise
{
/**
Expand All @@ -18,9 +21,6 @@ public function __construct(ResponseInterface $response)
$this->response = $response;
}

/**
* {@inheritdoc}
*/
public function then(callable $onFulfilled = null, callable $onRejected = null)
{
if (null === $onFulfilled) {
Expand All @@ -34,17 +34,11 @@ public function then(callable $onFulfilled = null, callable $onRejected = null)
}
}

/**
* {@inheritdoc}
*/
public function getState()
{
return Promise::FULFILLED;
}

/**
* {@inheritdoc}
*/
public function wait($unwrap = true)
{
if ($unwrap) {

Check failure on line 44 in src/Promise/HttpFulfilledPromise.php

View workflow job for this annotation

GitHub Actions / PHPStan

Method Http\Client\Promise\HttpFulfilledPromise::wait() should return Psr\Http\Message\ResponseInterface|null but return statement is missing.
Expand Down
13 changes: 4 additions & 9 deletions src/Promise/HttpRejectedPromise.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,11 @@

use Http\Client\Exception;
use Http\Promise\Promise;
use Psr\Http\Message\ResponseInterface;

/**
* @implements Promise<ResponseInterface, Exception>
*/
final class HttpRejectedPromise implements Promise
{
/**
Expand All @@ -17,9 +21,6 @@ public function __construct(Exception $exception)
$this->exception = $exception;
}

/**
* {@inheritdoc}
*/
public function then(callable $onFulfilled = null, callable $onRejected = null)
{
if (null === $onRejected) {
Expand All @@ -38,17 +39,11 @@ public function then(callable $onFulfilled = null, callable $onRejected = null)
}
}

/**
* {@inheritdoc}
*/
public function getState()
{
return Promise::REJECTED;
}

/**
* {@inheritdoc}
*/
public function wait($unwrap = true)
{
if ($unwrap) {

Check failure on line 49 in src/Promise/HttpRejectedPromise.php

View workflow job for this annotation

GitHub Actions / PHPStan

Method Http\Client\Promise\HttpRejectedPromise::wait() should return Psr\Http\Message\ResponseInterface|null but return statement is missing.
Expand Down

0 comments on commit c56232d

Please sign in to comment.