12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- RSpec.shared_examples 'security keys setup', authenticated_as: :authenticate do
- let(:password_check) { true }
- let(:current_user) { agent }
- def authenticate
- Setting.set('two_factor_authentication_method_security_keys', true)
- current_user
- end
- before do
- skip('Mocking of Web Authentication API is currently supported only in Chrome.') if Capybara.current_driver != :zammad_chrome
- end
- it 'sets up security keys method' do
- setup_security_keys_method(user: current_user, password_check: password_check)
- end
- end
- def mock_security_key
- options = Selenium::WebDriver::VirtualAuthenticatorOptions.new(protocol: :u2f, transport: :usb, resident_key: false,
- user_consenting: true, user_verification: true,
- user_verified: true)
- page.driver.browser.add_virtual_authenticator(options)
- end
- def setup_security_keys_method(user:, password_check:)
- in_modal do
- if password_check
- expect(page).to have_text('Set up two-factor authentication: Confirm Password')
- fill_in 'Password', with: user.password_plain
- click_on 'Next'
- end
- expect(page).to have_text('Set up two-factor authentication: Security Keys')
- click_on 'Set Up'
- expect(page).to have_text('Set up two-factor authentication: Security Key')
- fill_in 'Name for this security key', with: Faker::Lorem.unique.word
- mock_security_key
- click_on 'Next'
- expect(page).to have_text('Set up two-factor authentication: Save Codes')
- click_on "OK, I've saved my recovery codes"
- end
- expect(page).to have_no_css('.modal')
- expect(user.reload.two_factor_configured?).to be(true)
- end
|