X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/9c926c6c71e0f387fddb24b010a57923b79125ad..c0d3342cfa53d1082312025ac28b6b6e112ce87b:/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 8b97e4117..0c2ab42b5 100644 --- a/test/helpers/user_blocks_helper_test.rb +++ b/test/helpers/user_blocks_helper_test.rb @@ -4,15 +4,33 @@ class UserBlocksHelperTest < ActionView::TestCase include ApplicationHelper def test_block_status - block = create(:user_block, :needs_view, :ends_at => Time.now.getutc) - assert_equal I18n.t("user_block.helper.until_login"), block_status(block) + block = create(:user_block, :needs_view, :ends_at => Time.now.utc) + assert_equal "Active until the user logs in.", block_status(block) - block_end = Time.now.getutc + 60.minutes - block = create(:user_block, :needs_view, :ends_at => block_end) - assert_equal I18n.t("user_block.helper.time_future_and_until_login", :time => friendly_date(block_end)), block_status(block) + block = create(:user_block, :needs_view, :ends_at => Time.now.utc + 1.hour) + assert_match %r{^Ends in about 1 hour and after the user has logged in\.$}, block_status(block) - block_end = Time.now.getutc + 60.minutes - block = create(:user_block, :ends_at => block_end) - assert_equal I18n.t("user_block.helper.time_future", :time => friendly_date(block_end)), block_status(block) + block = create(:user_block, :ends_at => Time.now.utc + 1.hour) + assert_match %r{^Ends in about 1 hour\.$}, 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