X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/325cd12c248892a78c4042d22fbdd8c1467037fb..23488f202877621ed27e74826848d5a4d518d867:/test/helpers/user_blocks_helper_test.rb?ds=sidebyside diff --git a/test/helpers/user_blocks_helper_test.rb b/test/helpers/user_blocks_helper_test.rb index de5ff1c6a..28cc0ad50 100644 --- a/test/helpers/user_blocks_helper_test.rb +++ b/test/helpers/user_blocks_helper_test.rb @@ -1,42 +1,84 @@ -# coding: utf-8 require "test_helper" class UserBlocksHelperTest < ActionView::TestCase include ApplicationHelper - def setup - I18n.locale = "en" + + def test_block_status + block = create(:user_block, :needs_view, :ends_at => Time.now.utc) + assert_equal "Active until the user logs in.", block_status(block) + + block = create(:user_block, :needs_view, :ends_at => Time.now.utc + 1.hour) + assert_match %r{^Ends in and after the user has logged in\.$}, block_status(block) + + block = create(:user_block, :ends_at => Time.now.utc + 1.hour) + assert_match %r{^Ends in \.$}, block_status(block) end - def teardown - I18n.locale = "en" + def test_block_short_status + freeze_time do + future_end_block = create(:user_block, :ends_at => Time.now.utc + 48.hours) + unread_future_end_block = create(:user_block, :needs_view, :ends_at => Time.now.utc + 48.hours) + past_end_block = create(:user_block, :ends_at => Time.now.utc + 1.hour) + unread_past_end_block = create(:user_block, :needs_view, :ends_at => Time.now.utc + 1.hour) + + travel 24.hours + + assert_equal "active", block_short_status(future_end_block) + assert_equal "active", block_short_status(unread_future_end_block) + assert_equal "ended", block_short_status(past_end_block) + assert_equal "active until read", block_short_status(unread_past_end_block) + end end - 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 end end