From 79c306ad06155549ff6e5929ff20a1149b4862c4 Mon Sep 17 00:00:00 2001 From: Anton Khorev Date: Tue, 17 Dec 2024 17:09:47 +0300 Subject: [PATCH 1/2] Add patch/put api message update --- config/routes.rb | 5 ++-- .../api/messages_controller_test.rb | 30 +++++++++++-------- 2 files changed, 19 insertions(+), 16 deletions(-) diff --git a/config/routes.rb b/config/routes.rb index 871fef1bf2..77b4398654 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -78,14 +78,13 @@ end end - resources :messages, :path => "user/messages", :constraints => { :id => /\d+/ }, :only => [:create, :show, :destroy], :controller => "messages", :as => :api_messages do + resources :messages, :path => "user/messages", :constraints => { :id => /\d+/ }, :only => [:create, :show, :update, :destroy], :controller => "messages", :as => :api_messages do collection do get "inbox" get "outbox" end end - - post "/user/messages/:id" => "messages#update", :as => :api_message_update + post "/user/messages/:id" => "messages#update" end namespace :api, :path => "api/0.6" do diff --git a/test/controllers/api/messages_controller_test.rb b/test/controllers/api/messages_controller_test.rb index cbf8dc8702..2e76393953 100644 --- a/test/controllers/api/messages_controller_test.rb +++ b/test/controllers/api/messages_controller_test.rb @@ -46,9 +46,13 @@ def test_routes { :controller => "api/messages", :action => "create" } ) assert_routing( - { :path => "/api/0.6/user/messages/1", :method => :post }, + { :path => "/api/0.6/user/messages/1", :method => :put }, { :controller => "api/messages", :action => "update", :id => "1" } ) + assert_recognizes( + { :controller => "api/messages", :action => "update", :id => "1" }, + { :path => "/api/0.6/user/messages/1", :method => :post } + ) assert_routing( { :path => "/api/0.6/user/messages/1", :method => :delete }, { :controller => "api/messages", :action => "destroy", :id => "1" } @@ -253,27 +257,27 @@ def test_update_status msg = create(:message, :unread, :sender => sender, :recipient => recipient) # attempt to mark message as read by recipient, not authenticated - post api_message_path(:id => msg.id), :params => { :read_status => true } + put api_message_path(:id => msg.id), :params => { :read_status => true } assert_response :unauthorized # attempt to mark message as read by recipient, not allowed - post api_message_path(:id => msg.id), :params => { :read_status => true }, :headers => user3_auth + put api_message_path(:id => msg.id), :params => { :read_status => true }, :headers => user3_auth assert_response :forbidden # missing parameter - post api_message_path(:id => msg.id), :headers => recipient_auth + put api_message_path(:id => msg.id), :headers => recipient_auth assert_response :bad_request # wrong type of parameter - post api_message_path(:id => msg.id), - :params => { :read_status => "not a boolean" }, - :headers => recipient_auth + put api_message_path(:id => msg.id), + :params => { :read_status => "not a boolean" }, + :headers => recipient_auth assert_response :bad_request # mark message as read by recipient - post api_message_path(:id => msg.id, :format => "json"), - :params => { :read_status => true }, - :headers => recipient_auth + put api_message_path(:id => msg.id, :format => "json"), + :params => { :read_status => true }, + :headers => recipient_auth assert_response :success assert_equal "application/json", response.media_type js = ActiveSupport::JSON.decode(@response.body) @@ -292,9 +296,9 @@ def test_update_status assert_equal msg.body, jsm["body"] # mark message as unread by recipient - post api_message_path(:id => msg.id, :format => "json"), - :params => { :read_status => false }, - :headers => recipient_auth + put api_message_path(:id => msg.id, :format => "json"), + :params => { :read_status => false }, + :headers => recipient_auth assert_response :success assert_equal "application/json", response.media_type js = ActiveSupport::JSON.decode(@response.body) From e89a78fff858d5db07f6959a39dd9655dc46008e Mon Sep 17 00:00:00 2001 From: Anton Khorev Date: Tue, 17 Dec 2024 17:14:19 +0300 Subject: [PATCH 2/2] Move api messages resources to api namespace --- config/routes.rb | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/config/routes.rb b/config/routes.rb index 77b4398654..4d3c1bf557 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -77,17 +77,17 @@ put "" => "user_preferences#update_all", :as => "" end end + end - resources :messages, :path => "user/messages", :constraints => { :id => /\d+/ }, :only => [:create, :show, :update, :destroy], :controller => "messages", :as => :api_messages do + namespace :api, :path => "api/0.6" do + resources :messages, :path => "user/messages", :constraints => { :id => /\d+/ }, :only => [:create, :show, :update, :destroy] do collection do get "inbox" get "outbox" end end post "/user/messages/:id" => "messages#update" - end - namespace :api, :path => "api/0.6" do resources :traces, :path => "gpx", :only => [:create, :show, :update, :destroy], :id => /\d+/ do scope :module => :traces do resource :data, :only => :show