2016-08-21 13:52:15 +02:00
|
|
|
<?php
|
2019-10-05 17:26:10 +02:00
|
|
|
|
2017-10-12 10:13:20 +02:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2016-08-21 13:52:15 +02:00
|
|
|
namespace ShlinkioTest\Shlink\Rest\Middleware;
|
|
|
|
|
2020-01-01 21:11:53 +01:00
|
|
|
use Laminas\Diactoros\Response;
|
|
|
|
use Laminas\Diactoros\ServerRequest;
|
|
|
|
use Laminas\Diactoros\Stream;
|
2017-03-24 20:34:18 +01:00
|
|
|
use PHPUnit\Framework\TestCase;
|
2017-03-25 09:22:00 +01:00
|
|
|
use Prophecy\Argument;
|
2020-11-02 11:50:19 +01:00
|
|
|
use Prophecy\PhpUnit\ProphecyTrait;
|
2019-12-01 10:58:48 +01:00
|
|
|
use Prophecy\Prophecy\ProphecyInterface;
|
2017-03-25 09:22:00 +01:00
|
|
|
use Psr\Http\Message\ServerRequestInterface;
|
2018-03-26 19:02:41 +02:00
|
|
|
use Psr\Http\Server\RequestHandlerInterface;
|
2016-08-21 13:52:15 +02:00
|
|
|
use Shlinkio\Shlink\Rest\Middleware\BodyParserMiddleware;
|
2019-02-26 22:56:43 +01:00
|
|
|
|
2018-10-28 08:34:02 +01:00
|
|
|
use function array_shift;
|
2016-08-21 13:52:15 +02:00
|
|
|
|
|
|
|
class BodyParserMiddlewareTest extends TestCase
|
|
|
|
{
|
2020-11-02 11:50:19 +01:00
|
|
|
use ProphecyTrait;
|
|
|
|
|
2019-12-29 22:48:40 +01:00
|
|
|
private BodyParserMiddleware $middleware;
|
2016-08-21 13:52:15 +02:00
|
|
|
|
2019-02-16 10:53:45 +01:00
|
|
|
public function setUp(): void
|
2016-08-21 13:52:15 +02:00
|
|
|
{
|
|
|
|
$this->middleware = new BodyParserMiddleware();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
2019-02-16 21:24:32 +01:00
|
|
|
* @dataProvider provideIgnoredRequestMethods
|
2016-08-21 13:52:15 +02:00
|
|
|
*/
|
2019-02-16 21:24:32 +01:00
|
|
|
public function requestsFromOtherMethodsJustFallbackToNextMiddleware(string $method): void
|
2016-08-21 13:52:15 +02:00
|
|
|
{
|
2019-12-01 10:58:48 +01:00
|
|
|
$request = $this->prophesize(ServerRequestInterface::class);
|
|
|
|
$request->getMethod()->willReturn($method);
|
|
|
|
$request->getParsedBody()->willReturn([]);
|
|
|
|
|
2020-10-04 00:35:14 +02:00
|
|
|
self::assertHandlingRequestJustFallsBackToNext($request);
|
2019-02-16 21:24:32 +01:00
|
|
|
}
|
2016-08-21 13:52:15 +02:00
|
|
|
|
2019-02-16 21:24:32 +01:00
|
|
|
public function provideIgnoredRequestMethods(): iterable
|
|
|
|
{
|
2019-02-17 20:28:34 +01:00
|
|
|
yield 'GET' => ['GET'];
|
|
|
|
yield 'HEAD' => ['HEAD'];
|
|
|
|
yield 'OPTIONS' => ['OPTIONS'];
|
2019-02-16 21:24:32 +01:00
|
|
|
}
|
2017-03-25 09:22:00 +01:00
|
|
|
|
2019-02-16 21:24:32 +01:00
|
|
|
/** @test */
|
|
|
|
public function requestsWithNonEmptyBodyJustFallbackToNextMiddleware(): void
|
|
|
|
{
|
2019-12-01 10:58:48 +01:00
|
|
|
$request = $this->prophesize(ServerRequestInterface::class);
|
|
|
|
$request->getMethod()->willReturn('POST');
|
|
|
|
$request->getParsedBody()->willReturn(['foo' => 'bar']);
|
|
|
|
|
2020-10-04 00:35:14 +02:00
|
|
|
self::assertHandlingRequestJustFallsBackToNext($request);
|
2016-08-21 13:52:15 +02:00
|
|
|
}
|
|
|
|
|
2019-12-01 10:58:48 +01:00
|
|
|
private function assertHandlingRequestJustFallsBackToNext(ProphecyInterface $requestMock): void
|
2019-02-16 21:24:32 +01:00
|
|
|
{
|
2019-12-01 10:58:48 +01:00
|
|
|
$getContentType = $requestMock->getHeaderLine('Content-type')->willReturn('');
|
|
|
|
$request = $requestMock->reveal();
|
|
|
|
|
2019-02-16 21:24:32 +01:00
|
|
|
$nextHandler = $this->prophesize(RequestHandlerInterface::class);
|
|
|
|
$handle = $nextHandler->handle($request)->willReturn(new Response());
|
|
|
|
|
|
|
|
$this->middleware->process($request, $nextHandler->reveal());
|
|
|
|
|
|
|
|
$handle->shouldHaveBeenCalledOnce();
|
2019-12-01 10:58:48 +01:00
|
|
|
$getContentType->shouldNotHaveBeenCalled();
|
2019-02-16 21:24:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** @test */
|
|
|
|
public function jsonRequestsAreJsonDecoded(): void
|
2016-08-21 13:52:15 +02:00
|
|
|
{
|
2017-03-25 09:22:00 +01:00
|
|
|
$test = $this;
|
2016-08-21 13:52:15 +02:00
|
|
|
$body = new Stream('php://temp', 'wr');
|
|
|
|
$body->write('{"foo": "bar", "bar": ["one", 5]}');
|
2018-12-25 23:01:30 +01:00
|
|
|
$request = (new ServerRequest())->withMethod('PUT')
|
|
|
|
->withBody($body)
|
|
|
|
->withHeader('content-type', 'application/json');
|
2018-03-26 19:02:41 +02:00
|
|
|
$delegate = $this->prophesize(RequestHandlerInterface::class);
|
|
|
|
$process = $delegate->handle(Argument::type(ServerRequestInterface::class))->will(
|
2017-03-25 09:22:00 +01:00
|
|
|
function (array $args) use ($test) {
|
|
|
|
/** @var ServerRequestInterface $req */
|
|
|
|
$req = array_shift($args);
|
|
|
|
|
|
|
|
$test->assertEquals([
|
|
|
|
'foo' => 'bar',
|
|
|
|
'bar' => ['one', 5],
|
|
|
|
], $req->getParsedBody());
|
|
|
|
|
|
|
|
return new Response();
|
2020-01-01 20:48:31 +01:00
|
|
|
},
|
2017-03-25 09:22:00 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->middleware->process($request, $delegate->reveal());
|
|
|
|
|
2018-11-11 13:18:21 +01:00
|
|
|
$process->shouldHaveBeenCalledOnce();
|
2016-08-21 13:52:15 +02:00
|
|
|
}
|
|
|
|
|
2019-02-16 21:24:32 +01:00
|
|
|
/** @test */
|
|
|
|
public function regularRequestsAreUrlDecoded(): void
|
2016-08-21 13:52:15 +02:00
|
|
|
{
|
2017-03-25 09:22:00 +01:00
|
|
|
$test = $this;
|
2016-08-21 13:52:15 +02:00
|
|
|
$body = new Stream('php://temp', 'wr');
|
|
|
|
$body->write('foo=bar&bar[]=one&bar[]=5');
|
2018-12-25 23:01:30 +01:00
|
|
|
$request = (new ServerRequest())->withMethod('PUT')
|
|
|
|
->withBody($body);
|
2018-03-26 19:02:41 +02:00
|
|
|
$delegate = $this->prophesize(RequestHandlerInterface::class);
|
|
|
|
$process = $delegate->handle(Argument::type(ServerRequestInterface::class))->will(
|
2017-03-25 09:22:00 +01:00
|
|
|
function (array $args) use ($test) {
|
|
|
|
/** @var ServerRequestInterface $req */
|
|
|
|
$req = array_shift($args);
|
|
|
|
|
|
|
|
$test->assertEquals([
|
|
|
|
'foo' => 'bar',
|
|
|
|
'bar' => ['one', 5],
|
|
|
|
], $req->getParsedBody());
|
|
|
|
|
|
|
|
return new Response();
|
2020-01-01 20:48:31 +01:00
|
|
|
},
|
2017-03-25 09:22:00 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->middleware->process($request, $delegate->reveal());
|
|
|
|
|
2018-11-11 13:18:21 +01:00
|
|
|
$process->shouldHaveBeenCalledOnce();
|
2016-08-21 13:52:15 +02:00
|
|
|
}
|
|
|
|
}
|