TwoFAccountReorderRequestTest.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. namespace Tests\Api\v1\Requests;
  3. use App\Api\v1\Requests\TwoFAccountReorderRequest;
  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\TwoFAccountReorderRequest
  10. */
  11. class TwoFAccountReorderRequestTest 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 TwoFAccountReorderRequest();
  23. $this->assertTrue($request->authorize());
  24. }
  25. /**
  26. * @dataProvider provideValidData
  27. */
  28. public function test_valid_data(array $data): void
  29. {
  30. $request = new TwoFAccountReorderRequest();
  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. 'orderedIds' => [1, 2, 5],
  42. ]],
  43. [[
  44. 'orderedIds' => [5],
  45. ]],
  46. ];
  47. }
  48. /**
  49. * @dataProvider provideInvalidData
  50. */
  51. public function test_invalid_data(array $data): void
  52. {
  53. $request = new TwoFAccountReorderRequest();
  54. $validator = Validator::make($data, $request->rules());
  55. $this->assertTrue($validator->fails());
  56. }
  57. /**
  58. * Provide invalid data for validation test
  59. */
  60. public function provideInvalidData(): array
  61. {
  62. return [
  63. [[
  64. 'orderedIds' => [], // required
  65. ]],
  66. [[
  67. 'orderedIds' => null, // required
  68. ]],
  69. [[
  70. 'orderedIds' => 0, // array
  71. ]],
  72. [[
  73. 'orderedIds' => 'string', // array
  74. ]],
  75. [[
  76. 'orderedIds' => true, // array
  77. ]],
  78. ];
  79. }
  80. }