diff options
author | Phil Hughes <me@iamphill.com> | 2017-05-10 17:15:19 +0000 |
---|---|---|
committer | Phil Hughes <me@iamphill.com> | 2017-05-10 17:15:19 +0000 |
commit | 09c4d27ae48ceb181f86657043af2a129c17dabf (patch) | |
tree | 1766eee1b65d69e27ae8e43342047f20d0c67957 /spec | |
parent | 05a2ef690b11467241e16b380a50384cf541ad0e (diff) | |
parent | f328f38e5b1f013c3b21f6f572cc22c71aad8fa3 (diff) | |
download | gitlab-ce-09c4d27ae48ceb181f86657043af2a129c17dabf.tar.gz |
Merge branch '31474-issue-boards-sidebar-milestone-dropdown-should-not-be-multi-select' into 'master'
Resolve "Issue boards sidebar milestone dropdown should not be multi select"
Closes #31474
See merge request !11084
Diffstat (limited to 'spec')
-rw-r--r-- | spec/features/dashboard/milestone_filter_spec.rb | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/spec/features/dashboard/milestone_filter_spec.rb b/spec/features/dashboard/milestone_filter_spec.rb new file mode 100644 index 00000000000..628627f70d4 --- /dev/null +++ b/spec/features/dashboard/milestone_filter_spec.rb @@ -0,0 +1,59 @@ +require 'spec_helper' + +describe 'Dashboard > milestone filter', feature: true, js: true do + let(:user) { create(:user) } + let(:project) { create(:project, name: 'test', namespace: user.namespace) } + let(:milestone) { create(:milestone, title: "v1.0", project: project) } + let(:milestone2) { create(:milestone, title: "v2.0", project: project) } + let!(:issue) { create :issue, author: user, project: project, milestone: milestone } + let!(:issue2) { create :issue, author: user, project: project, milestone: milestone2 } + + before do + login_as(user) + visit issues_dashboard_path(author_id: user.id) + end + + context 'default state' do + it 'shows issues with Any Milestone' do + page.all('.issue-info').each do |issue_info| + expect(issue_info.text).to match(/v\d.0/) + end + end + end + + context 'filtering by milestone' do + milestone_select = '.js-milestone-select' + + before do + find(milestone_select).click + + page.within('.dropdown-content') do + click_link 'v1.0' + end + + find(milestone_select).click + end + + it 'shows issues with Milestone v1.0' do + expect(find('.issues-list')).to have_selector('.issue', count: 1) + + find(milestone_select).click + + expect(find('.dropdown-content')).to have_selector('a.is-active', count: 1) + end + + it 'should not change active Milestone unless clicked' do + find(milestone_select).click + + expect(find('.dropdown-content')).to have_selector('a.is-active', count: 1) + + # open & close dropdown + find('.dropdown-menu-close').click + expect(find('.milestone-filter')).not_to have_selector('.dropdown.open') + find(milestone_select).click + + expect(find('.dropdown-content')).to have_selector('a.is-active', count: 1) + expect(find('.dropdown-content a.is-active')).to have_content('v1.0') + end + end +end |