for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
namespace Nimo\Tests;
use Nimo\Handlers\CallableHandler;
use Nimo\Handlers\MiddlewareIncluedHandler;
use PHPUnit\Framework\Assert;
class MiddlewareIncluedHandlerTest extends NimoTestCase
{
public function testMiddlewareIncluedHandler()
$wrappedHandler = $this->throwHandler();
$request = $this->getRequestMock();
$response = $this->getResponseMock();
$middleware = $this->assertedMiddleware($request, $wrappedHandler, $response);
$request
object<PHPUnit\Framework\MockObject\MockObject>
object<Psr\Http\Message\ServerRequestInterface>
It seems like the type of the argument is not accepted by the function/method which you are calling.
In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.
We suggest to add an explicit type cast like in the following example:
function acceptsInteger($int) { } $x = '123'; // string "123" // Instead of acceptsInteger($x); // we recommend to use acceptsInteger((integer) $x);
$response
object<Psr\Http\Message\ResponseInterface>
/**
* @var CallableHandler $wrappedHandler
*/
$handler = $wrappedHandler->includeMiddleware($middleware);
Assert::assertInstanceOf(MiddlewareIncluedHandler::class, $handler);
$actualResponse = $handler->handle($request);
Assert::assertSame($response, $actualResponse);
}
It seems like the type of the argument is not accepted by the function/method which you are calling.
In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.
We suggest to add an explicit type cast like in the following example: