2023-03-18 17:33:43 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests\Feature\Http\Middlewares;
|
|
|
|
|
|
|
|
use App\Http\Middleware\AdminOnly;
|
|
|
|
use App\Models\User;
|
|
|
|
use Illuminate\Auth\Access\AuthorizationException;
|
|
|
|
use Illuminate\Http\Request;
|
2024-06-26 14:29:13 +02:00
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2023-03-18 17:33:43 +01:00
|
|
|
use Tests\FeatureTestCase;
|
|
|
|
|
|
|
|
class AdminOnlyMiddlewareTest extends FeatureTestCase
|
|
|
|
{
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2023-03-18 17:33:43 +01:00
|
|
|
public function test_users_are_rejected()
|
|
|
|
{
|
|
|
|
$this->expectException(AuthorizationException::class);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var \App\Models\User|\Illuminate\Contracts\Auth\Authenticatable
|
|
|
|
*/
|
|
|
|
$user = User::factory()->create();
|
|
|
|
|
|
|
|
$this->actingAs($user);
|
|
|
|
|
|
|
|
$request = Request::create('/admin', 'GET');
|
|
|
|
$middleware = new AdminOnly;
|
|
|
|
|
|
|
|
$response = $middleware->handle($request, function () {
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-06-26 14:29:13 +02:00
|
|
|
#[Test]
|
2023-03-18 17:33:43 +01:00
|
|
|
public function test_admins_pass()
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var \App\Models\User|\Illuminate\Contracts\Auth\Authenticatable
|
|
|
|
*/
|
|
|
|
$admin = User::factory()->administrator()->create();
|
|
|
|
|
|
|
|
$this->actingAs($admin);
|
|
|
|
|
|
|
|
$request = Request::create('/admin', 'GET');
|
|
|
|
$middleware = new AdminOnly;
|
|
|
|
|
|
|
|
$response = $middleware->handle($request, function () {
|
|
|
|
});
|
|
|
|
|
|
|
|
$this->assertNull($response);
|
|
|
|
}
|
|
|
|
}
|