385 lines
12 KiB
Ruby
385 lines
12 KiB
Ruby
require 'rails_helper'
|
|
|
|
describe 'Filter issues', feature: true do
|
|
include WaitForAjax
|
|
|
|
let!(:group) { create(:group) }
|
|
let!(:project) { create(:project, group: group) }
|
|
let!(:user) { create(:user)}
|
|
let!(:milestone) { create(:milestone, project: project) }
|
|
let!(:label) { create(:label, project: project) }
|
|
let!(:wontfix) { create(:label, project: project, title: "Won't fix") }
|
|
|
|
before do
|
|
project.team << [user, :master]
|
|
group.add_developer(user)
|
|
login_as(user)
|
|
create(:issue, project: project)
|
|
end
|
|
|
|
describe 'for assignee from issues#index' do
|
|
before do
|
|
visit namespace_project_issues_path(project.namespace, project)
|
|
|
|
find('.js-assignee-search').click
|
|
|
|
find('.dropdown-menu-user-link', text: user.username).click
|
|
|
|
wait_for_ajax
|
|
end
|
|
|
|
context 'assignee', js: true do
|
|
it 'updates to current user' do
|
|
expect(find('.js-assignee-search .dropdown-toggle-text')).to have_content(user.name)
|
|
end
|
|
|
|
it 'does not change when closed link is clicked' do
|
|
find('.issues-state-filters a', text: "Closed").click
|
|
|
|
expect(find('.js-assignee-search .dropdown-toggle-text')).to have_content(user.name)
|
|
end
|
|
|
|
it 'does not change when all link is clicked' do
|
|
find('.issues-state-filters a', text: "All").click
|
|
|
|
expect(find('.js-assignee-search .dropdown-toggle-text')).to have_content(user.name)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'for milestone from issues#index' do
|
|
before do
|
|
visit namespace_project_issues_path(project.namespace, project)
|
|
|
|
find('.js-milestone-select').click
|
|
|
|
find('.milestone-filter .dropdown-content a', text: milestone.title).click
|
|
|
|
wait_for_ajax
|
|
end
|
|
|
|
context 'milestone', js: true do
|
|
it 'updates to current milestone' do
|
|
expect(find('.js-milestone-select .dropdown-toggle-text')).to have_content(milestone.title)
|
|
end
|
|
|
|
it 'does not change when closed link is clicked' do
|
|
find('.issues-state-filters a', text: "Closed").click
|
|
|
|
expect(find('.js-milestone-select .dropdown-toggle-text')).to have_content(milestone.title)
|
|
end
|
|
|
|
it 'does not change when all link is clicked' do
|
|
find('.issues-state-filters a', text: "All").click
|
|
|
|
expect(find('.js-milestone-select .dropdown-toggle-text')).to have_content(milestone.title)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'for label from issues#index', js: true do
|
|
before do
|
|
visit namespace_project_issues_path(project.namespace, project)
|
|
find('.js-label-select').click
|
|
wait_for_ajax
|
|
end
|
|
|
|
it 'filters by any label' do
|
|
find('.dropdown-menu-labels a', text: 'Any Label').click
|
|
page.first('.labels-filter .dropdown-title .dropdown-menu-close-icon').click
|
|
wait_for_ajax
|
|
|
|
expect(find('.labels-filter')).to have_content 'Label'
|
|
end
|
|
|
|
it 'filters by no label' do
|
|
find('.dropdown-menu-labels a', text: 'No Label').click
|
|
page.first('.labels-filter .dropdown-title .dropdown-menu-close-icon').click
|
|
wait_for_ajax
|
|
|
|
page.within '.labels-filter' do
|
|
expect(page).to have_content 'Labels'
|
|
end
|
|
expect(find('.js-label-select .dropdown-toggle-text')).to have_content('Labels')
|
|
end
|
|
|
|
it 'filters by a label' do
|
|
find('.dropdown-menu-labels a', text: label.title).click
|
|
page.within '.labels-filter' do
|
|
expect(page).to have_content label.title
|
|
end
|
|
expect(find('.js-label-select .dropdown-toggle-text')).to have_content(label.title)
|
|
end
|
|
|
|
it "filters by `won't fix` and another label" do
|
|
page.within '.labels-filter' do
|
|
click_link wontfix.title
|
|
expect(page).to have_content wontfix.title
|
|
click_link label.title
|
|
end
|
|
|
|
expect(find('.js-label-select .dropdown-toggle-text')).to have_content("#{wontfix.title} +1 more")
|
|
end
|
|
|
|
it "filters by `won't fix` label followed by another label after page load" do
|
|
page.within '.labels-filter' do
|
|
click_link wontfix.title
|
|
expect(page).to have_content wontfix.title
|
|
end
|
|
|
|
find('.dropdown-menu-close-icon').click
|
|
|
|
expect(find('.filtered-labels')).to have_content(wontfix.title)
|
|
|
|
find('.js-label-select').click
|
|
wait_for_ajax
|
|
find('.dropdown-menu-labels a', text: label.title).click
|
|
|
|
find('.dropdown-menu-close-icon').click
|
|
|
|
expect(find('.filtered-labels')).to have_content(wontfix.title)
|
|
expect(find('.filtered-labels')).to have_content(label.title)
|
|
|
|
find('.js-label-select').click
|
|
wait_for_ajax
|
|
|
|
expect(find('.dropdown-menu-labels li', text: wontfix.title)).to have_css('.is-active')
|
|
expect(find('.dropdown-menu-labels li', text: label.title)).to have_css('.is-active')
|
|
end
|
|
|
|
it "selects and unselects `won't fix`" do
|
|
find('.dropdown-menu-labels a', text: wontfix.title).click
|
|
find('.dropdown-menu-labels a', text: wontfix.title).click
|
|
|
|
find('.dropdown-menu-close-icon').click
|
|
expect(page).not_to have_css('.filtered-labels')
|
|
end
|
|
end
|
|
|
|
describe 'for assignee and label from issues#index' do
|
|
before do
|
|
visit namespace_project_issues_path(project.namespace, project)
|
|
|
|
find('.js-assignee-search').click
|
|
|
|
find('.dropdown-menu-user-link', text: user.username).click
|
|
|
|
expect(page).not_to have_selector('.issues-list .issue')
|
|
|
|
find('.js-label-select').click
|
|
|
|
find('.dropdown-menu-labels .dropdown-content a', text: label.title).click
|
|
page.first('.labels-filter .dropdown-title .dropdown-menu-close-icon').click
|
|
|
|
wait_for_ajax
|
|
end
|
|
|
|
context 'assignee and label', js: true do
|
|
it 'updates to current assignee and label' do
|
|
expect(find('.js-assignee-search .dropdown-toggle-text')).to have_content(user.name)
|
|
expect(find('.js-label-select .dropdown-toggle-text')).to have_content(label.title)
|
|
end
|
|
|
|
it 'does not change when closed link is clicked' do
|
|
find('.issues-state-filters a', text: "Closed").click
|
|
|
|
expect(find('.js-assignee-search .dropdown-toggle-text')).to have_content(user.name)
|
|
expect(find('.js-label-select .dropdown-toggle-text')).to have_content(label.title)
|
|
end
|
|
|
|
it 'does not change when all link is clicked' do
|
|
find('.issues-state-filters a', text: "All").click
|
|
|
|
expect(find('.js-assignee-search .dropdown-toggle-text')).to have_content(user.name)
|
|
expect(find('.js-label-select .dropdown-toggle-text')).to have_content(label.title)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'filter issues by text' do
|
|
before do
|
|
create(:issue, title: "Bug", project: project)
|
|
|
|
bug_label = create(:label, project: project, title: 'bug')
|
|
milestone = create(:milestone, title: "8", project: project)
|
|
|
|
issue = create(:issue,
|
|
title: "Bug 2",
|
|
project: project,
|
|
milestone: milestone,
|
|
author: user,
|
|
assignee: user)
|
|
issue.labels << bug_label
|
|
|
|
visit namespace_project_issues_path(project.namespace, project)
|
|
end
|
|
|
|
context 'only text', js: true do
|
|
it 'filters issues by searched text' do
|
|
fill_in 'issuable_search', with: 'Bug'
|
|
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 2)
|
|
end
|
|
end
|
|
|
|
it 'does not show any issues' do
|
|
fill_in 'issuable_search', with: 'testing'
|
|
|
|
page.within '.issues-list' do
|
|
expect(page).not_to have_selector('.issue')
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'text and dropdown options', js: true do
|
|
it 'filters by text and label' do
|
|
fill_in 'issuable_search', with: 'Bug'
|
|
|
|
expect(page).to have_issuable_counts(open: 2, closed: 0, all: 2)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 2)
|
|
end
|
|
|
|
click_button 'Label'
|
|
page.within '.labels-filter' do
|
|
click_link 'bug'
|
|
end
|
|
find('.dropdown-menu-close-icon').click
|
|
|
|
expect(page).to have_issuable_counts(open: 1, closed: 0, all: 1)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 1)
|
|
end
|
|
end
|
|
|
|
it 'filters by text and milestone' do
|
|
fill_in 'issuable_search', with: 'Bug'
|
|
|
|
expect(page).to have_issuable_counts(open: 2, closed: 0, all: 2)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 2)
|
|
end
|
|
|
|
click_button 'Milestone'
|
|
page.within '.milestone-filter' do
|
|
click_link '8'
|
|
end
|
|
|
|
expect(page).to have_issuable_counts(open: 1, closed: 0, all: 1)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 1)
|
|
end
|
|
end
|
|
|
|
it 'filters by text and assignee' do
|
|
fill_in 'issuable_search', with: 'Bug'
|
|
|
|
expect(page).to have_issuable_counts(open: 2, closed: 0, all: 2)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 2)
|
|
end
|
|
|
|
click_button 'Assignee'
|
|
page.within '.dropdown-menu-assignee' do
|
|
click_link user.name
|
|
end
|
|
|
|
expect(page).to have_issuable_counts(open: 1, closed: 0, all: 1)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 1)
|
|
end
|
|
end
|
|
|
|
it 'filters by text and author' do
|
|
fill_in 'issuable_search', with: 'Bug'
|
|
|
|
expect(page).to have_issuable_counts(open: 2, closed: 0, all: 2)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 2)
|
|
end
|
|
|
|
click_button 'Author'
|
|
page.within '.dropdown-menu-author' do
|
|
click_link user.name
|
|
end
|
|
|
|
expect(page).to have_issuable_counts(open: 1, closed: 0, all: 1)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 1)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'filter issues and sort', js: true do
|
|
before do
|
|
bug_label = create(:label, project: project, title: 'bug')
|
|
bug_one = create(:issue, title: "Frontend", project: project)
|
|
bug_two = create(:issue, title: "Bug 2", project: project)
|
|
|
|
bug_one.labels << bug_label
|
|
bug_two.labels << bug_label
|
|
|
|
visit namespace_project_issues_path(project.namespace, project)
|
|
end
|
|
|
|
it 'is able to filter and sort issues' do
|
|
click_button 'Label'
|
|
wait_for_ajax
|
|
page.within '.labels-filter' do
|
|
click_link 'bug'
|
|
end
|
|
find('.dropdown-menu-close-icon').click
|
|
wait_for_ajax
|
|
|
|
expect(page).to have_issuable_counts(open: 2, closed: 0, all: 2)
|
|
page.within '.issues-list' do
|
|
expect(page).to have_selector('.issue', count: 2)
|
|
end
|
|
|
|
click_button 'Last created'
|
|
page.within '.dropdown-menu-sort' do
|
|
click_link 'Oldest created'
|
|
end
|
|
wait_for_ajax
|
|
|
|
page.within '.issues-list' do
|
|
expect(page).to have_content('Frontend')
|
|
end
|
|
end
|
|
end
|
|
|
|
it 'updates atom feed link for project issues' do
|
|
visit namespace_project_issues_path(project.namespace, project, milestone_title: '', assignee_id: user.id)
|
|
|
|
link = find('.nav-controls a', text: 'Subscribe')
|
|
params = CGI::parse(URI.parse(link[:href]).query)
|
|
auto_discovery_link = find('link[type="application/atom+xml"]', visible: false)
|
|
auto_discovery_params = CGI::parse(URI.parse(auto_discovery_link[:href]).query)
|
|
|
|
expect(params).to include('private_token' => [user.private_token])
|
|
expect(params).to include('milestone_title' => [''])
|
|
expect(params).to include('assignee_id' => [user.id.to_s])
|
|
expect(auto_discovery_params).to include('private_token' => [user.private_token])
|
|
expect(auto_discovery_params).to include('milestone_title' => [''])
|
|
expect(auto_discovery_params).to include('assignee_id' => [user.id.to_s])
|
|
end
|
|
|
|
it 'updates atom feed link for group issues' do
|
|
visit issues_group_path(group, milestone_title: '', assignee_id: user.id)
|
|
|
|
link = find('.nav-controls a', text: 'Subscribe')
|
|
params = CGI::parse(URI.parse(link[:href]).query)
|
|
auto_discovery_link = find('link[type="application/atom+xml"]', visible: false)
|
|
auto_discovery_params = CGI::parse(URI.parse(auto_discovery_link[:href]).query)
|
|
|
|
expect(params).to include('private_token' => [user.private_token])
|
|
expect(params).to include('milestone_title' => [''])
|
|
expect(params).to include('assignee_id' => [user.id.to_s])
|
|
expect(auto_discovery_params).to include('private_token' => [user.private_token])
|
|
expect(auto_discovery_params).to include('milestone_title' => [''])
|
|
expect(auto_discovery_params).to include('assignee_id' => [user.id.to_s])
|
|
end
|
|
end
|