mirror of
https://github.com/glitch-soc/mastodon.git
synced 2025-02-23 11:03:50 -05:00
Convert settings/two_factor_authentication/recovery_codes
spec controller->system/request (#33912)
This commit is contained in:
parent
c433fd01a6
commit
62dc303d3c
@ -1,30 +0,0 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe Settings::TwoFactorAuthentication::RecoveryCodesController do
|
||||
render_views
|
||||
|
||||
describe 'POST #create' do
|
||||
it 'updates the codes and shows them on a view when signed in' do
|
||||
user = Fabricate(:user)
|
||||
otp_backup_codes = user.generate_otp_backup_codes!
|
||||
allow(user).to receive(:generate_otp_backup_codes!).and_return(otp_backup_codes)
|
||||
allow(controller).to receive(:current_user).and_return(user)
|
||||
|
||||
sign_in user, scope: :user
|
||||
post :create, session: { challenge_passed_at: Time.now.utc }
|
||||
|
||||
expect(flash[:notice]).to eq 'Recovery codes successfully regenerated'
|
||||
expect(response).to have_http_status(200)
|
||||
expect(response).to render_template(:index)
|
||||
expect(response.body)
|
||||
.to include(*otp_backup_codes)
|
||||
end
|
||||
|
||||
it 'redirects when not signed in' do
|
||||
post :create
|
||||
expect(response).to redirect_to '/auth/sign_in'
|
||||
end
|
||||
end
|
||||
end
|
@ -0,0 +1,16 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe 'Settings TwoFactorAuthentication RecoveryCodes' do
|
||||
describe 'POST /settings/two_factor_authentication/recovery_codes' do
|
||||
context 'when signed out' do
|
||||
it 'redirects to sign in page' do
|
||||
post settings_two_factor_authentication_recovery_codes_path
|
||||
|
||||
expect(response)
|
||||
.to redirect_to(new_user_session_path)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
@ -0,0 +1,37 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe 'Settings TwoFactorAuthentication RecoveryCodes' do
|
||||
describe 'Generating recovery codes' do
|
||||
let(:user) { Fabricate :user, otp_required_for_login: true }
|
||||
let(:backup_code) { +'147e7284c95bd260b91ed17820860019' }
|
||||
|
||||
before do
|
||||
stub_code_generator
|
||||
sign_in(user)
|
||||
end
|
||||
|
||||
it 'updates the codes and includes them in the view' do
|
||||
# Attempt to generate codes
|
||||
visit settings_two_factor_authentication_methods_path
|
||||
click_on I18n.t('two_factor_authentication.generate_recovery_codes')
|
||||
|
||||
# Fill in challenge password
|
||||
fill_in 'form_challenge_current_password', with: user.password
|
||||
|
||||
expect { click_on I18n.t('challenge.confirm') }
|
||||
.to(change { user.reload.otp_backup_codes })
|
||||
|
||||
expect(page)
|
||||
.to have_content(I18n.t('two_factor_authentication.recovery_codes_regenerated'))
|
||||
.and have_title(I18n.t('settings.two_factor_authentication'))
|
||||
.and have_css('ol.recovery-codes')
|
||||
.and have_content(backup_code)
|
||||
end
|
||||
|
||||
def stub_code_generator
|
||||
allow(SecureRandom).to receive(:hex).and_return(backup_code)
|
||||
end
|
||||
end
|
||||
end
|
Loading…
x
Reference in New Issue
Block a user