153 lines
3.8 KiB
Ruby
153 lines
3.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'Merge requests > User mass updates', :js do
|
|
let(:project) { create(:project, :repository) }
|
|
let(:user) { project.creator }
|
|
let!(:merge_request) { create(:merge_request, source_project: project, target_project: project) }
|
|
|
|
before do
|
|
stub_feature_flags(mr_attention_requests: false)
|
|
|
|
project.add_maintainer(user)
|
|
sign_in(user)
|
|
end
|
|
|
|
context 'status' do
|
|
describe 'close merge request' do
|
|
before do
|
|
visit project_merge_requests_path(project)
|
|
end
|
|
|
|
it 'closes merge request', :js do
|
|
change_status('Closed')
|
|
|
|
expect(page).to have_selector('.merge-request', count: 0)
|
|
end
|
|
end
|
|
|
|
describe 'reopen merge request' do
|
|
before do
|
|
merge_request.close
|
|
visit project_merge_requests_path(project, state: 'closed')
|
|
end
|
|
|
|
it 'reopens merge request', :js do
|
|
change_status('Open')
|
|
|
|
expect(page).to have_selector('.merge-request', count: 0)
|
|
end
|
|
end
|
|
|
|
it 'does not exist in merged state' do
|
|
merge_request.close
|
|
visit project_merge_requests_path(project, state: 'merged')
|
|
|
|
click_button 'Edit merge requests'
|
|
|
|
expect(page).not_to have_button 'Select status'
|
|
end
|
|
end
|
|
|
|
context 'assignee' do
|
|
describe 'set assignee' do
|
|
before do
|
|
visit project_merge_requests_path(project)
|
|
end
|
|
|
|
it 'updates merge request with assignee' do
|
|
change_assignee(user.name)
|
|
|
|
expect(find('.merge-request')).to have_link "Assigned to #{user.name}"
|
|
end
|
|
|
|
describe 'with attention requests feature flag on' do
|
|
before do
|
|
stub_feature_flags(mr_attention_requests: true)
|
|
end
|
|
|
|
it 'updates merge request with assignee' do
|
|
change_assignee(user.name)
|
|
|
|
expect(find('.issuable-meta a.author-link')[:title]).to eq "Attention requested from assignee #{user.name}, go to their profile."
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'remove assignee' do
|
|
before do
|
|
merge_request.assignees = [user]
|
|
visit project_merge_requests_path(project)
|
|
end
|
|
|
|
it 'removes assignee from the merge request' do
|
|
change_assignee('Unassigned')
|
|
|
|
expect(find('.merge-request')).not_to have_link "Assigned to #{user.name}"
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'milestone' do
|
|
let(:milestone) { create(:milestone, project: project) }
|
|
|
|
describe 'set milestone' do
|
|
before do
|
|
visit project_merge_requests_path(project)
|
|
end
|
|
|
|
it 'updates merge request with milestone' do
|
|
change_milestone(milestone.title)
|
|
|
|
expect(find('.merge-request')).to have_content milestone.title
|
|
end
|
|
end
|
|
|
|
describe 'unset milestone' do
|
|
before do
|
|
merge_request.milestone = milestone
|
|
merge_request.save!
|
|
visit project_merge_requests_path(project)
|
|
end
|
|
|
|
it 'removes milestone from the merge request' do
|
|
change_milestone("No milestone")
|
|
|
|
expect(find('.merge-request')).not_to have_content milestone.title
|
|
end
|
|
end
|
|
end
|
|
|
|
def change_status(text)
|
|
click_button 'Edit merge requests'
|
|
check 'Select all'
|
|
click_button 'Select status'
|
|
click_button text
|
|
click_update_merge_requests_button
|
|
end
|
|
|
|
def change_assignee(text)
|
|
click_button 'Edit merge requests'
|
|
check 'Select all'
|
|
within 'aside[aria-label="Bulk update"]' do
|
|
click_button 'Select assignee'
|
|
wait_for_requests
|
|
click_link text
|
|
end
|
|
click_update_merge_requests_button
|
|
end
|
|
|
|
def change_milestone(text)
|
|
click_button 'Edit merge requests'
|
|
check 'Select all'
|
|
click_button 'Select milestone'
|
|
click_link text
|
|
click_update_merge_requests_button
|
|
end
|
|
|
|
def click_update_merge_requests_button
|
|
click_button 'Update all'
|
|
wait_for_requests
|
|
end
|
|
end
|