WebAuthnRegisterControllerTest.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <?php
  2. namespace Tests\Feature\Http\Auth;
  3. use App\Models\User;
  4. use Tests\FeatureTestCase;
  5. use Laragear\WebAuthn\Http\Requests\AttestedRequest;
  6. use Laragear\WebAuthn\Http\Requests\AttestationRequest;
  7. use Illuminate\Support\Facades\Config;
  8. use Laragear\WebAuthn\WebAuthn;
  9. use Laragear\WebAuthn\JsonTransport;
  10. /**
  11. * @covers \App\Http\Controllers\Auth\WebAuthnRegisterController
  12. */
  13. class WebAuthnRegisterControllerTest extends FeatureTestCase
  14. {
  15. /**
  16. * @var \App\Models\User
  17. */
  18. protected $user;
  19. /**
  20. * @test
  21. */
  22. public function setUp(): void
  23. {
  24. parent::setUp();
  25. $this->user = User::factory()->create();
  26. }
  27. /**
  28. * @test
  29. */
  30. public function test_uses_attestation_with_fastRegistration_request(): void
  31. {
  32. Config::set('webauthn.user_verification', WebAuthn::USER_VERIFICATION_DISCOURAGED);
  33. $request = $this->mock(AttestationRequest::class);
  34. $request->expects('fastRegistration')->andReturnSelf();
  35. $request->expects('toCreate')->andReturn(new JsonTransport());
  36. $this->actingAs($this->user, 'web-guard')
  37. ->json('POST', '/webauthn/register/options')
  38. ->assertOk();
  39. }
  40. /**
  41. * @test
  42. */
  43. public function test_uses_attestation_with_secureRegistration_request(): void
  44. {
  45. Config::set('webauthn.user_verification', WebAuthn::USER_VERIFICATION_REQUIRED);
  46. $request = $this->mock(AttestationRequest::class);
  47. $request->expects('secureRegistration')->andReturnSelf();
  48. $request->expects('toCreate')->andReturn(new JsonTransport());
  49. $this->actingAs($this->user, 'web-guard')
  50. ->json('POST', '/webauthn/register/options')
  51. ->assertOk();
  52. }
  53. /**
  54. * @test
  55. */
  56. public function test_register_uses_attested_request(): void
  57. {
  58. $this->mock(AttestedRequest::class)->expects('save')->andReturn();
  59. $this->actingAs($this->user, 'web-guard')
  60. ->json('POST', '/webauthn/register')
  61. ->assertNoContent();
  62. }
  63. }