2020-11-24 15:15:51 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module RuboCop
|
|
|
|
module Cop
|
|
|
|
module RSpec
|
|
|
|
# This cop checks for `Timecop.freeze` usage in specs.
|
|
|
|
#
|
|
|
|
# @example
|
|
|
|
#
|
|
|
|
# # bad
|
|
|
|
# Timecop.freeze(Time.current) { example.run }
|
|
|
|
#
|
|
|
|
# # good
|
|
|
|
# freeze_time(Time.current) { example.run }
|
|
|
|
#
|
2022-10-11 01:57:18 +05:30
|
|
|
class TimecopFreeze < RuboCop::Cop::Base
|
|
|
|
extend RuboCop::Cop::AutoCorrector
|
|
|
|
|
2020-11-24 15:15:51 +05:30
|
|
|
include MatchRange
|
|
|
|
MESSAGE = 'Do not use `Timecop.freeze`, use `freeze_time` instead. ' \
|
|
|
|
'See https://gitlab.com/gitlab-org/gitlab/-/issues/214432 for more info.'
|
|
|
|
|
|
|
|
def_node_matcher :timecop_freeze?, <<~PATTERN
|
|
|
|
(send (const nil? :Timecop) :freeze ?_)
|
|
|
|
PATTERN
|
|
|
|
|
|
|
|
def on_send(node)
|
|
|
|
return unless timecop_freeze?(node)
|
|
|
|
|
2022-10-11 01:57:18 +05:30
|
|
|
add_offense(node, message: MESSAGE) do |corrector|
|
2020-11-24 15:15:51 +05:30
|
|
|
each_match_range(node.source_range, /^(Timecop\.freeze)/) do |match_range|
|
|
|
|
corrector.replace(match_range, 'freeze_time')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|