debian-mirror-gitlab/spec/features/dashboard/milestones_spec.rb
2022-10-11 01:57:18 +05:30

74 lines
2.2 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Dashboard > Milestones' do
describe 'as anonymous user' do
before do
visit dashboard_milestones_path
end
it 'is redirected to sign-in page' do
expect(page).to have_current_path new_user_session_path, ignore_query: true
end
end
describe 'as logged-in user' do
let(:user) { create(:user) }
let(:group) { create(:group) }
let(:project) { create(:project, namespace: user.namespace) }
let!(:milestone) { create(:milestone, project: project) }
let!(:milestone2) { create(:milestone, group: group) }
before do
group.add_developer(user)
sign_in(user)
visit dashboard_milestones_path
end
it 'sees milestones' do
expect(page).to have_current_path dashboard_milestones_path, ignore_query: true
expect(page).to have_content(milestone.title)
expect(page).to have_content(group.name)
expect(first('.milestone')).to have_content('Merge requests')
end
describe 'new milestones dropdown', :js do
it 'takes user to a new milestone page', :js do
click_button 'Toggle project select'
page.within('.select2-results') do
first('.select2-result-label').click
end
a_el = find('.js-new-project-item-link')
expect(a_el).to have_content('New Milestone in ')
expect(a_el).to have_no_content('New New Milestone in ')
a_el.click
expect(page).to have_current_path(new_group_milestone_path(group), ignore_query: true)
end
end
end
describe 'with merge requests disabled' do
let(:user) { create(:user) }
let(:group) { create(:group) }
let(:project) { create(:project, :merge_requests_disabled, namespace: user.namespace) }
let!(:milestone) { create(:milestone, project: project) }
before do
group.add_developer(user)
sign_in(user)
visit dashboard_milestones_path
end
it 'does not see milestones' do
expect(page).to have_current_path dashboard_milestones_path, ignore_query: true
expect(page).to have_content(milestone.title)
expect(first('.milestone')).to have_no_content('Merge Requests')
end
end
end