# frozen_string_literal: true require 'spec_helper' RSpec.describe 'User sorts merge requests' do include CookieHelper let!(:merge_request) { create(:merge_request, source_project: project, target_project: project) } let!(:merge_request2) do create(:merge_request_with_diffs, source_project: project, target_project: project, source_branch: 'merge-test') end let_it_be(:user) { create(:user) } let_it_be(:group) { create(:group) } let_it_be(:group_member) { create(:group_member, :maintainer, user: user, group: group) } let_it_be(:project) { create(:project, :public, group: group) } before do sign_in(user) visit(project_merge_requests_path(project)) end it 'keeps the sort option' do find('.filter-dropdown-container .dropdown').click page.within('ul.dropdown-menu.dropdown-menu-right li') do click_link('Milestone') end visit(merge_requests_dashboard_path(assignee_username: user.username)) expect(find('.issues-filters a.is-active')).to have_content('Milestone') visit(project_merge_requests_path(project)) expect(find('.issues-filters a.is-active')).to have_content('Milestone') visit(merge_requests_group_path(group)) expect(find('.issues-filters a.is-active')).to have_content('Milestone') end it 'fallbacks to issuable_sort cookie key when remembering the sorting option' do set_cookie('issuable_sort', 'milestone') visit(merge_requests_dashboard_path(assignee_username: user.username)) expect(find('.issues-filters a.is-active')).to have_content('Milestone') end it 'separates remember sorting with issues' do create(:issue, project: project) find('.filter-dropdown-container .dropdown').click page.within('ul.dropdown-menu.dropdown-menu-right li') do click_link('Milestone') end visit(project_issues_path(project)) expect(find('.issues-filters a.is-active')).not_to have_content('Milestone') end context 'when merge requests have awards' do before do create_list(:award_emoji, 2, awardable: merge_request) create(:award_emoji, :downvote, awardable: merge_request) create(:award_emoji, awardable: merge_request2) create_list(:award_emoji, 2, :downvote, awardable: merge_request2) end it 'sorts by popularity' do find('.filter-dropdown-container .dropdown').click page.within('ul.dropdown-menu.dropdown-menu-right li') do click_link('Popularity') end page.within('.mr-list') do page.within('li.merge-request:nth-child(1)') do expect(page).to have_content(merge_request.title) expect(page).to have_content('2 1') end page.within('li.merge-request:nth-child(2)') do expect(page).to have_content(merge_request2.title) expect(page).to have_content('1 2') end end end end end