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

98 lines
2.9 KiB
Ruby
Raw Normal View History

2015-03-12 17:51:41 -04:00
require 'spec_helper'
describe GroupsHelper do
2017-06-20 17:35:55 -04:00
include ApplicationHelper
2015-03-12 17:51:41 -04:00
describe 'group_icon' do
avatar_file_path = File.join(Rails.root, 'spec', 'fixtures', 'banana_sample.gif')
2015-03-12 17:51:41 -04:00
it 'returns an url for the avatar' do
2015-03-12 17:51:41 -04:00
group = create(:group)
group.avatar = fixture_file_upload(avatar_file_path)
2015-03-12 17:51:41 -04:00
group.save!
2017-06-21 09:48:12 -04:00
expect(group_icon(group.path).to_s)
2017-07-17 09:46:59 -04:00
.to match("/uploads/-/system/group/avatar/#{group.id}/banana_sample.gif")
2015-03-12 17:51:41 -04:00
end
it 'gives default avatar_icon when no avatar is present' do
2015-03-12 17:51:41 -04:00
group = create(:group)
group.save!
expect(group_icon(group.path)).to match('group_avatar.png')
end
end
describe 'group_lfs_status' do
let(:group) { create(:group) }
let!(:project) { create(:project, namespace_id: group.id) }
before do
allow(Gitlab.config.lfs).to receive(:enabled).and_return(true)
end
context 'only one project in group' do
before do
group.update_attribute(:lfs_enabled, true)
end
it 'returns all projects as enabled' do
expect(group_lfs_status(group)).to include('Enabled for all projects')
end
it 'returns all projects as disabled' do
project.update_attribute(:lfs_enabled, false)
expect(group_lfs_status(group)).to include('Enabled for 0 out of 1 project')
end
end
context 'more than one project in group' do
before do
create(:project, namespace_id: group.id)
end
context 'LFS enabled in group' do
before do
group.update_attribute(:lfs_enabled, true)
end
it 'returns both projects as enabled' do
expect(group_lfs_status(group)).to include('Enabled for all projects')
end
it 'returns only one as enabled' do
project.update_attribute(:lfs_enabled, false)
expect(group_lfs_status(group)).to include('Enabled for 1 out of 2 projects')
end
end
context 'LFS disabled in group' do
before do
group.update_attribute(:lfs_enabled, false)
end
it 'returns both projects as disabled' do
expect(group_lfs_status(group)).to include('Disabled for all projects')
end
it 'returns only one as disabled' do
project.update_attribute(:lfs_enabled, true)
expect(group_lfs_status(group)).to include('Disabled for 1 out of 2 projects')
end
end
end
end
2017-06-20 17:35:55 -04:00
describe 'group_title', :nested_groups do
2017-06-20 17:35:55 -04:00
let(:group) { create(:group) }
let(:nested_group) { create(:group, parent: group) }
let(:deep_nested_group) { create(:group, parent: nested_group) }
let!(:very_deep_nested_group) { create(:group, parent: deep_nested_group) }
it 'outputs the groups in the correct order' do
2017-06-30 12:52:11 -04:00
expect(helper.group_title(very_deep_nested_group)).to match(/>#{group.name}<\/a>.*>#{nested_group.name}<\/a>.*>#{deep_nested_group.name}<\/a>/)
2017-06-20 17:35:55 -04:00
end
end
2015-03-12 17:51:41 -04:00
end