debian-mirror-gitlab/spec/helpers/invite_members_helper_spec.rb

118 lines
3.3 KiB
Ruby
Raw Normal View History

2021-01-03 14:25:43 +05:30
# frozen_string_literal: true
require "spec_helper"
RSpec.describe InviteMembersHelper do
2021-06-08 01:23:25 +05:30
include Devise::Test::ControllerHelpers
2021-01-03 14:25:43 +05:30
let_it_be(:project) { create(:project) }
let_it_be(:developer) { create(:user, developer_projects: [project]) }
2021-04-29 21:17:54 +05:30
2021-01-03 14:25:43 +05:30
let(:owner) { project.owner }
2021-03-11 19:13:27 +05:30
before do
helper.extend(Gitlab::Experimentation::ControllerConcern)
end
2021-01-29 00:20:46 +05:30
context 'with project' do
before do
2021-06-08 01:23:25 +05:30
allow(helper).to receive(:current_user) { owner }
2021-01-29 00:20:46 +05:30
assign(:project, project)
end
2021-01-03 14:25:43 +05:30
2021-03-11 19:13:27 +05:30
describe "#can_invite_members_for_project?" do
2021-06-08 01:23:25 +05:30
context 'when the user can_manage_project_members' do
2021-03-11 19:13:27 +05:30
before do
2021-06-08 01:23:25 +05:30
allow(helper).to receive(:can_manage_project_members?).and_return(true)
2021-03-11 19:13:27 +05:30
end
it 'returns true' do
expect(helper.can_invite_members_for_project?(project)).to eq true
2021-06-08 01:23:25 +05:30
expect(helper).to have_received(:can_manage_project_members?)
2021-03-11 19:13:27 +05:30
end
context 'when feature flag is disabled' do
before do
stub_feature_flags(invite_members_group_modal: false)
end
it 'returns false' do
expect(helper.can_invite_members_for_project?(project)).to eq false
2021-06-08 01:23:25 +05:30
expect(helper).not_to have_received(:can_manage_project_members?)
2021-03-11 19:13:27 +05:30
end
end
end
2021-06-08 01:23:25 +05:30
context 'when the user can not manage project members' do
2021-03-11 19:13:27 +05:30
before do
2021-06-08 01:23:25 +05:30
expect(helper).to receive(:can_manage_project_members?).and_return(false)
2021-03-11 19:13:27 +05:30
end
it 'returns false' do
expect(helper.can_invite_members_for_project?(project)).to eq false
end
end
end
2021-01-29 00:20:46 +05:30
describe "#directly_invite_members?" do
context 'when the user is an owner' do
before do
allow(helper).to receive(:current_user) { owner }
end
it 'returns true' do
expect(helper.directly_invite_members?).to eq true
end
2021-01-03 14:25:43 +05:30
end
2021-01-29 00:20:46 +05:30
context 'when the user is a developer' do
before do
allow(helper).to receive(:current_user) { developer }
end
it 'returns false' do
expect(helper.directly_invite_members?).to eq false
end
2021-01-03 14:25:43 +05:30
end
end
end
2021-01-29 00:20:46 +05:30
context 'with group' do
let_it_be(:group) { create(:group) }
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
describe "#invite_group_members?" do
context 'when the user is an owner' do
before do
group.add_owner(owner)
allow(helper).to receive(:current_user) { owner }
end
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
it 'returns false' do
allow(helper).to receive(:experiment_enabled?).with(:invite_members_empty_group_version_a) { false }
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
expect(helper.invite_group_members?(group)).to eq false
end
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
it 'returns true' do
allow(helper).to receive(:experiment_enabled?).with(:invite_members_empty_group_version_a) { true }
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
expect(helper.invite_group_members?(group)).to eq true
end
2021-01-03 14:25:43 +05:30
end
2021-01-29 00:20:46 +05:30
context 'when the user is a developer' do
before do
group.add_developer(developer)
allow(helper).to receive(:current_user) { developer }
end
it 'returns false' do
allow(helper).to receive(:experiment_enabled?).with(:invite_members_empty_group_version_a) { true }
2021-01-03 14:25:43 +05:30
2021-01-29 00:20:46 +05:30
expect(helper.invite_group_members?(group)).to eq false
end
2021-01-03 14:25:43 +05:30
end
end
end
end