178 lines
5 KiB
Ruby
178 lines
5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'profiles/keys/_key.html.haml', feature_category: :authentication_and_authorization 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.created_at, format: "%b %d, %Y"))
|
|
expect(rendered).to have_text(key.expires_at.to_date)
|
|
expect(rendered).to have_button('Remove')
|
|
end
|
|
|
|
context 'when disable_ssh_key_used_tracking is enabled' do
|
|
before do
|
|
stub_feature_flags(disable_ssh_key_used_tracking: true)
|
|
end
|
|
|
|
it 'renders "Unavailable" for last used' do
|
|
render
|
|
|
|
expect(rendered).to have_text('Last used: Unavailable')
|
|
end
|
|
end
|
|
|
|
context 'when disable_ssh_key_used_tracking is disabled' do
|
|
before do
|
|
stub_feature_flags(disable_ssh_key_used_tracking: false)
|
|
end
|
|
|
|
it 'displays the correct last used date' do
|
|
render
|
|
|
|
expect(rendered).to have_text(l(key.last_used_at, format: "%b %d, %Y"))
|
|
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
|
|
end
|
|
|
|
context 'displays the usage type' do
|
|
where(:usage_type, :usage_type_text, :displayed_buttons, :hidden_buttons, :revoke_ssh_signatures_ff) do
|
|
[
|
|
[:auth, 'Authentication', ['Remove'], ['Revoke'], true],
|
|
[:auth_and_signing, 'Authentication & Signing', %w[Remove Revoke], [], true],
|
|
[:signing, 'Signing', %w[Remove Revoke], [], true],
|
|
[:auth, 'Authentication', ['Remove'], ['Revoke'], false],
|
|
[:auth_and_signing, 'Authentication & Signing', %w[Remove], ['Revoke'], false],
|
|
[:signing, 'Signing', %w[Remove], ['Revoke'], false]
|
|
]
|
|
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
|
|
|
|
it 'renders remove/revoke buttons', :aggregate_failures do
|
|
stub_feature_flags(revoke_ssh_signatures: revoke_ssh_signatures_ff)
|
|
|
|
render
|
|
|
|
displayed_buttons.each do |button|
|
|
expect(rendered).to have_text(button)
|
|
end
|
|
|
|
hidden_buttons.each do |button|
|
|
expect(rendered).not_to have_text(button)
|
|
end
|
|
end
|
|
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 have_text('Remove')
|
|
expect(response).not_to have_text('Revoke')
|
|
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
|