+ assert_content issues.first.reported_user.display_name
+ end
+
+ def test_view_issue_with_report
+ sign_in_as(create(:moderator_user))
+ issue = create(:issue, :assigned_role => "moderator")
+ issue.reports << create(:report, :details => "test report text **with kramdown**")
+
+ visit issue_path(issue)
+ assert_content I18n.t("issues.show.reports", :count => 1)
+ assert_content "test report text with kramdown"
+ assert_selector "strong", :text => "with kramdown"
+ end
+
+ def test_view_issue_rich_text_container
+ sign_in_as(create(:moderator_user))
+ issue = create(:issue, :assigned_role => "moderator")
+ issue.reports << create(:report, :details => "paragraph one\n\n---\n\nparagraph two")
+
+ visit issue_path(issue)
+ assert_content I18n.t("issues.show.reports", :count => 1)
+ richtext = find "div.richtext"
+ richtext_elements = richtext.all "*"
+ assert_equal 3, richtext_elements.size
+ assert_equal "p", richtext_elements[0].tag_name
+ assert_equal "paragraph one", richtext_elements[0].text
+ assert_equal "hr", richtext_elements[1].tag_name
+ assert_equal "p", richtext_elements[2].tag_name
+ assert_equal "paragraph two", richtext_elements[2].text
+ end
+
+ def test_view_issues_with_no_reported_user
+ sign_in_as(create(:moderator_user))
+ anonymous_note = create(:note_with_comments)
+ issue = create(:issue, :reportable => anonymous_note, :assigned_role => "moderator")
+
+ visit issues_path
+ assert_content reportable_title(anonymous_note)
+
+ visit issue_path(issue)
+ assert_content reportable_title(anonymous_note)
+ end
+
+ def test_search_issues_by_user
+ good_user = create(:user)
+ bad_user = create(:user)
+ create(:issue, :reportable => bad_user, :reported_user => bad_user, :assigned_role => "administrator")
+
+ sign_in_as(create(:administrator_user))
+
+ # No issues against the user
+ 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")
+
+ # 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")
+
+ # 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")