gitlab-org--gitlab-foss/spec/features/issues/user_bulk_edits_issues_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

145 lines
3.5 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Multiple issue updating from issues#index', :js do
let!(:project) { create(:project) }
let!(:issue) { create(:issue, project: project) }
let!(:user) { create(:user) }
2016-03-23 07:45:24 -04:00
before do
project.add_maintainer(user)
sign_in(user)
2016-03-23 07:45:24 -04:00
end
context 'status' do
it 'sets to closed', :js do
visit project_issues_path(project)
click_button 'Edit issues'
check 'Select all'
click_button 'Select status'
click_button 'Closed'
click_update_issues_button
expect(page).to have_selector('.issue', count: 0)
end
it 'sets to open', :js do
create_closed
visit project_issues_path(project, state: 'closed')
click_button 'Edit issues'
check 'Select all'
click_button 'Select status'
click_button 'Open'
click_update_issues_button
expect(page).to have_selector('.issue', count: 0)
end
end
context 'assignee' do
it 'updates to current user' do
visit project_issues_path(project)
2016-03-23 07:18:39 -04:00
click_button 'Edit issues'
check 'Select all'
2016-05-10 19:11:16 -04:00
click_update_assignee_button
click_link user.username
2016-03-23 07:18:39 -04:00
click_update_issues_button
page.within('.issue .controls') do
expect(find('.author-link')['href']).to have_content(user.website_url)
2016-03-23 07:18:39 -04:00
end
end
it 'updates to unassigned' do
2016-03-23 07:18:39 -04:00
create_assigned
visit project_issues_path(project)
2016-03-23 07:18:39 -04:00
expect(find('.issue:first-of-type')).to have_link "Assigned to #{user.name}"
click_button 'Edit issues'
check 'Select all'
2016-05-10 19:11:16 -04:00
click_update_assignee_button
2016-03-24 05:10:46 -04:00
click_link 'Unassigned'
2016-03-23 07:18:39 -04:00
click_update_issues_button
expect(find('.issue:first-of-type')).not_to have_link "Assigned to #{user.name}"
2016-03-23 07:18:39 -04:00
end
end
context 'milestone' do
let!(:milestone) { create(:milestone, project: project) }
2016-03-23 07:45:24 -04:00
it 'updates milestone' do
visit project_issues_path(project)
2016-03-23 07:45:24 -04:00
click_button 'Edit issues'
check 'Select all'
click_button 'Select milestone'
click_link milestone.title
2016-03-23 07:45:24 -04:00
click_update_issues_button
expect(page.find('.issue')).to have_content milestone.title
2016-03-23 07:45:24 -04:00
end
it 'sets to no milestone' do
2016-03-23 07:45:24 -04:00
create_with_milestone
visit project_issues_path(project)
2016-03-23 07:45:24 -04:00
wait_for_requests
expect(find('.issue:first-of-type')).to have_text milestone.title
2016-03-23 07:45:24 -04:00
click_button 'Edit issues'
check 'Select all'
click_button 'Select milestone'
click_link 'No milestone'
2016-03-23 07:45:24 -04:00
click_update_issues_button
expect(find('.issue:first-of-type')).not_to have_text milestone.title
2016-03-23 07:45:24 -04:00
end
end
describe 'select all issues' do
let!(:issue_2) { create(:issue, project: project) }
it 'after selecting all issues, unchecking one issue only unselects that one issue' do
visit project_issues_path(project)
click_button 'Edit issues'
check 'Select all'
uncheck issue.title
expect(page).to have_unchecked_field 'Select all'
expect(page).to have_unchecked_field issue.title
expect(page).to have_checked_field issue_2.title
end
end
def create_closed
create(:issue, project: project, state: :closed)
end
2016-03-23 07:18:39 -04:00
def create_assigned
create(:issue, project: project, assignees: [user])
2016-03-23 07:18:39 -04:00
end
2016-03-23 07:45:24 -04:00
def create_with_milestone
create(:issue, project: project, milestone: milestone)
end
2016-05-10 19:11:16 -04:00
def click_update_assignee_button
click_button 'Select assignee'
wait_for_requests
2016-05-10 19:11:16 -04:00
end
def click_update_issues_button
click_button 'Update all'
wait_for_requests
end
end