mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-25 17:06:52 +02:00 
			
		
		
		
	Improve test coverage for LocationController (#3779)
By adding tests for create, update, delete
This commit is contained in:
		
							parent
							
								
									622b939f00
								
							
						
					
					
						commit
						dcbc1360a9
					
				| @ -5,6 +5,7 @@ namespace Pterodactyl\Tests\Integration\Api\Application\Location; | |||||||
| use Pterodactyl\Models\Node; | use Pterodactyl\Models\Node; | ||||||
| use Illuminate\Http\Response; | use Illuminate\Http\Response; | ||||||
| use Pterodactyl\Models\Location; | use Pterodactyl\Models\Location; | ||||||
|  | use Pterodactyl\Transformers\Api\Application\LocationTransformer; | ||||||
| use Pterodactyl\Transformers\Api\Application\NodeTransformer; | use Pterodactyl\Transformers\Api\Application\NodeTransformer; | ||||||
| use Pterodactyl\Transformers\Api\Application\ServerTransformer; | use Pterodactyl\Transformers\Api\Application\ServerTransformer; | ||||||
| use Pterodactyl\Tests\Integration\Api\Application\ApplicationApiIntegrationTestCase; | use Pterodactyl\Tests\Integration\Api\Application\ApplicationApiIntegrationTestCase; | ||||||
| @ -88,6 +89,77 @@ class LocationControllerTest extends ApplicationApiIntegrationTestCase | |||||||
|         ], true); |         ], true); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Test that a location can be created. | ||||||
|  |      */ | ||||||
|  |     public function testCreateLocation() | ||||||
|  |     { | ||||||
|  |         $response = $this->postJson('/api/application/locations', [ | ||||||
|  |             'short' => 'inhouse', | ||||||
|  |             'long' => 'This is my inhouse location', | ||||||
|  |         ]); | ||||||
|  | 
 | ||||||
|  |         $response->assertStatus(Response::HTTP_CREATED); | ||||||
|  |         $response->assertJsonCount(3); | ||||||
|  |         $response->assertJsonStructure([ | ||||||
|  |             'object', | ||||||
|  |             'attributes' => ['id', 'short', 'long', 'created_at', 'updated_at'], | ||||||
|  |             'meta' => ['resource'], | ||||||
|  |         ]); | ||||||
|  | 
 | ||||||
|  |         $this->assertDatabaseHas('locations', ['short' => 'inhouse', 'long' => 'This is my inhouse location']); | ||||||
|  | 
 | ||||||
|  |         $location = Location::where('short', 'inhouse')->first(); | ||||||
|  |         $response->assertJson([ | ||||||
|  |             'object' => 'location', | ||||||
|  |             'attributes' => $this->getTransformer(LocationTransformer::class)->transform($location), | ||||||
|  |             'meta' => [ | ||||||
|  |                 'resource' => route('api.application.locations.view', $location->id), | ||||||
|  |             ], | ||||||
|  |         ], true); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Test that a location can be updated. | ||||||
|  |      */ | ||||||
|  |     public function testUpdateLocation() | ||||||
|  |     { | ||||||
|  |         $location = Location::factory()->create(); | ||||||
|  | 
 | ||||||
|  |         $response = $this->patchJson('/api/application/locations/' . $location->id, [ | ||||||
|  |             'short' => 'new inhouse', | ||||||
|  |             'long' => 'This is my new inhouse location' | ||||||
|  |         ]); | ||||||
|  |         $response->assertStatus(Response::HTTP_OK); | ||||||
|  |         $response->assertJsonCount(2); | ||||||
|  |         $response->assertJsonStructure([ | ||||||
|  |             'object', | ||||||
|  |             'attributes' => ['id', 'short', 'long', 'created_at', 'updated_at'] | ||||||
|  |         ]); | ||||||
|  | 
 | ||||||
|  |         $this->assertDatabaseHas('locations', ['short' => 'new inhouse', 'long' => 'This is my new inhouse location']); | ||||||
|  |         $location = $location->fresh(); | ||||||
|  | 
 | ||||||
|  |         $response->assertJson([ | ||||||
|  |             'object' => 'location', | ||||||
|  |             'attributes' => $this->getTransformer(LocationTransformer::class)->transform($location), | ||||||
|  |         ]); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Test that a location can be deleted from the database. | ||||||
|  |      */ | ||||||
|  |     public function testDeleteLocation() | ||||||
|  |     { | ||||||
|  |         $location = Location::factory()->create(); | ||||||
|  |         $this->assertDatabaseHas('locations', ['id' => $location->id]); | ||||||
|  | 
 | ||||||
|  |         $response = $this->delete('/api/application/locations/' . $location->id); | ||||||
|  |         $response->assertStatus(Response::HTTP_NO_CONTENT); | ||||||
|  | 
 | ||||||
|  |         $this->assertDatabaseMissing('locations', ['id' => $location->id]); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Test that all of the defined relationships for a location can be loaded successfully. |      * Test that all of the defined relationships for a location can be loaded successfully. | ||||||
|      */ |      */ | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Paul Vogel
						Paul Vogel