# frozen_string_literal: true require 'spec_helper' RSpec.describe 'profiles/keys/_key.html.haml' do let_it_be(:user) { create(:user) } before do allow(view).to receive(:key).and_return(key) allow(view).to receive(:is_admin).and_return(false) end context 'when the key partial is used' do let_it_be(:key) do create(:personal_key, user: user, last_used_at: 7.days.ago, expires_at: 2.days.from_now) end it 'displays the correct values', :aggregate_failures do render expect(rendered).to have_text(key.title) expect(rendered).to have_css('[data-testid="key-icon"]') expect(rendered).to have_text(key.fingerprint) expect(rendered).to have_text(l(key.last_used_at, format: "%b %d, %Y")) expect(rendered).to have_text(l(key.created_at, format: "%b %d, %Y")) expect(rendered).to have_text(key.expires_at.to_date) expect(response).to render_template(partial: 'shared/ssh_keys/_key_delete') end context 'displays the usage type' do where(:usage_type, :usage_type_text) do [ [:auth, 'Authentication'], [:auth_and_signing, 'Authentication & Signing'], [:signing, 'Signing'] ] end with_them do let(:key) { create(:key, user: user, usage_type: usage_type) } it 'renders usage type text' do render expect(rendered).to have_text(usage_type_text) end end end context 'when the key has not been used' do let_it_be(:key) do create(:personal_key, user: user, last_used_at: nil) end it 'renders "Never" for last used' do render expect(rendered).to have_text('Last used: Never') end end context 'when the key does not have an expiration date' do let_it_be(:key) do create(:personal_key, user: user, expires_at: nil) end it 'renders "Never" for expires' do render expect(rendered).to have_text('Expires: Never') end end context 'when the key has expired' do let_it_be(:key) { create(:personal_key, :expired, user: user) } it 'renders "Expired:" as the expiration date label' do render expect(rendered).to have_text('Expired:') end end context 'when the key is not deletable' do # Turns out key.can_delete? is only false for LDAP keys # but LDAP keys don't exist outside EE before do allow(key).to receive(:can_delete?).and_return(false) end it 'does not render the partial' do render expect(response).not_to render_template(partial: 'shared/ssh_keys/_key_delete') end end context 'icon tooltip' do using RSpec::Parameterized::TableSyntax where(:valid, :expiry, :result) do false | 2.days.from_now | 'Key type is forbidden. Must be DSA, ECDSA, ED25519, ECDSA_SK, or ED25519_SK' true | 2.days.from_now | '' end with_them do let_it_be(:key) do create(:personal_key, user: user) end it 'renders the correct icon', :aggregate_failures do unless valid stub_application_setting(rsa_key_restriction: ApplicationSetting::FORBIDDEN_KEY_VALUE) end key.expires_at = expiry render if result.empty? expect(rendered).to have_css('[data-testid="key-icon"]') else expect(rendered).to have_css('[data-testid="warning-solid-icon"]') expect(rendered).to have_selector("span.has-tooltip[title='#{result}']") end end end end end end