sign_in_as(create(:moderator_user))
visit issues_path
- assert_content I18n.t("issues.index.issues_not_found")
+ assert_content I18n.t("issues.page.issues_not_found")
end
def test_view_issues
visit issues_path
fill_in "search_by_user", :with => good_user.display_name
click_on "Search"
- assert_no_content I18n.t("issues.index.user_not_found")
- assert_content I18n.t("issues.index.issues_not_found")
+ assert_no_content I18n.t("issues.page.user_not_found")
+ assert_content I18n.t("issues.page.issues_not_found")
# User doesn't exist
visit issues_path
fill_in "search_by_user", :with => "Nonexistent User"
click_on "Search"
- assert_content I18n.t("issues.index.user_not_found")
- assert_content I18n.t("issues.index.issues_not_found")
+ assert_content I18n.t("issues.page.user_not_found")
+ assert_no_content I18n.t("issues.page.issues_not_found")
# Find Issue against bad_user
visit issues_path
fill_in "search_by_user", :with => bad_user.display_name
click_on "Search"
- assert_no_content I18n.t("issues.index.user_not_found")
- assert_no_content I18n.t("issues.index.issues_not_found")
+ assert_no_content I18n.t("issues.page.user_not_found")
+ assert_no_content I18n.t("issues.page.issues_not_found")
end
def test_commenting
check :reassign
click_on "Add Comment"
+ assert_content "and the issue was reassigned"
+ assert_current_path issues_path(:status => "open")
+
issue.reload
assert_equal "moderator", issue.assigned_role
end
+ def test_reassign_issue_as_super_user
+ issue = create(:issue)
+ sign_in_as(create(:super_user))
+
+ visit issue_path(issue)
+
+ fill_in :issue_comment_body, :with => "reassigning to moderators"
+ check :reassign
+ click_on "Add Comment"
+
+ assert_content "and the issue was reassigned"
+ assert_current_path issue_path(issue)
+ end
+
def test_issue_index_with_multiple_roles
user1 = create(:user)
user2 = create(:user)
visit issues_path
- assert_link I18n.t("issues.index.reports_count", :count => issue1.reports_count), :href => issue_path(issue1)
- assert_link I18n.t("issues.index.reports_count", :count => issue2.reports_count), :href => issue_path(issue2)
+ assert_link I18n.t("issues.page.reports_count", :count => issue1.reports_count), :href => issue_path(issue1)
+ assert_link I18n.t("issues.page.reports_count", :count => issue2.reports_count), :href => issue_path(issue2)
+ end
+
+ def test_issues_pagination
+ 1.upto(8).each do |n|
+ user = create(:user, :display_name => "extra_#{n}")
+ create(:issue, :reportable => user, :reported_user => user, :assigned_role => "administrator")
+ end
+
+ sign_in_as(create(:administrator_user))
+
+ visit issues_path(:limit => 5)
+
+ # First Page
+ assert_no_content I18n.t("issues.page.user_not_found")
+ assert_no_content I18n.t("issues.page.issues_not_found")
+ 4.upto(8).each do |n|
+ assert_content(/extra_#{n}[^\d]/i, :count => 2)
+ end
+ 1.upto(3).each do |n|
+ assert_no_content(/extra_#{n}[^\d]/i)
+ end
+
+ # Second Page
+ click_on "Older Issues"
+ assert_no_content I18n.t("issues.page.user_not_found")
+ assert_no_content I18n.t("issues.page.issues_not_found")
+ 4.upto(8).each do |n|
+ assert_no_content(/extra_#{n}[^\d]/i)
+ end
+ 1.upto(3).each do |n|
+ assert_content(/extra_#{n}[^\d]/i, :count => 2)
+ end
+
+ # Back to First Page
+ click_on "Newer Issues"
+ assert_no_content I18n.t("issues.page.user_not_found")
+ assert_no_content I18n.t("issues.page.issues_not_found")
+ 4.upto(8).each do |n|
+ assert_content(/extra_#{n}[^\d]/i, :count => 2)
+ end
+ 1.upto(3).each do |n|
+ assert_no_content(/extra_#{n}[^\d]/i)
+ end
end
end