Sha256: b65f47ab38b59c2191c0684c197b25c2e45940d3a86c756f3237667cdbf03127

Contents?: true

Size: 1.3 KB

Versions: 2

Compression:

Stored size: 1.3 KB

Contents

# frozen_string_literal: true

module RailsBestPractices
  module Reviews
    # Review a controller file to make sure using simplified syntax for render.
    #
    # See the best practice details here https://rails-bestpractices.com/posts/2010/12/12/simplify-render-in-controllers/
    #
    # Implementation:
    #
    # Review process:
    #   check all render method commands in controller files,
    #   if there is a key 'action', 'template' or 'file' in the argument,
    #   then they should be replaced by simplified syntax.
    class SimplifyRenderInControllersReview < Review
      interesting_nodes :command
      interesting_files CONTROLLER_FILES
      url 'https://rails-bestpractices.com/posts/2010/12/12/simplify-render-in-controllers/'

      # check command node in the controller file,
      # if its message is render and the arguments contain a key action, template or file,
      # then it should be replaced by simplified syntax.
      add_callback :start_command do |node|
        if 'render' == node.message.to_s
          keys = node.arguments.all.first.hash_keys
          if keys && keys.size == 1 &&
             (keys.include?('action') || keys.include?('template') || keys.include?('file'))
            add_error 'simplify render in controllers'
          end
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
rails_best_practices-1.19.3 lib/rails_best_practices/reviews/simplify_render_in_controllers_review.rb
rails_best_practices-1.19.2 lib/rails_best_practices/reviews/simplify_render_in_controllers_review.rb