gitlab-org--gitlab-foss/spec/features/merge_requests/user_mass_updates_spec.rb

143 lines
3.5 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
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' 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' 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_css('.js-issue-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)
page.within('.merge-request .controls') do
expect(find('.author-link')["title"]).to have_content(user.name)
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 .controls')).not_to have_css('.author-link')
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'
find('#check-all-issues').click
find('.js-issue-status').click
find('.dropdown-menu-status a', text: text).click
click_update_merge_requests_button
end
def change_assignee(text)
click_button 'Edit merge requests'
find('#check-all-issues').click
find('.js-update-assignee').click
wait_for_requests
page.within '.dropdown-menu-user' do
click_link text
end
click_update_merge_requests_button
end
def change_milestone(text)
click_button 'Edit merge requests'
find('#check-all-issues').click
find('.issues-bulk-update .js-milestone-select').click
find('.dropdown-menu-milestone a', text: text).click
click_update_merge_requests_button
end
def click_update_merge_requests_button
find('.update-selected-issues').click
wait_for_requests
end
end