]> git.openstreetmap.org Git - rails.git/commitdiff
Merge remote-tracking branch 'upstream/pull/3216'
authorTom Hughes <tom@compton.nu>
Wed, 9 Jun 2021 16:46:11 +0000 (17:46 +0100)
committerTom Hughes <tom@compton.nu>
Wed, 9 Jun 2021 16:46:11 +0000 (17:46 +0100)
app/helpers/user_blocks_helper.rb
test/helpers/user_blocks_helper_test.rb

index 73425edec4b028f1752cf109bc199fa20a58b32b..95b6cb600c739786701c0cb95c6fe8470c4428a3 100644 (file)
@@ -26,9 +26,11 @@ module UserBlocksHelper
   end
 
   def block_duration_in_words(duration)
+    # Ensure the requested duration isn't negative, even by a millisecond
+    duration = 0 if duration.negative?
     parts = ActiveSupport::Duration.build(duration).parts
     if duration < 1.day
-      t("user_blocks.helper.block_duration.hours", :count => parts[:hours])
+      t("user_blocks.helper.block_duration.hours", :count => parts.fetch(:hours, 0))
     elsif duration < 1.week
       t("user_blocks.helper.block_duration.days", :count => parts[:days])
     elsif duration < 1.month
index 16f83ec89a64930d2af1c225fea36e43f6f55dd9..c4afa6c83b6e7e991d8ad8b869903af75d7932f9 100644 (file)
@@ -13,4 +13,24 @@ class UserBlocksHelperTest < ActionView::TestCase
     block = create(:user_block, :ends_at => Time.now.getutc + 1.hour)
     assert_match %r{^Ends in <span title=".*">about 1 hour</span>\.$}, block_status(block)
   end
+
+  def test_block_duration_in_words
+    words = block_duration_in_words(364.days)
+    assert_equal "11 months", words
+
+    words = block_duration_in_words(24.hours)
+    assert_equal "1 day", words
+
+    # Ensure that nil hours is not passed to i18n.t
+    words = block_duration_in_words(10.minutes)
+    assert_equal "0 hours", words
+
+    words = block_duration_in_words(0)
+    assert_equal "0 hours", words
+
+    # Ensure that (slightly) negative durations don't mess everything up
+    # This can happen on zero hour blocks when ends_at is a millisecond before created_at
+    words = block_duration_in_words(-0.001)
+    assert_equal "0 hours", words
+  end
 end