58 lines
1.8 KiB
Ruby
58 lines
1.8 KiB
Ruby
require "spec_helper"
|
|
|
|
# The main goal of this spec is not to check whether the sorting UI works, but
|
|
# to check if the sorting option set by user is being kept persisted while going through pages.
|
|
# The `it`s are named here by convention `starting point -> some pages -> final point`.
|
|
# All those specs are moved out to this spec intentionally to keep them all in one place.
|
|
describe "User sorts things" do
|
|
include Spec::Support::Helpers::Features::SortingHelpers
|
|
include DashboardHelper
|
|
|
|
set(:project) { create(:project_empty_repo, :public) }
|
|
set(:current_user) { create(:user) } # Using `current_user` instead of just `user` because of the hardoced call in `assigned_mrs_dashboard_path` which is used below.
|
|
set(:issue) { create(:issue, project: project, author: current_user) }
|
|
set(:merge_request) { create(:merge_request, target_project: project, source_project: project, author: current_user) }
|
|
|
|
before do
|
|
project.add_developer(current_user)
|
|
sign_in(current_user)
|
|
end
|
|
|
|
it "issues -> project home page -> issues" do
|
|
sort_option = "Last updated"
|
|
|
|
visit(project_issues_path(project))
|
|
|
|
sort_by(sort_option)
|
|
|
|
visit(project_path(project))
|
|
visit(project_issues_path(project))
|
|
|
|
expect(find(".issues-filters")).to have_content(sort_option)
|
|
end
|
|
|
|
it "issues -> merge requests" do
|
|
sort_option = "Last updated"
|
|
|
|
visit(project_issues_path(project))
|
|
|
|
sort_by(sort_option)
|
|
|
|
visit(project_merge_requests_path(project))
|
|
|
|
expect(find(".issues-filters")).to have_content(sort_option)
|
|
end
|
|
|
|
it "merge requests -> dashboard merge requests" do
|
|
sort_option = "Last updated"
|
|
|
|
visit(project_merge_requests_path(project))
|
|
|
|
sort_by(sort_option)
|
|
|
|
visit(assigned_mrs_dashboard_path)
|
|
|
|
expect(find(".issues-filters")).to have_content(sort_option)
|
|
end
|
|
end
|