# frozen_string_literal: true require 'spec_helper' RSpec.describe 'Merge request > User assigns themselves', feature_category: :code_review_workflow do let(:project) { create(:project, :public, :repository) } let(:user) { project.creator } let(:issue1) { create(:issue, project: project) } let(:issue2) { create(:issue, project: project) } let(:merge_request) { create(:merge_request, :simple, source_project: project, author: user, description: "fixes #{issue1.to_reference} and #{issue2.to_reference}") } context 'logged in as a member of the project' do before do sign_in(user) visit project_merge_request_path(project, merge_request) end it 'updates related issues', :js, quarantine: 'https://gitlab.com/gitlab-org/gitlab/-/issues/343006' do click_link 'Assign yourself to these issues' expect(page).to have_content '2 issues have been assigned to you' end it 'updates updated_by', :js do wait_for_requests expect do page.within('[data-testid="assignee-block-container"]') do click_button 'assign yourself' end expect(find('.assignee')).to have_content(user.name) wait_for_all_requests end.to change { merge_request.reload.updated_at } end context 'when related issues are already assigned' do before do [issue1, issue2].each { |issue| issue.update!(assignees: [user]) } end it 'does not display if related issues are already assigned' do page.within('[data-testid="assignee-block-container"]') do expect(page).not_to have_content 'Assign yourself' end end end end context 'logged in as a non-member of the project' do before do sign_in(create(:user)) visit project_merge_request_path(project, merge_request) end it 'does not show assignment link' do page.within('[data-testid="assignee-block-container"]') do expect(page).not_to have_content 'Assign yourself' end end end end