2020-11-24 15:15:51 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.context 'WebAuthn' do
|
|
|
|
include JavaScriptFixturesHelpers
|
|
|
|
|
|
|
|
let(:user) { create(:user, :two_factor_via_webauthn, otp_secret: 'otpsecret:coolkids') }
|
|
|
|
|
|
|
|
describe SessionsController, '(JavaScript fixtures)', type: :controller do
|
|
|
|
include DeviseHelpers
|
|
|
|
|
|
|
|
render_views
|
|
|
|
|
|
|
|
before do
|
|
|
|
set_devise_mapping(context: @request)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'webauthn/authenticate.html' do
|
|
|
|
allow(controller).to receive(:find_user).and_return(user)
|
|
|
|
post :create, params: { user: { login: user.username, password: user.password } }
|
|
|
|
|
|
|
|
expect(response).to be_successful
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe Profiles::TwoFactorAuthsController, '(JavaScript fixtures)', type: :controller do
|
|
|
|
render_views
|
|
|
|
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
allow_next_instance_of(Profiles::TwoFactorAuthsController) do |instance|
|
|
|
|
allow(instance).to receive(:build_qr_code).and_return('qrcode:blackandwhitesquares')
|
|
|
|
end
|
2023-05-27 22:25:52 +05:30
|
|
|
stub_feature_flags(webauthn_without_totp: false)
|
2020-11-24 15:15:51 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'webauthn/register.html' do
|
|
|
|
get :show
|
|
|
|
|
|
|
|
expect(response).to be_successful
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|