diff options
author | Kamil Trzciński <ayufan@ayufan.eu> | 2019-04-08 15:33:36 +0200 |
---|---|---|
committer | Kamil Trzciński <ayufan@ayufan.eu> | 2019-04-15 13:05:14 +0200 |
commit | 650f40865e5d8136cb366fbde689c4100aafb0c5 (patch) | |
tree | f740d9f235693ad8e2a3693d6ec30dee26d2a74a /rubocop | |
parent | 7457c1e1229cd1e90e608e8b247e2fbb217f05b6 (diff) | |
download | gitlab-ce-650f40865e5d8136cb366fbde689c4100aafb0c5.tar.gz |
Forbid the use of `#reload` and prefer `#reset`forbid-the-usage-of-reload
The `#reload` makes to load all objects into memory,
and the main purpose of `#reload` is to drop the association cache.
The `#reset` seems to solve exactly that case.
Diffstat (limited to 'rubocop')
-rw-r--r-- | rubocop/cop/active_record_association_reload.rb | 21 | ||||
-rw-r--r-- | rubocop/rubocop.rb | 1 |
2 files changed, 22 insertions, 0 deletions
diff --git a/rubocop/cop/active_record_association_reload.rb b/rubocop/cop/active_record_association_reload.rb new file mode 100644 index 00000000000..dc241cab7d0 --- /dev/null +++ b/rubocop/cop/active_record_association_reload.rb @@ -0,0 +1,21 @@ +# frozen_string_literal: true + +module RuboCop + module Cop + # Cop that blacklists the use of `reload`. + class ActiveRecordAssociationReload < RuboCop::Cop::Cop + MSG = 'Use reset instead of reload. ' \ + 'For more details check the https://gitlab.com/gitlab-org/gitlab-ce/issues/60218.' + + def_node_matcher :reload?, <<~PATTERN + (send _ :reload ...) + PATTERN + + def on_send(node) + return unless reload?(node) + + add_offense(node, location: :selector) + end + end + end +end diff --git a/rubocop/rubocop.rb b/rubocop/rubocop.rb index 3e33419eb2e..50eab6f9270 100644 --- a/rubocop/rubocop.rb +++ b/rubocop/rubocop.rb @@ -6,6 +6,7 @@ require_relative 'cop/gitlab/finder_with_find_by' require_relative 'cop/gitlab/union' require_relative 'cop/include_sidekiq_worker' require_relative 'cop/safe_params' +require_relative 'cop/active_record_association_reload' require_relative 'cop/avoid_return_from_blocks' require_relative 'cop/avoid_break_from_strong_memoize' require_relative 'cop/avoid_route_redirect_leading_slash' |