Add support API token management to profile
This commit is contained in:
66
tests/Feature/SuperAdminSupportApiTokensTest.php
Normal file
66
tests/Feature/SuperAdminSupportApiTokensTest.php
Normal file
@@ -0,0 +1,66 @@
|
||||
<?php
|
||||
|
||||
namespace Tests\Feature;
|
||||
|
||||
use App\Filament\SuperAdmin\Widgets\SupportApiTokenManager;
|
||||
use App\Models\User;
|
||||
use Filament\Facades\Filament;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Laravel\Sanctum\PersonalAccessToken;
|
||||
use Livewire\Livewire;
|
||||
use Tests\TestCase;
|
||||
|
||||
class SuperAdminSupportApiTokensTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
public function test_superadmin_can_create_support_api_token(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'super_admin']);
|
||||
|
||||
$this->bootSuperAdminPanel($user);
|
||||
|
||||
Livewire::test(SupportApiTokenManager::class)
|
||||
->callTableAction('create_support_token', null, [
|
||||
'name' => 'support-api',
|
||||
'abilities' => ['support:read'],
|
||||
'expires_at' => now()->addDays(7)->toDateTimeString(),
|
||||
]);
|
||||
|
||||
$token = PersonalAccessToken::query()
|
||||
->where('tokenable_id', $user->getKey())
|
||||
->where('tokenable_type', $user->getMorphClass())
|
||||
->where('name', 'support-api')
|
||||
->latest('id')
|
||||
->first();
|
||||
|
||||
$this->assertNotNull($token);
|
||||
$this->assertContains('support-admin', $token->abilities ?? []);
|
||||
$this->assertContains('support:read', $token->abilities ?? []);
|
||||
$this->assertNotNull($token->expires_at);
|
||||
}
|
||||
|
||||
public function test_superadmin_can_revoke_support_api_token(): void
|
||||
{
|
||||
$user = User::factory()->create(['role' => 'super_admin']);
|
||||
$token = $user->createToken('support-api', ['support:read'])->accessToken;
|
||||
|
||||
$this->bootSuperAdminPanel($user);
|
||||
|
||||
Livewire::test(SupportApiTokenManager::class)
|
||||
->callTableAction('revoke', $token);
|
||||
|
||||
$this->assertFalse(PersonalAccessToken::query()->whereKey($token->getKey())->exists());
|
||||
}
|
||||
|
||||
private function bootSuperAdminPanel(User $user): void
|
||||
{
|
||||
$panel = Filament::getPanel('superadmin');
|
||||
|
||||
$this->assertNotNull($panel);
|
||||
|
||||
Filament::setCurrentPanel($panel);
|
||||
Filament::bootCurrentPanel();
|
||||
Filament::auth()->login($user);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user