cbcf62086f
Co-authored-by: DaneEveritt <dane@daneeveritt.com>
52 lines
1.5 KiB
PHP
52 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace Pterodactyl\Tests\Unit\Http\Middleware\Api\Application;
|
|
|
|
use Pterodactyl\Tests\Unit\Http\Middleware\MiddlewareTestCase;
|
|
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
|
|
use Pterodactyl\Http\Middleware\Api\Application\AuthenticateApplicationUser;
|
|
|
|
class AuthenticateUserTest extends MiddlewareTestCase
|
|
{
|
|
/**
|
|
* Test that no user defined results in an access denied exception.
|
|
*/
|
|
public function testNoUserDefined()
|
|
{
|
|
$this->expectException(AccessDeniedHttpException::class);
|
|
|
|
$this->setRequestUserModel(null);
|
|
|
|
$this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
|
|
}
|
|
|
|
/**
|
|
* Test that a non-admin user results in an exception.
|
|
*/
|
|
public function testNonAdminUser()
|
|
{
|
|
$this->expectException(AccessDeniedHttpException::class);
|
|
|
|
$this->generateRequestUserModel(['root_admin' => false]);
|
|
|
|
$this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
|
|
}
|
|
|
|
/**
|
|
* Test that an admin user continues though the middleware.
|
|
*/
|
|
public function testAdminUser()
|
|
{
|
|
$this->generateRequestUserModel(['root_admin' => true]);
|
|
|
|
$this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
|
|
}
|
|
|
|
/**
|
|
* Return an instance of the middleware for testing.
|
|
*/
|
|
private function getMiddleware(): AuthenticateApplicationUser
|
|
{
|
|
return new AuthenticateApplicationUser();
|
|
}
|
|
}
|