]> git.openstreetmap.org Git - rails.git/commitdiff
Report verification render not redirect
authorHarry Wood <github@harrywood.co.uk>
Wed, 4 May 2022 15:34:40 +0000 (16:34 +0100)
committerHarry Wood <github@harrywood.co.uk>
Wed, 4 May 2022 18:42:36 +0000 (19:42 +0100)
Fix an issue with the report verification, causing it to lose the text of a report if the user fails to fill in a category.

By using a `render` instead of a `redirect_to`, the rails standard verification behaviour works better. It means we also get a nice red "can't be blank" message highlighting the specific missing field.

app/controllers/reports_controller.rb
test/controllers/reports_controller_test.rb

index a04fab5b9ab36c87a19a442c07b277cc59c56250..30cb9da7cc18c526ab9b93eabbb338cf72fbf2a8 100644 (file)
@@ -28,7 +28,8 @@ class ReportsController < ApplicationController
 
       redirect_to helpers.reportable_url(@report.issue.reportable), :notice => t(".successful_report")
     else
 
       redirect_to helpers.reportable_url(@report.issue.reportable), :notice => t(".successful_report")
     else
-      redirect_to new_report_path(:reportable_type => @report.issue.reportable_type, :reportable_id => @report.issue.reportable_id), :notice => t(".provide_details")
+      flash[:notice] = t(".provide_details")
+      render :action => "new"
     end
   end
 
     end
   end
 
index e8f59ec5ec1df1ed270c4f4e47607520a0300060..8374e76d9f5d0efefe9fe39239cb8d7d8e4fbeeb 100644 (file)
@@ -63,10 +63,12 @@ class ReportsControllerTest < ActionDispatch::IntegrationTest
       category = "other"
       post reports_path(:report => {
                           :category => category,
       category = "other"
       post reports_path(:report => {
                           :category => category,
-                          :issue => { :reportable_id => 1, :reportable_type => "User" }
+                          :issue => { :reportable_id => target_user.id, :reportable_type => "User" }
                         })
     end
                         })
     end
-    assert_response :redirect
+    assert_response :success
+    assert_template :new
+    assert_match(/Please provide the required details/, flash[:notice])
 
     assert_equal 1, issue.reports.count
   end
 
     assert_equal 1, issue.reports.count
   end