Sha256: 1602e3fd993083f8866c910f973bdbb630e25369394d65f7a16dc19aa3ff2d44

Contents?: true

Size: 1.92 KB

Versions: 7

Compression:

Stored size: 1.92 KB

Contents

# frozen_string_literal: true

module RailsBestPractices
  module Reviews
    # Review model files to make sure finders are on their own model.
    #
    # See the best practice details here https://rails-bestpractices.com/posts/2010/07/23/keep-finders-on-their-own-model/
    #
    # Implementation:
    #
    # Review process:
    #   check all call nodes in model files.
    #
    #   if the call node is a finder (find, all, first or last),
    #   and the it calls the other model,
    #   and there is a hash argument for finder,
    #   then it should keep finders on its own model.
    class KeepFindersOnTheirOwnModelReview < Review
      interesting_nodes :method_add_arg
      interesting_files MODEL_FILES
      url 'https://rails-bestpractices.com/posts/2010/07/23/keep-finders-on-their-own-model/'

      FINDERS = %w[find all first last].freeze

      # check all the call nodes to see if there is a finder for other model.
      #
      # if the call node is
      #
      # 1. the message of call node is one of the find, all, first or last
      # 2. the receiver of call node is also a call node (it's the other model)
      # 3. the any of its arguments is a hash (complex finder)
      #
      # then it should keep finders on its own model.
      add_callback :start_method_add_arg do |node|
        add_error 'keep finders on their own model' if other_finder?(node)
      end

      private

      # check if the call node is the finder of other model.
      #
      # the message of the node should be one of find, all, first or last,
      # and the receiver of the node should be with message :call (this is the other model),
      # and any of its arguments is a hash,
      # then it is the finder of other model.
      def other_finder?(node)
        FINDERS.include?(node[1].message.to_s) && node[1].receiver.sexp_type == :call &&
          node.arguments.grep_nodes_count(sexp_type: :bare_assoc_hash) > 0
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
rails_best_practices-1.23.2 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb
rails_best_practices-1.23.1 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb
rails_best_practices-1.23.0 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb
rails_best_practices-1.22.1 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb
rails_best_practices-1.22.0 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb
rails_best_practices-1.21.0 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb
rails_best_practices-1.20.1 lib/rails_best_practices/reviews/keep_finders_on_their_own_model_review.rb