initial commit
This commit is contained in:
		
							
								
								
									
										41
									
								
								tests/Feature/ApiTokenPermissionsTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								tests/Feature/ApiTokenPermissionsTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace Tests\Feature; | ||||
| 
 | ||||
| use App\Models\User; | ||||
| use Illuminate\Foundation\Testing\RefreshDatabase; | ||||
| use Illuminate\Support\Str; | ||||
| use Laravel\Jetstream\Features; | ||||
| 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.'); | ||||
|         } | ||||
| 
 | ||||
|         $this->actingAs($user = User::factory()->withPersonalTeam()->create()); | ||||
| 
 | ||||
|         $token = $user->tokens()->create([ | ||||
|             'name' => 'Test Token', | ||||
|             'token' => Str::random(40), | ||||
|             'abilities' => ['create', 'read'], | ||||
|         ]); | ||||
| 
 | ||||
|         $response = $this->put('/user/api-tokens/'.$token->id, [ | ||||
|             'name' => $token->name, | ||||
|             'permissions' => [ | ||||
|                 'delete', | ||||
|                 'missing-permission', | ||||
|             ], | ||||
|         ]); | ||||
| 
 | ||||
|         $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')); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user