X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/a6b8cf3e646f2845591d4452b722885f51c960c1..6316745c2ed5a098102f6a18d547f86bd98d7511:/test/controllers/messages_controller_test.rb?ds=sidebyside diff --git a/test/controllers/messages_controller_test.rb b/test/controllers/messages_controller_test.rb index f72e69593..bdf88600c 100644 --- a/test/controllers/messages_controller_test.rb +++ b/test/controllers/messages_controller_test.rb @@ -16,18 +16,6 @@ class MessagesControllerTest < ActionDispatch::IntegrationTest { :path => "/messages/1", :method => :get }, { :controller => "messages", :action => "show", :id => "1" } ) - assert_routing( - { :path => "/messages/1/mark", :method => :post }, - { :controller => "messages", :action => "mark", :message_id => "1" } - ) - assert_routing( - { :path => "/messages/1/reply", :method => :get }, - { :controller => "messages", :action => "reply", :message_id => "1" } - ) - assert_routing( - { :path => "/messages/1/reply", :method => :post }, - { :controller => "messages", :action => "reply", :message_id => "1" } - ) assert_routing( { :path => "/messages/1", :method => :delete }, { :controller => "messages", :action => "destroy", :id => "1" } @@ -171,7 +159,7 @@ class MessagesControllerTest < ActionDispatch::IntegrationTest end end end - assert_redirected_to messages_inbox_path + assert_redirected_to messages_outbox_path assert_equal "Message sent", flash[:notice] e = ActionMailer::Base.deliveries.first assert_equal [recipient_user.email], e.to @@ -219,63 +207,6 @@ class MessagesControllerTest < ActionDispatch::IntegrationTest end end - ## - # test the reply action - def test_reply - user = create(:user) - recipient_user = create(:user) - other_user = create(:user) - message = create(:message, :unread, :sender => user, :recipient => recipient_user) - - # Check that the message reply page requires us to login - get message_reply_path(message) - assert_redirected_to login_path(:referer => message_reply_path(message)) - - # Login as the wrong user - session_for(other_user) - - # Check that we can't reply to somebody else's message - get message_reply_path(message) - assert_redirected_to login_path(:referer => message_reply_path(message)) - assert_equal "You are logged in as '#{other_user.display_name}' but the message you have asked to reply to was not sent to that user. Please log in as the correct user in order to reply.", flash[:notice] - - # Login as the right user - session_for(recipient_user) - - # Check that the message reply page loads - get message_reply_path(message) - assert_response :success - assert_template "new" - assert_select "title", "Re: #{message.title} | OpenStreetMap" - assert_select "form[action='/messages']", :count => 1 do - assert_select "input[type='hidden'][name='display_name'][value='#{user.display_name}']" - assert_select "input#message_title[value='Re: #{message.title}']", :count => 1 - assert_select "textarea#message_body", :count => 1 - assert_select "input[type='submit'][value='Send']", :count => 1 - end - assert Message.find(message.id).message_read - - # Login as the sending user - session_for(user) - - # Check that the message reply page loads - get message_reply_path(message) - assert_response :success - assert_template "new" - assert_select "title", "Re: #{message.title} | OpenStreetMap" - assert_select "form[action='/messages']", :count => 1 do - assert_select "input[type='hidden'][name='display_name'][value='#{recipient_user.display_name}']" - assert_select "input#message_title[value='Re: #{message.title}']", :count => 1 - assert_select "textarea#message_body", :count => 1 - assert_select "input[type='submit'][value='Send']", :count => 1 - end - - # Asking to reply to a message with a bogus ID should fail - get message_reply_path(99999) - assert_response :not_found - assert_template "no_such_message" - end - ## # test the show action def test_show @@ -324,84 +255,6 @@ class MessagesControllerTest < ActionDispatch::IntegrationTest assert_template "no_such_message" end - ## - # test the mark action - def test_mark - sender_user = create(:user) - recipient_user = create(:user) - other_user = create(:user) - message = create(:message, :unread, :sender => sender_user, :recipient => recipient_user) - - # Check that the marking a message requires us to login - post message_mark_path(message) - assert_response :forbidden - - # Login as a user with no messages - session_for(other_user) - - # Check that marking a message we didn't send or receive fails - post message_mark_path(message) - assert_response :not_found - assert_template "no_such_message" - - # Login as the message sender_user - session_for(sender_user) - - # Check that marking a message we sent fails - post message_mark_path(message) - assert_response :not_found - assert_template "no_such_message" - - # Login as the message recipient_user - session_for(recipient_user) - - # Check that the marking a message read works - post message_mark_path(message, :mark => "read") - assert_redirected_to messages_inbox_path - assert Message.find(message.id).message_read - - # Check that the marking a message unread works - post message_mark_path(message, :mark => "unread") - assert_redirected_to messages_inbox_path - assert_not Message.find(message.id).message_read - - # Check that the marking a message read works and redirects to inbox from the message page - post message_mark_path(message, :mark => "read"), :headers => { :referer => message_path(message) } - assert_redirected_to messages_inbox_path - assert Message.find(message.id).message_read - - # Check that the marking a message unread works and redirects to inbox from the message page - post message_mark_path(message, :mark => "unread"), :headers => { :referer => message_path(message) } - assert_redirected_to messages_inbox_path - assert_not Message.find(message.id).message_read - - # Asking to mark a message with a bogus ID should fail - post message_mark_path(99999) - assert_response :not_found - assert_template "no_such_message" - end - - ## - # test the mark action for messages from muted users - def test_mark_muted - sender_user = create(:user) - recipient_user = create(:user) - create(:user_mute, :owner => recipient_user, :subject => sender_user) - message = create(:message, :unread, :sender => sender_user, :recipient => recipient_user) - - session_for(recipient_user) - - # Check that the marking a message read works - post message_mark_path(message, :mark => "read") - assert_redirected_to messages_muted_inbox_path - assert Message.find(message.id).message_read - - # Check that the marking a message unread works - post message_mark_path(message, :mark => "unread") - assert_redirected_to messages_muted_inbox_path - assert_not Message.find(message.id).message_read - end - ## # test the destroy action def test_destroy