271 lines
7.9 KiB
Ruby
271 lines
7.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "spec_helper"
|
|
|
|
RSpec.describe InviteMembersHelper do
|
|
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
|
|
|
|
describe '#show_invite_members_track_event' do
|
|
it 'shows values when can directly invite members' do
|
|
allow(helper).to receive(:directly_invite_members?).and_return(true)
|
|
|
|
expect(helper.show_invite_members_track_event).to eq 'show_invite_members'
|
|
end
|
|
|
|
it 'shows values when can indirectly invite members' do
|
|
allow(helper).to receive(:directly_invite_members?).and_return(false)
|
|
allow(helper).to receive(:indirectly_invite_members?).and_return(true)
|
|
|
|
expect(helper.show_invite_members_track_event).to eq 'show_invite_members_version_b'
|
|
end
|
|
end
|
|
|
|
context 'with project' do
|
|
before do
|
|
assign(:project, project)
|
|
end
|
|
|
|
describe "#can_invite_members_for_project?" do
|
|
context 'when the user can_import_members' do
|
|
before do
|
|
allow(helper).to receive(:can_import_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_import_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_import_members?)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when the user can not invite members' do
|
|
before do
|
|
expect(helper).to receive(:can_import_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
|
|
|
|
describe "#indirectly_invite_members?" do
|
|
context 'when a user is a developer' do
|
|
before do
|
|
allow(helper).to receive(:current_user) { developer }
|
|
end
|
|
|
|
it 'returns false' do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_version_b) { false }
|
|
|
|
expect(helper.indirectly_invite_members?).to eq false
|
|
end
|
|
|
|
it 'returns true' do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_version_b) { true }
|
|
|
|
expect(helper.indirectly_invite_members?).to eq true
|
|
end
|
|
end
|
|
|
|
context 'when a user is an owner' do
|
|
before do
|
|
allow(helper).to receive(:current_user) { owner }
|
|
end
|
|
|
|
it 'returns false' do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_version_b) { true }
|
|
|
|
expect(helper.indirectly_invite_members?).to eq false
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with group' do
|
|
let_it_be(:group) { create(:group) }
|
|
|
|
describe "#can_invite_members_for_group?" do
|
|
include Devise::Test::ControllerHelpers
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
before do
|
|
sign_in(user)
|
|
allow(helper).to receive(:current_user) { user }
|
|
end
|
|
|
|
context 'when the user can_import_members' do
|
|
before do
|
|
allow(helper).to receive(:can?).with(user, :admin_group_member, group).and_return(true)
|
|
end
|
|
|
|
it 'returns true' do
|
|
expect(helper.can_invite_members_for_group?(group)).to eq true
|
|
expect(helper).to have_received(:can?).with(user, :admin_group_member, group)
|
|
end
|
|
|
|
context 'when feature flag is disabled' do
|
|
before do
|
|
stub_feature_flags(invite_members_group_modal: false)
|
|
end
|
|
|
|
it 'returns false' do
|
|
stub_feature_flags(invite_members_group_modal: false)
|
|
|
|
expect(helper.can_invite_members_for_group?(group)).to eq false
|
|
expect(helper).not_to have_received(:can?)
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when the user can not invite members' do
|
|
before do
|
|
expect(helper).to receive(:can?).with(user, :admin_group_member, group).and_return(false)
|
|
end
|
|
|
|
it 'returns false' do
|
|
expect(helper.can_invite_members_for_group?(group)).to eq false
|
|
end
|
|
end
|
|
end
|
|
|
|
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
|
|
|
|
describe '#dropdown_invite_members_link' do
|
|
shared_examples_for 'dropdown invite members link' do
|
|
let(:link_regex) do
|
|
/data-track-event="click_link".*data-track-property="_track_property_".*Invite members/
|
|
end
|
|
|
|
before do
|
|
allow(helper).to receive(:experiment_tracking_category_and_group) { '_track_property_' }
|
|
allow(helper).to receive(:current_user) { owner }
|
|
end
|
|
|
|
it 'records the experiment' do
|
|
allow(helper).to receive(:experiment_enabled?)
|
|
|
|
helper.dropdown_invite_members_link(form_model)
|
|
|
|
expect(helper).to have_received(:experiment_tracking_category_and_group).with(:invite_members_new_dropdown)
|
|
end
|
|
|
|
context 'with experiment enabled' do
|
|
before do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_new_dropdown) { true }
|
|
end
|
|
|
|
it 'returns link' do
|
|
link = helper.dropdown_invite_members_link(form_model)
|
|
|
|
expect(link).to match(link_regex)
|
|
expect(link).to include(link_href)
|
|
expect(link).to include('gl-emoji')
|
|
end
|
|
end
|
|
|
|
context 'with no experiment enabled' do
|
|
before do
|
|
allow(helper).to receive(:experiment_enabled?).with(:invite_members_new_dropdown) { false }
|
|
end
|
|
|
|
it 'returns link' do
|
|
link = helper.dropdown_invite_members_link(form_model)
|
|
|
|
expect(link).to match(link_regex)
|
|
expect(link).to include(link_href)
|
|
expect(link).not_to include('gl-emoji')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with a project' do
|
|
let_it_be(:form_model) { project }
|
|
|
|
let(:link_href) { "href=\"#{project_project_members_path(form_model)}\"" }
|
|
|
|
it_behaves_like 'dropdown invite members link'
|
|
end
|
|
|
|
context 'with a group' do
|
|
let_it_be(:form_model) { create(:group) }
|
|
|
|
let(:link_href) { "href=\"#{group_group_members_path(form_model)}\"" }
|
|
|
|
it_behaves_like 'dropdown invite members link'
|
|
end
|
|
end
|
|
end
|