SettingUpdateRequestTest.php 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. namespace Tests\Api\v1\Requests;
  3. use App\Api\v1\Requests\SettingUpdateRequest;
  4. use Illuminate\Foundation\Testing\WithoutMiddleware;
  5. use Illuminate\Support\Facades\Auth;
  6. use Illuminate\Support\Facades\Validator;
  7. use Tests\TestCase;
  8. /**
  9. * @covers \App\Api\v1\Requests\SettingUpdateRequest
  10. */
  11. class SettingUpdateRequestTest extends TestCase
  12. {
  13. use WithoutMiddleware;
  14. /**
  15. * @test
  16. */
  17. public function test_user_is_authorized()
  18. {
  19. Auth::shouldReceive('check')
  20. ->once()
  21. ->andReturn(true);
  22. $request = new SettingUpdateRequest();
  23. $this->assertTrue($request->authorize());
  24. }
  25. /**
  26. * @dataProvider provideValidData
  27. */
  28. public function test_valid_data(array $data): void
  29. {
  30. $request = new SettingUpdateRequest();
  31. $validator = Validator::make($data, $request->rules());
  32. $this->assertFalse($validator->fails());
  33. }
  34. /**
  35. * Provide Valid data for validation test
  36. */
  37. public function provideValidData(): array
  38. {
  39. return [
  40. [[
  41. 'value' => true,
  42. ]],
  43. [[
  44. 'value' => 'MyValue',
  45. ]],
  46. [[
  47. 'value' => 10,
  48. ]],
  49. ];
  50. }
  51. /**
  52. * @dataProvider provideInvalidData
  53. */
  54. public function test_invalid_data(array $data): void
  55. {
  56. $request = new SettingUpdateRequest();
  57. $validator = Validator::make($data, $request->rules());
  58. $this->assertTrue($validator->fails());
  59. }
  60. /**
  61. * Provide invalid data for validation test
  62. */
  63. public function provideInvalidData(): array
  64. {
  65. return [
  66. [[
  67. 'value' => '', // required
  68. ]],
  69. [[
  70. 'value' => null, // required
  71. ]],
  72. ];
  73. }
  74. }