1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Merge requests > User mass updates', :js, feature_category: :code_review_workflow do
let(:project) { create(:project, :repository) }
let(:user) { project.creator }
let(:user2) { create(:user) }
let!(:merge_request) { create(:merge_request, source_project: project, target_project: project) }
before do
project.add_maintainer(user)
project.add_maintainer(user2)
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
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_button text
click_update_merge_requests_button
end
def click_update_merge_requests_button
click_button 'Update all'
wait_for_requests
end
end
|