diff options
Diffstat (limited to 'spec/views/profiles/keys/_key.html.haml_spec.rb')
-rw-r--r-- | spec/views/profiles/keys/_key.html.haml_spec.rb | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/spec/views/profiles/keys/_key.html.haml_spec.rb b/spec/views/profiles/keys/_key.html.haml_spec.rb new file mode 100644 index 00000000000..bb101198ac3 --- /dev/null +++ b/spec/views/profiles/keys/_key.html.haml_spec.rb @@ -0,0 +1,123 @@ +# 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 '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) do + create(:personal_key, + user: user, + expires_at: 2.days.ago) + end + + 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, or ED25519' + false | 2.days.ago | 'Key type is forbidden. Must be DSA, ECDSA, or ED25519' + true | 2.days.ago | 'Key usable beyond expiration date.' + 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 |