Sha256: 25985c7f261499e48d43c5f97daeedd993c02ac2ad87f52d2a672cfdfc2d1d1e

Contents?: true

Size: 1.04 KB

Versions: 2

Compression:

Stored size: 1.04 KB

Contents

require_relative '../../migration_helpers'

module Gitlab
  module Styles
    module Rubocop
      module Cop
        module Migration
          # Cop that checks if `add_concurrent_index` is used with `up`/`down` methods
          # and not `change`.
          class AddConcurrentIndex < RuboCop::Cop::Cop
            include MigrationHelpers

            MSG = '`add_concurrent_index` is not reversible so you must manually define ' \
              'the `up` and `down` methods in your migration class, using `remove_concurrent_index` in `down`'.freeze

            def on_send(node)
              return unless in_migration?(node)

              name = node.children[1]

              return unless name == :add_concurrent_index

              node.each_ancestor(:def) do |def_node|
                next unless method_name(def_node) == :change

                add_offense(def_node, :name)
              end
            end

            def method_name(node)
              node.children.first
            end
          end
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
gitlab-styles-1.0.0 lib/gitlab/styles/rubocop/cop/migration/add_concurrent_index.rb
gitlab-styles-0.1.0 lib/gitlab/styles/rubocop/cop/migration/add_concurrent_index.rb