2020-03-13 11:09:21 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require_relative '../../migration_helpers'
|
|
|
|
|
|
|
|
module RuboCop
|
|
|
|
module Cop
|
|
|
|
module Migration
|
|
|
|
# Cop that prevents usage of `with_lock_retries` within the `change` method.
|
2022-09-14 11:12:56 -04:00
|
|
|
class WithLockRetriesWithChange < RuboCop::Cop::Base
|
2020-03-13 11:09:21 -04:00
|
|
|
include MigrationHelpers
|
|
|
|
|
|
|
|
MSG = '`with_lock_retries` cannot be used within `change` so you must manually define ' \
|
2021-03-23 08:09:33 -04:00
|
|
|
'the `up` and `down` methods in your migration class and use `with_lock_retries` in both methods'
|
2020-03-13 11:09:21 -04:00
|
|
|
|
|
|
|
def on_send(node)
|
|
|
|
return unless in_migration?(node)
|
|
|
|
return unless node.children[1] == :with_lock_retries
|
|
|
|
|
|
|
|
node.each_ancestor(:def) do |def_node|
|
2022-09-14 11:12:56 -04:00
|
|
|
add_offense(def_node.loc.name) if def_node.method_name == :change
|
2020-03-13 11:09:21 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|