stage 1 of oauth removal, switch to sanctum pat tokens
This commit is contained in:
77
tests/Feature/Auth/UserRoleAccessTest.php
Normal file
77
tests/Feature/Auth/UserRoleAccessTest.php
Normal file
@@ -0,0 +1,77 @@
|
||||
<?php
|
||||
|
||||
namespace Tests\Feature\Auth;
|
||||
|
||||
use App\Models\User;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Tests\TestCase;
|
||||
|
||||
class UserRoleAccessTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
public function test_user_role_cannot_access_dashboard(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'user']);
|
||||
|
||||
$response = $this->actingAs($user)->get('/dashboard');
|
||||
|
||||
$response->assertRedirect('/packages');
|
||||
}
|
||||
|
||||
public function test_user_role_cannot_access_event_admin_dashboard(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'user']);
|
||||
|
||||
$response = $this->actingAs($user)->get('/event-admin/dashboard');
|
||||
|
||||
$response->assertRedirect('/packages');
|
||||
}
|
||||
|
||||
public function test_user_role_cannot_access_event_admin_logout(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'user']);
|
||||
|
||||
$response = $this->actingAs($user)->get('/event-admin/logout');
|
||||
|
||||
$response->assertRedirect('/packages');
|
||||
}
|
||||
|
||||
public function test_user_role_login_redirects_to_packages(): void
|
||||
{
|
||||
$user = User::factory()->create(['email' => 'test@example.com', 'role' => 'user']);
|
||||
|
||||
$response = $this->post('/login', [
|
||||
'login' => 'test@example.com',
|
||||
'password' => 'password',
|
||||
]);
|
||||
|
||||
$response->assertRedirect('/packages');
|
||||
}
|
||||
|
||||
public function test_tenant_admin_can_access_both_dashboards(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'tenant_admin']);
|
||||
|
||||
// Can access regular dashboard
|
||||
$response1 = $this->actingAs($user)->get('/dashboard');
|
||||
$response1->assertStatus(200);
|
||||
|
||||
// Can access event admin dashboard
|
||||
$response2 = $this->actingAs($user)->get('/event-admin/dashboard');
|
||||
$response2->assertStatus(200);
|
||||
}
|
||||
|
||||
public function test_super_admin_can_access_both_dashboards(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'super_admin']);
|
||||
|
||||
// Can access regular dashboard
|
||||
$response1 = $this->actingAs($user)->get('/dashboard');
|
||||
$response1->assertStatus(200);
|
||||
|
||||
// Can access event admin dashboard
|
||||
$response2 = $this->actingAs($user)->get('/event-admin/dashboard');
|
||||
$response2->assertStatus(200);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user