Class: Rubocop::Cop::Rails::IncludeUrlHelper
- Inherits:
-
RuboCop::Cop::Base
- Object
- RuboCop::Cop::Base
- Rubocop::Cop::Rails::IncludeUrlHelper
- Defined in:
- lib/rubocop/cop/rails/include_url_helper.rb
Overview
Avoid including ‘ActionView::Helpers::UrlHelper`.
It adds/overrides ~40 methods while usually only one is needed.
Instead, use the `Gitlab::Routing.url_helpers`/`Application.routes.url_helpers`(outside of gitlab)
and `ActionController::Base.helpers.link_to`.
See also
Constant Summary collapse
- MSG =
"Avoid including `ActionView::Helpers::UrlHelper`.\nIt adds/overrides ~40 methods while usually only one is needed.\nInstead, use the `Gitlab::Routing.url_helpers`/`Application.routes.url_helpers`(outside of gitlab)\nand `ActionController::Base.helpers.link_to`.\nSee https://gitlab.com/gitlab-org/gitlab/-/issues/340567.\n"
Instance Method Summary collapse
Instance Method Details
#include_url_helpers_node?(node) ⇒ Object
41 42 43 |
# File 'lib/rubocop/cop/rails/include_url_helper.rb', line 41 def_node_matcher :include_url_helpers_node?, "(send nil? :include (const (const (const {nil? cbase} :ActionView) :Helpers) :UrlHelper))\n" |
#on_send(node) ⇒ Object
45 46 47 |
# File 'lib/rubocop/cop/rails/include_url_helper.rb', line 45 def on_send(node) add_offense(node) if include_url_helpers_node?(node) end |