ApiTokenPermissionsTest.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <?php
  2. namespace Tests\Feature;
  3. use App\Models\User;
  4. use Illuminate\Foundation\Testing\RefreshDatabase;
  5. use Illuminate\Support\Str;
  6. use Laravel\Jetstream\Features;
  7. use Laravel\Jetstream\Http\Livewire\ApiTokenManager;
  8. use Livewire\Livewire;
  9. use Tests\TestCase;
  10. class ApiTokenPermissionsTest extends TestCase
  11. {
  12. use RefreshDatabase;
  13. public function test_api_token_permissions_can_be_updated()
  14. {
  15. if (! Features::hasApiFeatures()) {
  16. return $this->markTestSkipped('API support is not enabled.');
  17. }
  18. if (Features::hasTeamFeatures()) {
  19. $this->actingAs($user = User::factory()->withPersonalTeam()->create());
  20. } else {
  21. $this->actingAs($user = User::factory()->create());
  22. }
  23. $token = $user->tokens()->create([
  24. 'name' => 'Test Token',
  25. 'token' => Str::random(40),
  26. 'abilities' => ['create', 'read'],
  27. ]);
  28. Livewire::test(ApiTokenManager::class)
  29. ->set(['managingPermissionsFor' => $token])
  30. ->set(['updateApiTokenForm' => [
  31. 'permissions' => [
  32. 'delete',
  33. 'missing-permission',
  34. ],
  35. ]])
  36. ->call('updateApiToken');
  37. $this->assertTrue($user->fresh()->tokens->first()->can('delete'));
  38. $this->assertFalse($user->fresh()->tokens->first()->can('read'));
  39. $this->assertFalse($user->fresh()->tokens->first()->can('missing-permission'));
  40. }
  41. }