require 'spec_helper' RSpec.describe 'Dashboard Issues', feature: true do let(:current_user) { create :user } let(:user) { current_user } # Shared examples depend on this being available let!(:public_project) { create(:empty_project, :public) } let(:project) { create(:empty_project) } let(:project_with_issues_disabled) { create(:empty_project, :issues_disabled) } let!(:authored_issue) { create :issue, author: current_user, project: project } let!(:authored_issue_on_public_project) { create :issue, author: current_user, project: public_project } let!(:assigned_issue) { create :issue, assignees: [current_user], project: project } let!(:other_issue) { create :issue, project: project } before do [project, project_with_issues_disabled].each { |project| project.team << [current_user, :master] } sign_in(current_user) visit issues_dashboard_path(assignee_id: current_user.id) end describe 'issues' do it 'shows issues assigned to current user' do expect(page).to have_content(assigned_issue.title) expect(page).not_to have_content(authored_issue.title) expect(page).not_to have_content(other_issue.title) end it 'shows checkmark when unassigned is selected for assignee', js: true do find('.js-assignee-search').click find('li', text: 'Unassigned').click find('.js-assignee-search').click expect(find('li[data-user-id="0"] a.is-active')).to be_visible end it 'shows issues when current user is author', js: true do find('#assignee_id', visible: false).set('') find('.js-author-search', match: :first).click expect(find('li[data-user-id="null"] a.is-active')).to be_visible find('.dropdown-menu-author li a', match: :first, text: current_user.to_reference).click find('.js-author-search', match: :first).click page.within '.dropdown-menu-user' do expect(find('.dropdown-menu-author li a.is-active', match: :first, text: current_user.to_reference)).to be_visible end expect(page).to have_content(authored_issue.title) expect(page).to have_content(authored_issue_on_public_project.title) expect(page).not_to have_content(assigned_issue.title) expect(page).not_to have_content(other_issue.title) end it 'shows all issues' do click_link('Reset filters') expect(page).to have_content(authored_issue.title) expect(page).to have_content(authored_issue_on_public_project.title) expect(page).to have_content(assigned_issue.title) expect(page).to have_content(other_issue.title) end it 'state filter tabs work' do find('#state-closed').click expect(page).to have_current_path(issues_dashboard_url(assignee_id: current_user.id, state: 'closed'), url: true) end it_behaves_like "it has an RSS button with current_user's RSS token" it_behaves_like "an autodiscoverable RSS feed with current_user's RSS token" end describe 'new issue dropdown' do it 'shows projects only with issues feature enabled', js: true do find('.new-project-item-select-button').trigger('click') page.within('.select2-results') do expect(page).to have_content(project.name_with_namespace) expect(page).not_to have_content(project_with_issues_disabled.name_with_namespace) end end it 'shows the new issue page', js: true do original_defaults = Gitlab::Application.routes.default_url_options Gitlab::Application.routes.default_url_options = { host: Capybara.current_session.server.host, port: Capybara.current_session.server.port, protocol: 'http' } find('.new-project-item-select-button').trigger('click') wait_for_requests find('.select2-results li').click expect(page).to have_current_path("/#{project.path_with_namespace}/issues/new") page.within('#content-body') do expect(page).to have_selector('.issue-form') end Gitlab::Application.routes.default_url_options = original_defaults end end end