1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- <?php
- namespace Tests\Feature;
- use App\Models\User;
- use Illuminate\Foundation\Testing\RefreshDatabase;
- use Illuminate\Support\Str;
- use Laravel\Jetstream\Features;
- use Laravel\Jetstream\Http\Livewire\ApiTokenManager;
- use Livewire\Livewire;
- use Tests\TestCase;
- class ApiTokenPermissionsTest extends TestCase
- {
- use RefreshDatabase;
- public function test_api_token_permissions_can_be_updated()
- {
- if (! Features::hasApiFeatures()) {
- return $this->markTestSkipped('API support is not enabled.');
- }
- if (Features::hasTeamFeatures()) {
- $this->actingAs($user = User::factory()->withPersonalTeam()->create());
- } else {
- $this->actingAs($user = User::factory()->create());
- }
- $token = $user->tokens()->create([
- 'name' => 'Test Token',
- 'token' => Str::random(40),
- 'abilities' => ['create', 'read'],
- ]);
- Livewire::test(ApiTokenManager::class)
- ->set(['managingPermissionsFor' => $token])
- ->set(['updateApiTokenForm' => [
- 'permissions' => [
- 'delete',
- 'missing-permission',
- ],
- ]])
- ->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'));
- }
- }
|