X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/44d9b77f7a2f48c6cea251b5e97a775598dee4fc..c47a40c1db59f0d0f836fbcd1b876390befe796e:/test/system/note_comments_test.rb diff --git a/test/system/note_comments_test.rb b/test/system/note_comments_test.rb index ea19dcd94..0577992f2 100644 --- a/test/system/note_comments_test.rb +++ b/test/system/note_comments_test.rb @@ -22,7 +22,7 @@ class NoteCommentsTest < ApplicationSystemTestCase end end - def test_add_comment + test "can add comment" do note = create(:note_with_comments) user = create(:user) sign_in_as(user) @@ -45,4 +45,129 @@ class NoteCommentsTest < ApplicationSystemTestCase assert_content "Some newly added note comment" end end + + test "can't add a comment when blocked" do + note = create(:note_with_comments) + user = create(:user) + sign_in_as(user) + visit note_path(note) + block = create(:user_block, :user => user) + + within_sidebar do + fill_in "text", :with => "Comment that won't be added while blocked" + + assert_no_text "Comment from #{user.display_name}" + assert_no_text "Comment that won't be added while blocked" + assert_no_text "Your access to the API has been blocked" + assert_button "Comment & Resolve", :disabled => false + assert_button "Comment", :disabled => false + + click_on "Comment" + + assert_no_text "Comment from #{user.display_name}" + assert_no_text "Comment that won't be added while blocked" + assert_text "Your access to the API has been blocked" + assert_button "Comment & Resolve", :disabled => false + assert_button "Comment", :disabled => false + + block.revoke! block.creator + + click_on "Comment" + + assert_text "Comment from #{user.display_name}" + assert_text "Comment that won't be added while blocked" + assert_no_text "Your access to the API has been blocked" + end + end + + test "can't resolve a note when blocked" do + note = create(:note_with_comments) + user = create(:user) + sign_in_as(user) + visit note_path(note) + create(:user_block, :user => user) + + within_sidebar do + assert_text "Unresolved note" + assert_no_text "Resolved note" + assert_no_text "Your access to the API has been blocked" + assert_button "Resolve", :disabled => false + assert_button "Comment", :disabled => true + + click_on "Resolve" + + assert_text "Unresolved note" + assert_no_text "Resolved note" + assert_text "Your access to the API has been blocked" + assert_button "Resolve", :disabled => false + assert_button "Comment", :disabled => true + end + end + + test "can't reactivate a note when blocked" do + note = create(:note_with_comments, :closed) + user = create(:user) + sign_in_as(user) + visit note_path(note) + create(:user_block, :user => user) + + within_sidebar do + assert_no_text "Unresolved note" + assert_text "Resolved note" + assert_no_text "Your access to the API has been blocked" + assert_button "Reactivate", :disabled => false + + click_on "Reactivate" + + assert_no_text "Unresolved note" + assert_text "Resolved note" + assert_text "Your access to the API has been blocked" + assert_button "Reactivate", :disabled => false + end + end + + test "no subscribe button when not logged in" do + note = create(:note_with_comments) + visit note_path(note) + + within_sidebar do + assert_no_button "Subscribe" + assert_no_button "Unsubscribe" + end + end + + test "can subscribe" do + note = create(:note_with_comments) + user = create(:user) + sign_in_as(user) + visit note_path(note) + + within_sidebar do + assert_button "Subscribe" + assert_no_button "Unsubscribe" + + click_on "Subscribe" + + assert_no_button "Subscribe" + assert_button "Unsubscribe" + end + end + + test "can unsubscribe" do + note = create(:note_with_comments) + user = create(:user) + create(:note_subscription, :note => note, :user => user) + sign_in_as(user) + visit note_path(note) + + within_sidebar do + assert_no_button "Subscribe" + assert_button "Unsubscribe" + + click_on "Unsubscribe" + + assert_button "Subscribe" + assert_no_button "Unsubscribe" + end + end end