12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- describe Controllers::User::TwoFactorsControllerPolicy do
- subject { described_class.new(user, record) }
- let(:record_class) { User::TwoFactorsController }
- let(:record) do
- rec = record_class.new
- rec.params = params
- rec
- end
- let(:twofactoree) { create(:agent) }
- describe 'endpoints for current user' do
- let(:user) { twofactoree }
- let(:params) { {} }
- let(:permitted_actions) do
- %i[two_factor_verify_configuration two_factor_authentication_method_initiate_configuration two_factor_default_authentication_method two_factor_authentication_method_configuration two_factor_authentication_remove_credentials]
- end
- it { is_expected.to permit_actions(permitted_actions) }
- end
- describe 'endpoints allowing to manage other users' do
- let(:params) { { id: twofactoree.id } }
- let(:actions) do
- %i[two_factor_enabled_authentication_methods two_factor_remove_authentication_method two_factor_remove_all_authentication_methods]
- end
- context 'with an admin' do
- let(:user) { create(:admin) }
- it { is_expected.to permit_actions(actions) }
- end
- context 'with a different user' do
- let(:user) { create(:agent) }
- it { is_expected.to forbid_actions(actions) }
- end
- context 'with the user' do
- let(:user) { twofactoree }
- it { is_expected.to permit_actions(actions) }
- context 'when user does not have user_preferences.two_factor_authentication permission' do
- before do
- user.roles.each { |role| role.permission_revoke('user_preferences') }
- end
- it { is_expected.to forbid_actions(actions) }
- end
- end
- end
- end
|