2017-04-05 18:53:57 -04:00
|
|
|
require_relative '../../migration_helpers'
|
|
|
|
|
|
|
|
module RuboCop
|
|
|
|
module Cop
|
|
|
|
module Migration
|
|
|
|
# Cop that checks if indexes are removed in a concurrent manner.
|
|
|
|
class RemoveIndex < RuboCop::Cop::Cop
|
|
|
|
include MigrationHelpers
|
|
|
|
|
|
|
|
MSG = '`remove_index` requires downtime, use `remove_concurrent_index` instead'.freeze
|
|
|
|
|
|
|
|
def on_def(node)
|
|
|
|
return unless in_migration?(node)
|
|
|
|
|
|
|
|
node.each_descendant(:send) do |send_node|
|
2017-09-19 11:25:42 -04:00
|
|
|
add_offense(send_node, location: :selector) if method_name(send_node) == :remove_index
|
2017-04-05 18:53:57 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def method_name(node)
|
|
|
|
node.children[1]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|