WebAuthnRegisterControllerTest.php 2.2 KB

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