[CORE][Controller] Fix JSON response and add test annotations

This commit is contained in:
Hugo Sales 2021-08-08 00:35:27 +00:00 committed by Diogo Peralta Cordeiro
parent a4cb90ba12
commit 7cace2051f
Signed by: diogo
GPG Key ID: 18D2D35001FBFAB0

View File

@ -30,7 +30,9 @@
namespace App\Core; namespace App\Core;
use function App\Core\I18n\_m;
use App\Util\Common; use App\Util\Common;
use App\Util\Exception\ClientException;
use App\Util\Exception\RedirectException; use App\Util\Exception\RedirectException;
use Exception; use Exception;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
@ -43,7 +45,6 @@ use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpKernel\Event\ControllerEvent; use Symfony\Component\HttpKernel\Event\ControllerEvent;
use Symfony\Component\HttpKernel\Event\ExceptionEvent; use Symfony\Component\HttpKernel\Event\ExceptionEvent;
use Symfony\Component\HttpKernel\Event\ViewEvent; use Symfony\Component\HttpKernel\Event\ViewEvent;
use Symfony\Component\HttpKernel\Exception\BadRequestHttpException;
use Symfony\Component\HttpKernel\KernelEvents; use Symfony\Component\HttpKernel\KernelEvents;
class Controller extends AbstractController implements EventSubscriberInterface class Controller extends AbstractController implements EventSubscriberInterface
@ -56,6 +57,11 @@ class Controller extends AbstractController implements EventSubscriberInterface
$this->request = $requestStack->getCurrentRequest(); $this->request = $requestStack->getCurrentRequest();
} }
/**
* TODO: Not currently used, so not tested, but should be
*
* @codeCoverageIgnore
*/
public function __invoke(Request $request) public function __invoke(Request $request)
{ {
$this->request = $request; $this->request = $request;
@ -92,14 +98,17 @@ class Controller extends AbstractController implements EventSubscriberInterface
$request = $event->getRequest(); $request = $event->getRequest();
$response = $event->getControllerResult(); $response = $event->getControllerResult();
if (!is_array($response)) { if (!is_array($response)) {
// This means it's not one of our custom format responses, nothing to do
// @codeCoverageIgnoreStart
return $event; return $event;
// @codeCoverageIgnoreEnd
} }
$this->vars = array_merge_recursive($this->vars, $response); $this->vars = array_merge_recursive($this->vars, $response);
Event::handle('EndTwigPopulateVars', [&$this->vars]); Event::handle('EndTwigPopulateVars', [&$this->vars]);
$template = $this->vars['_template']; $template = $this->vars['_template'];
unset($this->vars['_template'], $this->vars['request']); unset($this->vars['_template'], $this->vars['request'], $response['_template']);
// Respond in the the most preffered acceptable content type // Respond in the the most preffered acceptable content type
$accept = $request->getAcceptableContentTypes() ?: ['text/html']; $accept = $request->getAcceptableContentTypes() ?: ['text/html'];
@ -109,10 +118,10 @@ class Controller extends AbstractController implements EventSubscriberInterface
$event->setResponse($this->render($template, $this->vars)); $event->setResponse($this->render($template, $this->vars));
break; break;
case 'json': case 'json':
$event->setResponse(new JsonResponse($this->vars)); $event->setResponse(new JsonResponse($response));
break; break;
default: default:
throw new BadRequestHttpException('Unsupported format', null, 406); throw new ClientException(_m('Unsupported format'), 406); // 406 Not Acceptable
} }
return $event; return $event;
@ -120,6 +129,8 @@ class Controller extends AbstractController implements EventSubscriberInterface
/** /**
* Symfony event when the controller throws an exception * Symfony event when the controller throws an exception
*
* @codeCoverageIgnore
*/ */
public function onKernelException(ExceptionEvent $event) public function onKernelException(ExceptionEvent $event)
{ {
@ -140,6 +151,9 @@ class Controller extends AbstractController implements EventSubscriberInterface
return $event; return $event;
} }
/**
* @codeCoverageIgnore
*/
public static function getSubscribedEvents() public static function getSubscribedEvents()
{ {
return [ return [
@ -166,8 +180,10 @@ class Controller extends AbstractController implements EventSubscriberInterface
case 'bool': case 'bool':
return (bool) $value; return (bool) $value;
default: default:
// @codeCoverageIgnoreStart
Log::critical($m = "Method '{$method}' on class App\\Core\\Controller not found (__call)"); Log::critical($m = "Method '{$method}' on class App\\Core\\Controller not found (__call)");
throw new Exception($m); throw new Exception($m);
// @codeCoverageIgnoreEnd
} }
} }
} }