about summary refs log tree commit diff
path: root/spec/controllers/settings/two_factor_authentication/recovery_codes_controller_spec.rb
blob: 630cec428e7264298987568fa30f72a7b98711d9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# frozen_string_literal: true

require 'rails_helper'

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!
      expect_any_instance_of(User).to receive(:generate_otp_backup_codes!) do |value|
        expect(value).to eq user
        otp_backup_codes
      end

      sign_in user, scope: :user
      post :create, session: { challenge_passed_at: Time.now.utc }

      expect(assigns(:recovery_codes)).to eq otp_backup_codes
      expect(flash[:notice]).to eq 'Recovery codes successfully regenerated'
      expect(response).to have_http_status(200)
      expect(response).to render_template(:index)
    end

    it 'redirects when not signed in' do
      post :create
      expect(response).to redirect_to '/auth/sign_in'
    end
  end
end