Commit c5256c8e authored by Linjie Zhang's avatar Linjie Zhang

Override sidekig_config method in JH repo

parent 836a2bb6
...@@ -49,14 +49,7 @@ module Gitlab ...@@ -49,14 +49,7 @@ module Gitlab
def config_queues def config_queues
@config_queues ||= begin @config_queues ||= begin
config = YAML.load_file(Rails.root.join(SIDEKIQ_QUEUES_PATH)) config = YAML.load_file(Rails.root.join(SIDEKIQ_QUEUES_PATH))
queues = config[:queues].map(&:first) config[:queues].map(&:first)
if Gitlab.jh? && File.exist?(JH_SIDEKIQ_QUEUES_PATH)
jh_config = YAML.load_file(JH_SIDEKIQ_QUEUES_PATH)
queues += jh_config[:queues].map(&:first)
end
queues
end end
end end
...@@ -105,32 +98,32 @@ module Gitlab ...@@ -105,32 +98,32 @@ module Gitlab
Gitlab.jh? && File.exist?(JH_QUEUE_CONFIG_PATH) && jh_workers != YAML.load_file(JH_QUEUE_CONFIG_PATH) Gitlab.jh? && File.exist?(JH_QUEUE_CONFIG_PATH) && jh_workers != YAML.load_file(JH_QUEUE_CONFIG_PATH)
end end
def queues_for_sidekiq_queues_yml(jh: false) def queues_for_sidekiq_queues_yml
namespaces_with_equal_weights = namespaces_with_equal_weights =
workers workers
.select { |worker| worker.jh? == jh } .reject { |worker| worker.jh? }
.group_by(&:queue_namespace) .group_by(&:queue_namespace)
.map(&:last) .map(&:last)
.select { |workers| workers.map(&:get_weight).uniq.count == 1 } .select { |workers| workers.map(&:get_weight).uniq.count == 1 }
.map(&:first) .map(&:first)
namespaces = namespaces_with_equal_weights.map(&:queue_namespace).to_set namespaces = namespaces_with_equal_weights.map(&:queue_namespace).to_set
remaining_queues = workers.select { |worker| worker.jh? == jh }.reject { |worker| namespaces.include?(worker.queue_namespace) } remaining_queues = workers.reject { |worker| worker.jh? }.reject { |worker| namespaces.include?(worker.queue_namespace) }
(namespaces_with_equal_weights.map(&:namespace_and_weight) + (namespaces_with_equal_weights.map(&:namespace_and_weight) +
remaining_queues.map(&:queue_and_weight)).sort remaining_queues.map(&:queue_and_weight)).sort
end end
# Override in JH repo
def jh_queues_for_sidekiq_queues_yml
[]
end
# YAML.load_file is OK here as we control the file contents # YAML.load_file is OK here as we control the file contents
def sidekiq_queues_yml_outdated? def sidekiq_queues_yml_outdated?
config_queues = YAML.load_file(SIDEKIQ_QUEUES_PATH)[:queues] config_queues = YAML.load_file(SIDEKIQ_QUEUES_PATH)[:queues]
if Gitlab.jh? && File.exist?(JH_SIDEKIQ_QUEUES_PATH) queues_for_sidekiq_queues_yml != config_queues
jh_config_queues = YAML.load_file(JH_SIDEKIQ_QUEUES_PATH)[:queues]
queues_for_sidekiq_queues_yml != config_queues || queues_for_sidekiq_queues_yml(jh: true) != jh_config_queues
else
queues_for_sidekiq_queues_yml != config_queues
end
end end
# Returns a hash of worker class name => mapped queue name # Returns a hash of worker class name => mapped queue name
...@@ -168,3 +161,5 @@ module Gitlab ...@@ -168,3 +161,5 @@ module Gitlab
end end
end end
end end
Gitlab::SidekiqConfig.prepend_mod
...@@ -102,8 +102,7 @@ namespace :gitlab do ...@@ -102,8 +102,7 @@ namespace :gitlab do
write_yaml(Gitlab::SidekiqConfig::SIDEKIQ_QUEUES_PATH, banner, queues: queues_and_weights) write_yaml(Gitlab::SidekiqConfig::SIDEKIQ_QUEUES_PATH, banner, queues: queues_and_weights)
if Gitlab.jh? if Gitlab.jh?
jh_queues_and_weights = Gitlab::SidekiqConfig.queues_for_sidekiq_queues_yml(jh: true) write_yaml(Gitlab::SidekiqConfig::JH_SIDEKIQ_QUEUES_PATH, banner, queues: Gitlab::SidekiqConfig.jh_queues_for_sidekiq_queues_yml)
write_yaml(Gitlab::SidekiqConfig::JH_SIDEKIQ_QUEUES_PATH, banner, queues: jh_queues_and_weights)
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