diff options
Diffstat (limited to 'spec/features/merge_requests/user_mass_updates_spec.rb')
-rw-r--r-- | spec/features/merge_requests/user_mass_updates_spec.rb | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/spec/features/merge_requests/user_mass_updates_spec.rb b/spec/features/merge_requests/user_mass_updates_spec.rb new file mode 100644 index 00000000000..199ba7e87ad --- /dev/null +++ b/spec/features/merge_requests/user_mass_updates_spec.rb @@ -0,0 +1,133 @@ +require 'rails_helper' + +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_master(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 + 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.assignee = user + merge_request.save + 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 |