# frozen_string_literal: true module RuboCop module Cop module FactoryBot # Use string value when setting the class attribute explicitly. # # This cop would promote faster tests by lazy-loading of # application files. Also, this could help you suppress potential bugs # in combination with external libraries by avoiding a preload of # application files from the factory files. # # @example # # bad # factory :foo, class: Foo do # end # # # good # factory :foo, class: 'Foo' do # end # class FactoryClassName < ::RuboCop::Cop::Base extend AutoCorrector MSG = "Pass '%s' string instead of `%s` " \ 'constant.' ALLOWED_CONSTANTS = %w[Hash OpenStruct].freeze RESTRICT_ON_SEND = %i[factory].freeze # @!method class_name(node) def_node_matcher :class_name, <<~PATTERN (send _ :factory _ (hash <(pair (sym :class) $(const ...)) ...>)) PATTERN def on_send(node) class_name(node) do |cn| next if allowed?(cn.const_name) msg = format(MSG, class_name: cn.const_name) add_offense(cn, message: msg) do |corrector| corrector.replace(cn, "'#{cn.source}'") end end end private def allowed?(const_name) ALLOWED_CONSTANTS.include?(const_name) end end end end end