117 lines
3.3 KiB
Ruby
117 lines
3.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "spec_helper"
|
|
|
|
RSpec.describe InviteMembersHelper do
|
|
include Devise::Test::ControllerHelpers
|
|
|
|
let_it_be(:project) { create(:project) }
|
|
let_it_be(:developer) { create(:user, developer_projects: [project]) }
|
|
|
|
let(:owner) { project.owner }
|
|
|
|
before do
|
|
helper.extend(Gitlab::Experimentation::ControllerConcern)
|
|
end
|
|
|
|
context 'with project' do
|
|
before do
|
|
allow(helper).to receive(:current_user) { owner }
|
|
assign(:project, project)
|
|
end
|
|
|
|
describe "#can_invite_members_for_project?" do
|
|
context 'when the user can_manage_project_members' do
|
|
before do
|
|
allow(helper).to receive(:can_manage_project_members?).and_return(true)
|
|
end
|
|
|
|
it 'returns true' do
|
|
expect(helper.can_invite_members_for_project?(project)).to eq true
|
|
expect(helper).to have_received(:can_manage_project_members?)
|
|
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
|
|
expect(helper).not_to have_received(:can_manage_project_members?)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when the user can not manage project members' do
|
|
before do
|
|
expect(helper).to receive(:can_manage_project_members?).and_return(false)
|
|
end
|
|
|
|
it 'returns false' do
|
|
expect(helper.can_invite_members_for_project?(project)).to eq false
|
|
end
|
|
end
|
|
end
|
|
|
|
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
|
|
end
|
|
|
|
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
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with group' do
|
|
let_it_be(:group) { create(:group) }
|
|
|
|
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
|
|
|
|
it 'returns false' do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_empty_group_version_a) { false }
|
|
|
|
expect(helper.invite_group_members?(group)).to eq false
|
|
end
|
|
|
|
it 'returns true' do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_empty_group_version_a) { true }
|
|
|
|
expect(helper.invite_group_members?(group)).to eq true
|
|
end
|
|
end
|
|
|
|
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 }
|
|
|
|
expect(helper.invite_group_members?(group)).to eq false
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|