- def test_block_status
- block = UserBlock.create(
- :user_id => 1,
- :creator_id => 2,
- :reason => "testing",
- :needs_view => true,
- :ends_at => Time.now.getutc
- )
- assert_equal I18n.t("user_block.helper.until_login"), block_status(block)
- block_end = Time.now.getutc + 60.minutes
- block = UserBlock.create(
- :user_id => 1,
- :creator_id => 2,
- :reason => "testing",
- :needs_view => true,
- :ends_at => Time.now.getutc + 60.minutes
- )
- assert_equal I18n.t("user_block.helper.time_future_and_until_login", :time => friendly_date(block_end)), block_status(block)
- block_end = Time.now.getutc + 60.minutes
- block = UserBlock.create(
- :user_id => 1,
- :creator_id => 2,
- :reason => "testing",
- :needs_view => false,
- :ends_at => Time.now.getutc + 60.minutes
- )
- assert_equal I18n.t("user_block.helper.time_future", :time => friendly_date(block_end)), block_status(block)
+ def test_block_short_status_with_immediate_update
+ freeze_time do
+ block = UserBlock.new :user => create(:user),
+ :creator => create(:moderator_user),
+ :reason => "because",
+ :created_at => Time.now.utc,
+ :ends_at => Time.now.utc,
+ :deactivates_at => Time.now.utc,
+ :needs_view => false
+
+ travel 1.second
+
+ block.save
+
+ assert_equal "ended", block_short_status(block)
+ end
+ end
+
+ def test_block_short_status_read
+ freeze_time do
+ block = create(:user_block, :needs_view, :ends_at => Time.now.utc)
+
+ travel 24.hours
+
+ assert_equal "active until read", block_short_status(block)
+
+ block.update(:needs_view => false, :deactivates_at => Time.now.utc)
+
+ assert_match "read at", block_short_status(block)
+ end
+ 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