2024-08-01 13:53:10 -05:00
|
|
|
<?php
|
|
|
|
|
|
2025-01-28 17:33:54 -06:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
2024-09-06 19:39:04 -05:00
|
|
|
namespace Tests;
|
2024-08-01 13:53:10 -05:00
|
|
|
|
|
|
|
|
use App\Models\User;
|
|
|
|
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
|
|
|
|
use Illuminate\Support\Str;
|
|
|
|
|
use Livewire\Livewire;
|
2025-09-26 17:41:28 -05:00
|
|
|
use Livewire\Volt\Volt;
|
2024-08-01 13:53:10 -05:00
|
|
|
|
|
|
|
|
class ApiTokenPermissionsTest extends TestCase
|
|
|
|
|
{
|
|
|
|
|
use RefreshDatabase;
|
|
|
|
|
|
2025-01-27 20:04:03 -06:00
|
|
|
public function test_api_tokens_can_be_deleted(): void
|
|
|
|
|
{
|
2025-01-28 17:46:59 -06:00
|
|
|
|
2025-01-27 20:04:03 -06:00
|
|
|
$this->actingAs($user = User::factory()->create());
|
|
|
|
|
|
|
|
|
|
$token = $user->tokens()->create([
|
|
|
|
|
'name' => 'Test Token',
|
|
|
|
|
'token' => Str::random(40),
|
|
|
|
|
'abilities' => [],
|
|
|
|
|
]);
|
|
|
|
|
|
2025-09-26 17:41:28 -05:00
|
|
|
Livewire::test('api-token-manager')
|
2025-01-27 20:04:03 -06:00
|
|
|
->set(['apiTokenIdBeingDeleted' => $token->id])
|
|
|
|
|
->call('deleteApiToken');
|
|
|
|
|
|
|
|
|
|
$this->assertCount(0, $user->fresh()->tokens);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function test_api_tokens_can_be_created(): void
|
|
|
|
|
{
|
2025-01-28 17:46:59 -06:00
|
|
|
|
2025-01-27 20:04:03 -06:00
|
|
|
$this->actingAs($user = User::factory()->create());
|
|
|
|
|
|
2025-09-26 17:41:28 -05:00
|
|
|
Livewire::test('api-token-manager')
|
2025-01-27 20:04:03 -06:00
|
|
|
->set(['createApiTokenForm' => [
|
|
|
|
|
'name' => 'Test Token',
|
|
|
|
|
'permissions' => [],
|
|
|
|
|
]])
|
|
|
|
|
->call('createApiToken');
|
|
|
|
|
|
|
|
|
|
$this->assertCount(1, $user->fresh()->tokens);
|
|
|
|
|
$this->assertEquals('Test Token', $user->fresh()->tokens->first()->name);
|
|
|
|
|
}
|
2024-09-05 18:21:19 -05:00
|
|
|
|
|
|
|
|
// public function test_api_token_permissions_can_be_updated(): void
|
|
|
|
|
// {
|
|
|
|
|
// if (! Features::hasApiFeatures()) {
|
|
|
|
|
// $this->markTestSkipped('API support is not enabled.');
|
|
|
|
|
// }
|
|
|
|
|
|
2024-09-06 19:39:04 -05:00
|
|
|
// $this->actingAs($user = User::factory()->create());
|
2024-09-05 18:21:19 -05:00
|
|
|
|
|
|
|
|
// $token = $user->tokens()->create([
|
|
|
|
|
// 'name' => 'Test Token',
|
|
|
|
|
// 'token' => Str::random(40),
|
|
|
|
|
// 'abilities' => ['create', 'read'],
|
|
|
|
|
// ]);
|
|
|
|
|
|
2025-09-26 17:41:28 -05:00
|
|
|
// Volt::test('api-token-manager')
|
2024-09-05 18:21:19 -05:00
|
|
|
// ->set(['managingPermissionsFor' => $token])
|
|
|
|
|
// ->set(['updateApiTokenForm' => [
|
2025-01-27 20:04:03 -06:00
|
|
|
// 'permissions' => [],
|
2024-09-05 18:21:19 -05:00
|
|
|
// ]])
|
|
|
|
|
// ->call('updateApiToken');
|
|
|
|
|
|
|
|
|
|
// $this->assertTrue($user->fresh()->tokens->first()->can('delete'));
|
|
|
|
|
// $this->assertFalse($user->fresh()->tokens->first()->can('read'));
|
|
|
|
|
// $this->assertFalse($user->fresh()->tokens->first()->can('missing-permission'));
|
|
|
|
|
// }
|
2024-08-01 13:53:10 -05:00
|
|
|
}
|