debian-mirror-gitlab/spec/features/dashboard/merge_requests_spec.rb

130 lines
4.1 KiB
Ruby
Raw Normal View History

2017-08-17 22:00:37 +05:30
require 'spec_helper'
2018-11-08 19:23:39 +05:30
describe 'Dashboard Merge Requests' do
2018-05-09 12:01:36 +05:30
include Spec::Support::Helpers::Features::SortingHelpers
2017-09-10 17:25:29 +05:30
include FilterItemSelectHelper
2018-03-17 18:26:18 +05:30
include ProjectForksHelper
2017-09-10 17:25:29 +05:30
2017-08-17 22:00:37 +05:30
let(:current_user) { create :user }
2017-09-10 17:25:29 +05:30
let(:project) { create(:project) }
let(:public_project) { create(:project, :public, :repository) }
2018-03-17 18:26:18 +05:30
let(:forked_project) { fork_project(public_project, current_user, repository: true) }
2017-08-17 22:00:37 +05:30
before do
2018-11-18 11:00:15 +05:30
project.add_maintainer(current_user)
2017-09-10 17:25:29 +05:30
sign_in(current_user)
end
context 'new merge request dropdown' do
let(:project_with_disabled_merge_requests) { create(:project, :merge_requests_disabled) }
before do
2018-11-18 11:00:15 +05:30
project_with_disabled_merge_requests.add_maintainer(current_user)
2017-09-10 17:25:29 +05:30
visit merge_requests_dashboard_path
end
2018-03-17 18:26:18 +05:30
it 'shows projects only with merge requests feature enabled', :js do
find('.new-project-item-select-button').click
2017-09-10 17:25:29 +05:30
page.within('.select2-results') do
2018-03-27 19:54:05 +05:30
expect(page).to have_content(project.full_name)
expect(page).not_to have_content(project_with_disabled_merge_requests.full_name)
2017-09-10 17:25:29 +05:30
end
end
2017-08-17 22:00:37 +05:30
end
2017-09-10 17:25:29 +05:30
context 'no merge requests exist' do
it 'shows an empty state' do
visit merge_requests_dashboard_path(assignee_id: current_user.id)
2017-08-17 22:00:37 +05:30
2017-09-10 17:25:29 +05:30
expect(page).to have_selector('.empty-state')
end
2017-08-17 22:00:37 +05:30
end
2017-09-10 17:25:29 +05:30
context 'merge requests exist' do
let!(:assigned_merge_request) do
2018-03-17 18:26:18 +05:30
create(:merge_request,
assignee: current_user,
source_project: project,
author: create(:user))
2017-09-10 17:25:29 +05:30
end
let!(:assigned_merge_request_from_fork) do
create(:merge_request,
source_branch: 'markdown', assignee: current_user,
2018-03-17 18:26:18 +05:30
target_project: public_project, source_project: forked_project,
author: create(:user))
2017-09-10 17:25:29 +05:30
end
let!(:authored_merge_request) do
create(:merge_request,
2018-03-17 18:26:18 +05:30
source_branch: 'markdown',
source_project: project,
author: current_user)
2017-09-10 17:25:29 +05:30
end
let!(:authored_merge_request_from_fork) do
create(:merge_request,
source_branch: 'feature_conflict',
author: current_user,
2018-03-17 18:26:18 +05:30
target_project: public_project, source_project: forked_project)
2017-09-10 17:25:29 +05:30
end
let!(:other_merge_request) do
create(:merge_request,
source_branch: 'fix',
2018-03-17 18:26:18 +05:30
source_project: project,
author: create(:user))
2017-09-10 17:25:29 +05:30
end
2017-08-17 22:00:37 +05:30
before do
2017-09-10 17:25:29 +05:30
visit merge_requests_dashboard_path(assignee_id: current_user.id)
end
it 'shows assigned merge requests' do
expect(page).to have_content(assigned_merge_request.title)
expect(page).to have_content(assigned_merge_request_from_fork.title)
expect(page).not_to have_content(authored_merge_request.title)
expect(page).not_to have_content(authored_merge_request_from_fork.title)
expect(page).not_to have_content(other_merge_request.title)
end
2018-03-17 18:26:18 +05:30
it 'shows authored merge requests', :js do
2017-09-10 17:25:29 +05:30
filter_item_select('Any Assignee', '.js-assignee-search')
filter_item_select(current_user.to_reference, '.js-author-search')
expect(page).to have_content(authored_merge_request.title)
expect(page).to have_content(authored_merge_request_from_fork.title)
expect(page).not_to have_content(assigned_merge_request.title)
expect(page).not_to have_content(assigned_merge_request_from_fork.title)
expect(page).not_to have_content(other_merge_request.title)
end
2018-05-09 12:01:36 +05:30
it 'shows error message without filter', :js do
2017-09-10 17:25:29 +05:30
filter_item_select('Any Assignee', '.js-assignee-search')
filter_item_select('Any Author', '.js-author-search')
2018-05-09 12:01:36 +05:30
expect(page).to have_content('Please select at least one filter to see results')
2017-09-10 17:25:29 +05:30
end
it 'shows sorted merge requests' do
2018-05-09 12:01:36 +05:30
sort_by('Created date')
2017-08-17 22:00:37 +05:30
visit merge_requests_dashboard_path(assignee_id: current_user.id)
2017-09-10 17:25:29 +05:30
2018-03-17 18:26:18 +05:30
expect(find('.issues-filters')).to have_content('Created date')
2017-08-17 22:00:37 +05:30
end
2017-09-10 17:25:29 +05:30
it 'keeps sorting merge requests after visiting Projects MR page' do
2018-05-09 12:01:36 +05:30
sort_by('Created date')
2017-09-10 17:25:29 +05:30
visit project_merge_requests_path(project)
2018-03-17 18:26:18 +05:30
expect(find('.issues-filters')).to have_content('Created date')
2017-08-17 22:00:37 +05:30
end
end
end