9be16e1f49
- Adds UI to configure in group and project settings - Removes notification configuration for users when disabled at group or project level
187 lines
4.8 KiB
Ruby
187 lines
4.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
describe 'Group show page' do
|
|
let(:group) { create(:group) }
|
|
let(:path) { group_path(group) }
|
|
|
|
context 'when signed in' do
|
|
let(:user) do
|
|
create(:group_member, :developer, user: create(:user), group: group ).user
|
|
end
|
|
|
|
before do
|
|
sign_in(user)
|
|
visit path
|
|
end
|
|
|
|
it_behaves_like "an autodiscoverable RSS feed with current_user's feed token"
|
|
|
|
context 'when group does not exist' do
|
|
let(:path) { group_path('not-exist') }
|
|
|
|
it { expect(status_code).to eq(404) }
|
|
end
|
|
end
|
|
|
|
context 'when signed out' do
|
|
describe 'RSS' do
|
|
before do
|
|
visit path
|
|
end
|
|
|
|
it_behaves_like "an autodiscoverable RSS feed without a feed token"
|
|
end
|
|
|
|
context 'when group has a public project', :js do
|
|
let!(:project) { create(:project, :public, namespace: group) }
|
|
|
|
it 'renders public project' do
|
|
visit path
|
|
|
|
expect(page).to have_link group.name
|
|
expect(page).to have_link project.name
|
|
end
|
|
end
|
|
|
|
context 'when group has a private project', :js do
|
|
let!(:project) { create(:project, :private, namespace: group) }
|
|
|
|
it 'does not render private project' do
|
|
visit path
|
|
|
|
expect(page).to have_link group.name
|
|
expect(page).not_to have_link project.name
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'subgroup support' do
|
|
let(:restricted_group) do
|
|
create(:group, subgroup_creation_level: ::Gitlab::Access::OWNER_SUBGROUP_ACCESS)
|
|
end
|
|
|
|
let(:relaxed_group) do
|
|
create(:group, subgroup_creation_level: ::Gitlab::Access::MAINTAINER_SUBGROUP_ACCESS)
|
|
end
|
|
|
|
let(:owner) { create(:user) }
|
|
let(:maintainer) { create(:user) }
|
|
|
|
context 'for owners' do
|
|
let(:path) { group_path(restricted_group) }
|
|
|
|
before do
|
|
restricted_group.add_owner(owner)
|
|
sign_in(owner)
|
|
end
|
|
|
|
context 'when subgroups are supported' do
|
|
it 'allows creating subgroups' do
|
|
visit path
|
|
|
|
expect(page)
|
|
.to have_css("li[data-text='New subgroup']", visible: false)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'for maintainers' do
|
|
before do
|
|
sign_in(maintainer)
|
|
end
|
|
|
|
context 'when subgroups are supported' do
|
|
context 'when subgroup_creation_level is set to maintainers' do
|
|
before do
|
|
relaxed_group.add_maintainer(maintainer)
|
|
end
|
|
|
|
it 'allows creating subgroups' do
|
|
path = group_path(relaxed_group)
|
|
visit path
|
|
|
|
expect(page)
|
|
.to have_css("li[data-text='New subgroup']", visible: false)
|
|
end
|
|
end
|
|
|
|
context 'when subgroup_creation_level is set to owners' do
|
|
before do
|
|
restricted_group.add_maintainer(maintainer)
|
|
end
|
|
|
|
it 'does not allow creating subgroups' do
|
|
path = group_path(restricted_group)
|
|
visit path
|
|
|
|
expect(page)
|
|
.not_to have_selector("li[data-text='New subgroup']",
|
|
visible: false)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'group has a project with emoji in description', :js do
|
|
let(:user) { create(:user) }
|
|
let!(:project) { create(:project, description: ':smile:', namespace: group) }
|
|
|
|
before do
|
|
group.add_owner(user)
|
|
sign_in(user)
|
|
visit path
|
|
end
|
|
|
|
it 'shows the project info' do
|
|
expect(page).to have_content(project.title)
|
|
expect(page).to have_emoji('smile')
|
|
end
|
|
end
|
|
|
|
context 'where group has projects' do
|
|
let(:user) { create(:user) }
|
|
|
|
before do
|
|
group.add_owner(user)
|
|
sign_in(user)
|
|
end
|
|
|
|
it 'allows users to sorts projects by most stars', :js do
|
|
project1 = create(:project, namespace: group, star_count: 2)
|
|
project2 = create(:project, namespace: group, star_count: 3)
|
|
project3 = create(:project, namespace: group, star_count: 0)
|
|
|
|
visit group_path(group, sort: :stars_desc)
|
|
|
|
expect(find('.group-row:nth-child(1) .namespace-title > a')).to have_content(project2.title)
|
|
expect(find('.group-row:nth-child(2) .namespace-title > a')).to have_content(project1.title)
|
|
expect(find('.group-row:nth-child(3) .namespace-title > a')).to have_content(project3.title)
|
|
end
|
|
end
|
|
|
|
context 'notification button', :js do
|
|
let(:maintainer) { create(:user) }
|
|
let!(:project) { create(:project, namespace: group) }
|
|
|
|
before do
|
|
group.add_maintainer(maintainer)
|
|
sign_in(maintainer)
|
|
end
|
|
|
|
it 'is enabled by default' do
|
|
visit path
|
|
|
|
expect(page).to have_selector('.notifications-btn:not(.disabled)', visible: true)
|
|
end
|
|
|
|
it 'is disabled if emails are disabled' do
|
|
group.update_attribute(:emails_disabled, true)
|
|
visit path
|
|
|
|
expect(page).to have_selector('.notifications-btn.disabled', visible: true)
|
|
end
|
|
end
|
|
end
|