# 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 describe '#common_invite_modal_dataset' do context 'when member_areas_of_focus is enabled', :experiment do context 'with control experience' do before do stub_experiments(member_areas_of_focus: :control) end it 'has expected attributes' do attributes = { areas_of_focus_options: [], no_selection_areas_of_focus: [] } expect(helper.common_invite_modal_dataset(project)).to include(attributes) end end context 'with candidate experience' do before do stub_experiments(member_areas_of_focus: :candidate) end it 'has expected attributes', :aggregate_failures do output = helper.common_invite_modal_dataset(project) expect(output[:no_selection_areas_of_focus]).to eq ['no_selection'] expect(Gitlab::Json.parse(output[:areas_of_focus_options]).first['value']).to eq 'Contribute to the codebase' end end end context 'when member_areas_of_focus is disabled' do before do stub_feature_flags(member_areas_of_focus: false) end it 'has expected attributes' do attributes = { id: project.id, name: project.name, default_access_level: Gitlab::Access::GUEST, areas_of_focus_options: [], no_selection_areas_of_focus: [] } expect(helper.common_invite_modal_dataset(project)).to include(attributes) end end context 'tasks_to_be_done' do subject(:output) { helper.common_invite_modal_dataset(source) } let_it_be(:source) { project } before do stub_experiments(invite_members_for_task: true) end context 'when not logged in' do before do allow(helper).to receive(:params).and_return({ open_modal: 'invite_members_for_task' }) end it "doesn't have the tasks to be done attributes" do expect(output[:tasks_to_be_done_options]).to be_nil expect(output[:projects]).to be_nil expect(output[:new_project_path]).to be_nil end end context 'when logged in but the open_modal param is not present' do before do allow(helper).to receive(:current_user).and_return(developer) end it "doesn't have the tasks to be done attributes" do expect(output[:tasks_to_be_done_options]).to be_nil expect(output[:projects]).to be_nil expect(output[:new_project_path]).to be_nil end end context 'when logged in and the open_modal param is present' do before do allow(helper).to receive(:current_user).and_return(developer) allow(helper).to receive(:params).and_return({ open_modal: 'invite_members_for_task' }) end context 'for a group' do let_it_be(:source) { create(:group, projects: [project]) } it 'has the expected attributes', :aggregate_failures do expect(output[:tasks_to_be_done_options]).to eq( [ { value: :code, text: 'Create/import code into a project (repository)' }, { value: :ci, text: 'Set up CI/CD pipelines to build, test, deploy, and monitor code' }, { value: :issues, text: 'Create/import issues (tickets) to collaborate on ideas and plan work' } ].to_json ) expect(output[:projects]).to eq( [{ id: project.id, title: project.title }].to_json ) expect(output[:new_project_path]).to eq( new_project_path(namespace_id: source.id) ) end end context 'for a project' do it 'has the expected attributes', :aggregate_failures do expect(output[:tasks_to_be_done_options]).to eq( [ { value: :code, text: 'Create/import code into a project (repository)' }, { value: :ci, text: 'Set up CI/CD pipelines to build, test, deploy, and monitor code' }, { value: :issues, text: 'Create/import issues (tickets) to collaborate on ideas and plan work' } ].to_json ) expect(output[:projects]).to eq( [{ id: project.id, title: project.title }].to_json ) expect(output[:new_project_path]).to eq('') end end end end 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_admin_project_member' do before do allow(helper).to receive(:can?).with(owner, :admin_project_member, project).and_return(true) end it 'returns true', :aggregate_failures do expect(helper.can_invite_members_for_project?(project)).to eq true expect(helper).to have_received(:can?).with(owner, :admin_project_member, project) end context 'when feature flag is disabled' do before do stub_feature_flags(invite_members_group_modal: false) end it 'returns false', :aggregate_failures do expect(helper.can_invite_members_for_project?(project)).to eq false expect(helper).not_to have_received(:can?).with(owner, :admin_project_member, project) end end end context 'when the user can not manage project members' do before do expect(helper).to receive(:can?).with(owner, :admin_project_member, project).and_return(false) end it 'returns false' do expect(helper.can_invite_members_for_project?(project)).to eq false end end end end end