class RuboCop::Cop::Rails::ExpandedDateRange


date.all_year
date.all_quarter
date.all_month
date.all_week
date.all_day
# good
date.beginning_of_year..date.end_of_year
date.beginning_of_quarter..date.end_of_quarter
date.beginning_of_month..date.end_of_month
date.beginning_of_week..date.end_of_week
date.beginning_of_day..date.end_of_day
# bad
@example
Incompatible ‘…` range is ignored.
Checks for expanded date range. It only compatible `..` range is targeted.

def on_irange(node)

def on_irange(node)
  return unless expanded_date_range(node)
  begin_node = node.begin
  end_node = node.end
  return unless same_receiver?(begin_node, end_node)
  beginning_method = begin_node.method_name
  end_method = end_node.method_name
  return unless use_mapped_methods?(beginning_method, end_method)
  preferred_method = "#{begin_node.receiver.source}.#{PREFERRED_METHODS[beginning_method]}"
  add_offense(node, message: format(MSG, preferred_method: preferred_method)) do |corrector|
    corrector.replace(node, preferred_method)
  end
end

def same_receiver?(begin_node, end_node)

def same_receiver?(begin_node, end_node)
  begin_node.receiver.source == end_node.receiver.source
end

def use_mapped_methods?(beginning_method, end_method)

def use_mapped_methods?(beginning_method, end_method)
  MAPPED_DATE_RANGE_METHODS[beginning_method] == end_method
end