gitlab-org--gitlab-foss/spec/helpers/icons_helper_spec.rb

269 lines
8.8 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe IconsHelper do
let(:icons_path) { ActionController::Base.helpers.image_path("icons.svg") }
describe 'icon' do
it 'returns aria-hidden by default' do
star = icon('star')
expect(star['aria-hidden']).to eq 'aria-hidden'
end
it 'does not return aria-hidden if aria-label is set' do
up = icon('up', 'aria-label' => 'up')
expect(up['aria-hidden']).to be_nil
expect(up['aria-label']).to eq 'aria-label'
end
end
describe 'sprite_icon_path' do
it 'returns relative path' do
expect(sprite_icon_path).to eq(icons_path)
end
it 'only calls image_path once when called multiple times' do
expect(ActionController::Base.helpers).to receive(:image_path).once.and_call_original
2.times { sprite_icon_path }
end
context 'when an asset_host is set in the config it will return an absolute local URL' do
let(:asset_host) { 'http://assets' }
before do
allow(ActionController::Base).to receive(:asset_host).and_return(asset_host)
end
it 'returns an absolute URL on that asset host' do
expect(sprite_icon_path)
.to eq ActionController::Base.helpers.image_path("icons.svg", host: Gitlab.config.gitlab.url)
end
end
end
describe 'sprite_icon' do
icon_name = 'clock'
it 'returns svg icon html with DEFAULT_ICON_SIZE' do
expect(sprite_icon(icon_name).to_s)
.to eq "<svg class=\"s#{IconsHelper::DEFAULT_ICON_SIZE}\" data-testid=\"#{icon_name}-icon\"><use xlink:href=\"#{icons_path}##{icon_name}\"></use></svg>"
end
it 'returns svg icon html without size class' do
expect(sprite_icon(icon_name, size: nil).to_s)
.to eq "<svg data-testid=\"#{icon_name}-icon\"><use xlink:href=\"#{icons_path}##{icon_name}\"></use></svg>"
end
it 'returns svg icon html + size classes' do
expect(sprite_icon(icon_name, size: 72).to_s)
.to eq "<svg class=\"s72\" data-testid=\"#{icon_name}-icon\"><use xlink:href=\"#{icons_path}##{icon_name}\"></use></svg>"
end
it 'returns svg icon html + size classes + additional class' do
expect(sprite_icon(icon_name, size: 72, css_class: 'icon-danger').to_s)
.to eq "<svg class=\"s72 icon-danger\" data-testid=\"#{icon_name}-icon\"><use xlink:href=\"#{icons_path}##{icon_name}\"></use></svg>"
end
describe 'non existing icon' do
non_existing = 'non_existing_icon_sprite'
it 'raises in development mode' do
stub_rails_env('development')
expect { sprite_icon(non_existing) }.to raise_error(ArgumentError, /is not a known icon/)
end
it 'raises in test mode' do
stub_rails_env('test')
expect { sprite_icon(non_existing) }.to raise_error(ArgumentError, /is not a known icon/)
end
it 'does not raise in production mode' do
stub_rails_env('production')
expect_file_not_to_read(Rails.root.join('node_modules/@gitlab/svgs/dist/icons.json'))
expect { sprite_icon(non_existing) }.not_to raise_error
end
end
end
describe 'audit icon' do
it 'returns right icon name for standard auth' do
icon_name = 'standard'
expect(audit_icon(icon_name).to_s)
.to eq sprite_icon('key')
end
it 'returns right icon name for two-factor auth' do
icon_name = 'two-factor'
expect(audit_icon(icon_name).to_s)
.to eq sprite_icon('key')
end
it 'returns right icon name for google_oauth2 auth' do
icon_name = 'google_oauth2'
expect(audit_icon(icon_name).to_s)
.to eq sprite_icon('google')
end
end
describe 'file_type_icon_class' do
it 'returns folder-o class' do
expect(file_type_icon_class('folder', 0, 'folder_name')).to eq 'folder-o'
end
it 'returns share class' do
expect(file_type_icon_class('file', '120000', 'link')).to eq 'share'
end
it 'returns document class with .pdf' do
expect(file_type_icon_class('file', 0, 'filename.pdf')).to eq 'document'
end
it 'returns doc-image class with .jpg' do
expect(file_type_icon_class('file', 0, 'filename.jpg')).to eq 'doc-image'
end
it 'returns doc-image class with .JPG' do
expect(file_type_icon_class('file', 0, 'filename.JPG')).to eq 'doc-image'
end
it 'returns doc-image class with .png' do
expect(file_type_icon_class('file', 0, 'filename.png')).to eq 'doc-image'
end
it 'returns doc-image class with .apng' do
expect(file_type_icon_class('file', 0, 'filename.apng')).to eq 'doc-image'
end
it 'returns doc-image class with .webp' do
expect(file_type_icon_class('file', 0, 'filename.webp')).to eq 'doc-image'
end
it 'returns doc-compressed class with .tar' do
expect(file_type_icon_class('file', 0, 'filename.tar')).to eq 'doc-compressed'
end
it 'returns doc-compressed class with .TAR' do
expect(file_type_icon_class('file', 0, 'filename.TAR')).to eq 'doc-compressed'
end
it 'returns doc-compressed class with .tar.gz' do
expect(file_type_icon_class('file', 0, 'filename.tar.gz')).to eq 'doc-compressed'
end
it 'returns volume-up class with .mp3' do
expect(file_type_icon_class('file', 0, 'filename.mp3')).to eq 'volume-up'
end
it 'returns volume-up class with .MP3' do
expect(file_type_icon_class('file', 0, 'filename.MP3')).to eq 'volume-up'
end
it 'returns volume-up class with .m4a' do
expect(file_type_icon_class('file', 0, 'filename.m4a')).to eq 'volume-up'
end
it 'returns volume-up class with .wav' do
expect(file_type_icon_class('file', 0, 'filename.wav')).to eq 'volume-up'
end
it 'returns live-preview class with .avi' do
expect(file_type_icon_class('file', 0, 'filename.avi')).to eq 'live-preview'
end
it 'returns live-preview class with .AVI' do
expect(file_type_icon_class('file', 0, 'filename.AVI')).to eq 'live-preview'
end
it 'returns live-preview class with .mp4' do
expect(file_type_icon_class('file', 0, 'filename.mp4')).to eq 'live-preview'
end
it 'returns doc-text class with .odt' do
expect(file_type_icon_class('file', 0, 'filename.odt')).to eq 'doc-text'
end
it 'returns doc-text class with .doc' do
expect(file_type_icon_class('file', 0, 'filename.doc')).to eq 'doc-text'
end
it 'returns doc-text class with .DOC' do
expect(file_type_icon_class('file', 0, 'filename.DOC')).to eq 'doc-text'
end
it 'returns doc-text class with .docx' do
expect(file_type_icon_class('file', 0, 'filename.docx')).to eq 'doc-text'
end
it 'returns document class with .xls' do
expect(file_type_icon_class('file', 0, 'filename.xls')).to eq 'document'
end
it 'returns document class with .XLS' do
expect(file_type_icon_class('file', 0, 'filename.XLS')).to eq 'document'
end
it 'returns document class with .xlsx' do
expect(file_type_icon_class('file', 0, 'filename.xlsx')).to eq 'document'
end
it 'returns doc-chart class with .odp' do
expect(file_type_icon_class('file', 0, 'filename.odp')).to eq 'doc-chart'
end
it 'returns doc-chart class with .ppt' do
expect(file_type_icon_class('file', 0, 'filename.ppt')).to eq 'doc-chart'
end
it 'returns doc-chart class with .PPT' do
expect(file_type_icon_class('file', 0, 'filename.PPT')).to eq 'doc-chart'
end
it 'returns doc-chart class with .pptx' do
expect(file_type_icon_class('file', 0, 'filename.pptx')).to eq 'doc-chart'
end
it 'returns doc-text class with .unknow' do
expect(file_type_icon_class('file', 0, 'filename.unknow')).to eq 'doc-text'
end
it 'returns doc-text class with no extension' do
expect(file_type_icon_class('file', 0, 'CHANGELOG')).to eq 'doc-text'
end
end
describe '#external_snippet_icon' do
it 'returns external snippet icon' do
expect(external_snippet_icon('download').to_s)
.to eq("<span class=\"gl-snippet-icon gl-snippet-icon-download\"></span>")
end
end
describe 'loading_icon' do
it 'returns span with gl-spinner class and default configuration' do
expect(loading_icon.to_s)
.to eq '<span class="gl-spinner gl-spinner-orange gl-spinner-sm" aria-label="Loading"></span>'
end
context 'when css_class is provided' do
it 'appends css_class to gl-spinner element' do
expect(loading_icon(css_class: 'gl-mr-2').to_s)
.to eq '<span class="gl-spinner gl-spinner-orange gl-spinner-sm gl-mr-2" aria-label="Loading"></span>'
end
end
context 'when container is true' do
it 'creates a container that has the gl-spinner-container class selector' do
expect(loading_icon(container: true).to_s)
.to eq '<div class="gl-spinner-container"><span class="gl-spinner gl-spinner-orange gl-spinner-sm" aria-label="Loading"></span></div>'
end
end
end
end