Commit 15b7f489 authored by Peter Leitzen's avatar Peter Leitzen

Merge branch 'issue_239356_fix_Rails/IndexBy' into 'master'

Resolve Rails/IndexBy rubocop offenses

See merge request gitlab-org/gitlab!81391
parents 688082f0 6ad4f10a
...@@ -239,6 +239,10 @@ Rails/FindBy: ...@@ -239,6 +239,10 @@ Rails/FindBy:
- 'spec/**/*.rb' - 'spec/**/*.rb'
- 'ee/spec/**/*.rb' - 'ee/spec/**/*.rb'
Rails/IndexBy:
Exclude:
- 'tooling/danger/**/*.rb'
# This is currently exiting with a rubocop exception error and should be # This is currently exiting with a rubocop exception error and should be
# resolved hopefully a future update # resolved hopefully a future update
# An error occurred while Rails/UniqueValidationWithoutIndex cop was inspecting # An error occurred while Rails/UniqueValidationWithoutIndex cop was inspecting
......
...@@ -458,24 +458,6 @@ Rails/HasManyOrHasOneDependent: ...@@ -458,24 +458,6 @@ Rails/HasManyOrHasOneDependent:
Rails/HelperInstanceVariable: Rails/HelperInstanceVariable:
Enabled: false Enabled: false
# Offense count: 17
# Cop supports --auto-correct.
Rails/IndexBy:
Exclude:
- 'app/graphql/types/design_management/design_fields.rb'
- 'app/models/ci/pipeline.rb'
- 'app/services/ci/pipeline_processing/atomic_processing_service/status_collection.rb'
- 'ee/app/services/projects/update_mirror_service.rb'
- 'ee/app/services/security/store_report_service.rb'
- 'ee/lib/ee/gitlab/auth/ldap/sync/group.rb'
- 'ee/lib/ee/gitlab/background_migration/backfill_version_data_from_gitaly.rb'
- 'ee/lib/gitlab/analytics/type_of_work/tasks_by_type.rb'
- 'ee/lib/gitlab/elastic/document_reference.rb'
- 'ee/lib/gitlab/group_plans_preloader.rb'
- 'lib/gitlab/database/count/reltuples_count_strategy.rb'
- 'lib/gitlab/language_detection.rb'
- 'tooling/danger/sidekiq_queues.rb'
# Offense count: 47 # Offense count: 47
# Cop supports --auto-correct. # Cop supports --auto-correct.
Rails/IndexWith: Rails/IndexWith:
......
...@@ -62,7 +62,7 @@ module Types ...@@ -62,7 +62,7 @@ module Types
def cached_actions_for_version(version) def cached_actions_for_version(version)
Gitlab::SafeRequestStore.fetch(['DesignFields', 'actions_for_version', version.id]) do Gitlab::SafeRequestStore.fetch(['DesignFields', 'actions_for_version', version.id]) do
version.actions.to_h { |dv| [dv.design_id, dv] } version.actions.index_by(&:design_id)
end end
end end
......
...@@ -421,9 +421,7 @@ module Ci ...@@ -421,9 +421,7 @@ module Ci
sql = sql.where(ref: ref) if ref sql = sql.where(ref: ref) if ref
sql.each_with_object({}) do |pipeline, hash| sql.index_by(&:sha)
hash[pipeline.sha] = pipeline
end
end end
def self.latest_successful_ids_per_project def self.latest_successful_ids_per_project
......
...@@ -91,17 +91,13 @@ module Ci ...@@ -91,17 +91,13 @@ module Ci
def all_statuses_by_id def all_statuses_by_id
strong_memoize(:all_statuses_by_id) do strong_memoize(:all_statuses_by_id) do
all_statuses.to_h do |row| all_statuses.index_by { |row| row[:id] }
[row[:id], row]
end
end end
end end
def all_statuses_by_name def all_statuses_by_name
strong_memoize(:statuses_by_name) do strong_memoize(:statuses_by_name) do
all_statuses.to_h do |row| all_statuses.index_by { |row| row[:name] }
[row[:name], row]
end
end end
end end
......
...@@ -61,7 +61,7 @@ module Projects ...@@ -61,7 +61,7 @@ module Projects
end end
def update_branches def update_branches
local_branches = repository.branches.each_with_object({}) { |branch, branches| branches[branch.name] = branch } local_branches = repository.branches.index_by(&:name)
errors = [] errors = []
...@@ -96,7 +96,7 @@ module Projects ...@@ -96,7 +96,7 @@ module Projects
end end
def update_tags(&block) def update_tags(&block)
old_tags = repository_tags_with_target.each_with_object({}) { |tag, tags| tags[tag.name] = tag } old_tags = repository_tags_with_target.index_by(&:name)
fetch_result = yield fetch_result = yield
return fetch_result unless fetch_result&.tags_changed return fetch_result unless fetch_result&.tags_changed
......
...@@ -293,7 +293,7 @@ module EE ...@@ -293,7 +293,7 @@ module EE
# returns a hash user_id -> LDAP identity in current LDAP provider # returns a hash user_id -> LDAP identity in current LDAP provider
def resolve_ldap_identities(for_users:) def resolve_ldap_identities(for_users:)
::Identity.for_user(for_users).with_provider(provider) ::Identity.for_user(for_users).with_provider(provider)
.to_h { |identity| [identity.user_id, identity] } .index_by(&:user_id)
end end
# returns a hash of normalized DN -> user for the current LDAP provider # returns a hash of normalized DN -> user for the current LDAP provider
......
...@@ -96,7 +96,7 @@ module Gitlab ...@@ -96,7 +96,7 @@ module Gitlab
end end
def labels_by_id def labels_by_id
@labels_by_id = labels.each_with_object({}) { |label, hash| hash[label.id] = label } @labels_by_id = labels.index_by(&:id)
end end
end end
end end
......
...@@ -32,7 +32,7 @@ module Gitlab ...@@ -32,7 +32,7 @@ module Gitlab
ids = group.map(&:db_id) ids = group.map(&:db_id)
records = klass.id_in(ids).preload_indexing_data records = klass.id_in(ids).preload_indexing_data
records_by_id = records.each_with_object({}) { |record, hash| hash[record.id] = record } records_by_id = records.index_by(&:id)
group.each do |ref| group.each do |ref|
ref.database_record = records_by_id[ref.db_id.to_i] ref.database_record = records_by_id[ref.db_id.to_i]
......
...@@ -19,9 +19,7 @@ module Gitlab ...@@ -19,9 +19,7 @@ module Gitlab
activerecord_relation(groups) activerecord_relation(groups)
) )
# A Hash mapping group IDs to their corresponding Group instances. # A Hash mapping group IDs to their corresponding Group instances.
groups_map = groups_and_ancestors.each_with_object({}) do |group, hash| groups_map = groups_and_ancestors.index_by(&:id)
hash[group.id] = group
end
all_plan_ids = Set.new all_plan_ids = Set.new
...@@ -45,9 +43,7 @@ module Gitlab ...@@ -45,9 +43,7 @@ module Gitlab
# Grab all the plans for all the Groups, using only a single query. # Grab all the plans for all the Groups, using only a single query.
plans = Plan plans = Plan
.where(id: all_plan_ids.to_a) .where(id: all_plan_ids.to_a)
.each_with_object({}) do |plan, hash| .index_by(&:id)
hash[plan.id] = plan
end
# Assign all the plans to the groups that have access to them. # Assign all the plans to the groups that have access to them.
groups.each do |group| groups.each do |group|
......
...@@ -46,7 +46,7 @@ module Gitlab ...@@ -46,7 +46,7 @@ module Gitlab
end end
def table_to_model_mapping def table_to_model_mapping
@table_to_model_mapping ||= models.each_with_object({}) { |model, h| h[model.table_name] = model } @table_to_model_mapping ||= models.index_by(&:table_name)
end end
def table_to_model(table_name) def table_to_model(table_name)
......
...@@ -63,7 +63,7 @@ module Gitlab ...@@ -63,7 +63,7 @@ module Gitlab
@repository @repository
.languages .languages
.first(MAX_LANGUAGES) .first(MAX_LANGUAGES)
.to_h { |l| [l[:label], l] } .index_by { |l| l[:label] }
end end
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment