]> git.openstreetmap.org Git - rails.git/commitdiff
Set block ends_at to exactly created_at + duration
authorAnton Khorev <tony29@yandex.ru>
Wed, 27 Dec 2023 03:48:00 +0000 (06:48 +0300)
committerAnton Khorev <tony29@yandex.ru>
Wed, 27 Dec 2023 03:48:00 +0000 (06:48 +0300)
app/controllers/user_blocks_controller.rb
test/controllers/user_blocks_controller_test.rb

index 546c8233c65a4d5f4eeb42d97cc76dc0558c1d28..885318cbe10ef282762f47939465858767b1e73b 100644 (file)
@@ -39,11 +39,13 @@ class UserBlocksController < ApplicationController
 
   def create
     if @valid_params
+      now = Time.now.utc
       @user_block = UserBlock.new(
         :user => @user,
         :creator => current_user,
         :reason => params[:user_block][:reason],
-        :ends_at => Time.now.utc + @block_period.hours,
+        :created_at => now,
+        :ends_at => now + @block_period.hours,
         :needs_view => params[:user_block][:needs_view]
       )
 
index 27022c973748deaa3b0f9937d728824b5532ca16..2c363be3d9d0566b2fffff1a62697995e2aea5a8 100644 (file)
@@ -261,6 +261,21 @@ class UserBlocksControllerTest < ActionDispatch::IntegrationTest
     assert_select "h1", "The user non_existent_user does not exist"
   end
 
+  ##
+  # test the duration of a created block
+  def test_create_duration
+    target_user = create(:user)
+    moderator_user = create(:moderator_user)
+
+    session_for(moderator_user)
+    post user_blocks_path(:display_name => target_user.display_name,
+                          :user_block_period => "336",
+                          :user_block => { :needs_view => false, :reason => "Vandalism" })
+
+    block = UserBlock.order(:id).last
+    assert_equal 1209600, block.ends_at - block.created_at
+  end
+
   ##
   # test the update action
   def test_update