2017-12-11 11:34:51 -05:00
|
|
|
require_relative '../../migration_helpers'
|
|
|
|
|
|
|
|
module RuboCop
|
|
|
|
module Cop
|
|
|
|
module Migration
|
|
|
|
# Cop that checks if remove_column is used in a regular (not
|
|
|
|
# post-deployment) migration.
|
|
|
|
class RemoveColumn < RuboCop::Cop::Cop
|
|
|
|
include MigrationHelpers
|
|
|
|
|
|
|
|
MSG = '`remove_column` must only be used in post-deployment migrations'.freeze
|
|
|
|
|
|
|
|
def on_def(node)
|
|
|
|
def_method = node.children[0]
|
|
|
|
|
|
|
|
return unless in_migration?(node) && !in_post_deployment_migration?(node)
|
|
|
|
return unless def_method == :change || def_method == :up
|
|
|
|
|
|
|
|
node.each_descendant(:send) do |send_node|
|
|
|
|
send_method = send_node.children[1]
|
|
|
|
|
|
|
|
if send_method == :remove_column
|
2017-09-19 11:25:42 -04:00
|
|
|
add_offense(send_node, location: :selector)
|
2017-12-11 11:34:51 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|