133 lines
3.4 KiB
Ruby
133 lines
3.4 KiB
Ruby
|
require 'rails_helper'
|
||
|
|
||
|
feature 'Multiple merge requests updating from merge_requests#index', feature: true do
|
||
|
include WaitForAjax
|
||
|
|
||
|
let!(:user) { create(:user)}
|
||
|
let!(:project) { create(:project) }
|
||
|
let!(:merge_request) { create(:merge_request, source_project: project, target_project: project) }
|
||
|
|
||
|
before do
|
||
|
project.team << [user, :master]
|
||
|
login_as(user)
|
||
|
end
|
||
|
|
||
|
context 'status', js: true do
|
||
|
describe 'close merge request' do
|
||
|
before do
|
||
|
visit namespace_project_merge_requests_path(project.namespace, 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 namespace_project_merge_requests_path(project.namespace, 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', js: true do
|
||
|
describe 'set assignee' do
|
||
|
before do
|
||
|
visit namespace_project_merge_requests_path(project.namespace, 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 namespace_project_merge_requests_path(project.namespace, 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', js: true do
|
||
|
let(:milestone) { create(:milestone, project: project) }
|
||
|
|
||
|
describe 'set milestone' do
|
||
|
before do
|
||
|
visit namespace_project_merge_requests_path(project.namespace, 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 namespace_project_merge_requests_path(project.namespace, 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)
|
||
|
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)
|
||
|
find('#check_all_issues').click
|
||
|
find('.js-update-assignee').click
|
||
|
wait_for_ajax
|
||
|
|
||
|
page.within '.dropdown-menu-user' do
|
||
|
click_link text
|
||
|
end
|
||
|
|
||
|
click_update_merge_requests_button
|
||
|
end
|
||
|
|
||
|
def change_milestone(text)
|
||
|
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_ajax
|
||
|
end
|
||
|
end
|