HomeController: Fix redirect

This commit is contained in:
Igor Scheller 2020-05-10 15:55:44 +02:00 committed by msquare
parent 2e1fbfb16d
commit ae744af814
2 changed files with 19 additions and 15 deletions

View File

@ -4,35 +4,37 @@ namespace Engelsystem\Controllers;
use Engelsystem\Config\Config;
use Engelsystem\Helpers\Authenticator;
use Engelsystem\Http\Exceptions\HttpTemporaryRedirect;
use Engelsystem\Http\Redirector;
use Engelsystem\Http\Response;
class HomeController extends BaseController
{
/**
* @var Authenticator
*/
/** @var Authenticator */
protected $auth;
/**
* @var Config
*/
/** @var Config */
protected $config;
/** @var Redirector */
protected $redirect;
/**
* @param Authenticator $auth
* @param Config $config
* @param Redirector $redirect
*/
public function __construct(Authenticator $auth, Config $config)
public function __construct(Authenticator $auth, Config $config, Redirector $redirect)
{
$this->auth = $auth;
$this->config = $config;
$this->redirect = $redirect;
}
/**
* @throws HttpTemporaryRedirect
* @return Response
*/
public function index()
public function index(): Response
{
throw new HttpTemporaryRedirect($this->auth->user() ? $this->config->get('home_site') : 'login');
return $this->redirect->to($this->auth->user() ? $this->config->get('home_site') : 'login');
}
}

View File

@ -5,7 +5,8 @@ namespace Engelsystem\Test\Unit\Controllers;
use Engelsystem\Config\Config;
use Engelsystem\Controllers\HomeController;
use Engelsystem\Helpers\Authenticator;
use Engelsystem\Http\Exceptions\HttpTemporaryRedirect;
use Engelsystem\Http\Redirector;
use Engelsystem\Http\Response;
use Engelsystem\Test\Unit\TestCase;
use PHPUnit\Framework\MockObject\MockObject;
@ -21,10 +22,11 @@ class HomeControllerTest extends TestCase
/** @var Authenticator|MockObject $auth */
$auth = $this->createMock(Authenticator::class);
$this->setExpects($auth, 'user', null, true);
/** @var Redirector|MockObject $redirect */
$redirect = $this->createMock(Redirector::class);
$this->setExpects($redirect, 'to', ['/foo'], new Response());
$controller = new HomeController($auth, $config);
$this->expectException(HttpTemporaryRedirect::class);
$controller = new HomeController($auth, $config, $redirect);
$controller->index();
}
}