mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-10-28 12:11:08 -04:00 
			
		
		
		
	* Create PHP CS Fixer config and add to CI workflow * Run php cs fixer on project * Add newline at end of file * Update to use PHP CS Fixer v3 * Run v3 config on project * Run seperate config in CI
		
			
				
	
	
		
			103 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| use Crater\Http\Controllers\V1\CustomField\CustomFieldsController;
 | |
| use Crater\Http\Requests\CustomFieldRequest;
 | |
| use Crater\Models\CustomField;
 | |
| use Crater\Models\User;
 | |
| use Illuminate\Support\Facades\Artisan;
 | |
| use Laravel\Sanctum\Sanctum;
 | |
| use function Pest\Laravel\deleteJson;
 | |
| use function Pest\Laravel\getJson;
 | |
| use function Pest\Laravel\postJson;
 | |
| use function Pest\Laravel\putJson;
 | |
| 
 | |
| beforeEach(function () {
 | |
|     Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
 | |
|     Artisan::call('db:seed', ['--class' => 'DemoSeeder', '--force' => true]);
 | |
| 
 | |
|     $user = User::find(1);
 | |
|     $this->withHeaders([
 | |
|         'company' => $user->company_id,
 | |
|     ]);
 | |
|     Sanctum::actingAs(
 | |
|         $user,
 | |
|         ['*']
 | |
|     );
 | |
| });
 | |
| 
 | |
| test('get custom fields', function () {
 | |
|     $response = getJson('api/v1/custom-fields?page=1');
 | |
| 
 | |
|     $response->assertOk();
 | |
| });
 | |
| 
 | |
| test('create custom field', function () {
 | |
|     $data = CustomField::factory()->raw();
 | |
| 
 | |
|     postJson('api/v1/custom-fields', $data)
 | |
|         ->assertStatus(200)
 | |
|         ->assertJson([
 | |
|             'success' => true,
 | |
|         ]);
 | |
| 
 | |
|     $this->assertDatabaseHas('custom_fields', [
 | |
|         'name' => $data['name'],
 | |
|         'label' => $data['label'],
 | |
|         'type' => $data['type'],
 | |
|         'model_type' => $data['model_type'],
 | |
|         'is_required' => $data['is_required'],
 | |
|     ]);
 | |
| });
 | |
| 
 | |
| test('store validates using a form request', function () {
 | |
|     $this->assertActionUsesFormRequest(
 | |
|         CustomFieldsController::class,
 | |
|         'store',
 | |
|         CustomFieldRequest::class
 | |
|     );
 | |
| });
 | |
| 
 | |
| test('update custom field', function () {
 | |
|     $customField = CustomField::factory()->create();
 | |
| 
 | |
|     $newCustomField = CustomField::factory()->raw([
 | |
|         'is_required' => false,
 | |
|     ]);
 | |
| 
 | |
|     putJson('api/v1/custom-fields/'.$customField->id, $newCustomField)
 | |
|         ->assertStatus(200)
 | |
|         ->assertJson([
 | |
|             'success' => true,
 | |
|         ]);
 | |
| 
 | |
|     $this->assertDatabaseHas('custom_fields', [
 | |
|         'id' => $customField->id,
 | |
|         'name' => $newCustomField['name'],
 | |
|         'label' => $newCustomField['label'],
 | |
|         'type' => $newCustomField['type'],
 | |
|         'model_type' => $newCustomField['model_type'],
 | |
|     ]);
 | |
| });
 | |
| 
 | |
| test('update validates using a form request', function () {
 | |
|     $this->assertActionUsesFormRequest(
 | |
|         CustomFieldsController::class,
 | |
|         'update',
 | |
|         CustomFieldRequest::class
 | |
|     );
 | |
| });
 | |
| 
 | |
| test('delete custom field', function () {
 | |
|     $customField = CustomField::factory()->create();
 | |
| 
 | |
|     $response = deleteJson('api/v1/custom-fields/'.$customField->id);
 | |
| 
 | |
|     $response
 | |
|         ->assertOk()
 | |
|         ->assertJson([
 | |
|             'success' => true,
 | |
|         ]);
 | |
| 
 | |
|     $this->assertDeleted($customField);
 | |
| });
 |