debian-mirror-gitlab/lib/gitlab/git/rugged_impl/use_rugged.rb

40 lines
1.2 KiB
Ruby
Raw Normal View History

2019-09-30 21:07:59 +05:30
# frozen_string_literal: true
module Gitlab
module Git
module RuggedImpl
module UseRugged
def use_rugged?(repo, feature_key)
feature = Feature.get(feature_key)
return feature.enabled? if Feature.persisted?(feature)
Gitlab::GitalyClient.can_use_disk?(repo.storage)
end
2019-10-12 21:52:04 +05:30
def execute_rugged_call(method_name, *args)
2019-09-30 21:07:59 +05:30
Gitlab::GitalyClient::StorageSettings.allow_disk_access do
2019-10-12 21:52:04 +05:30
start = Gitlab::Metrics::System.monotonic_time
result = send(method_name, *args) # rubocop:disable GitlabSecurity/PublicSend
duration = Gitlab::Metrics::System.monotonic_time - start
if Gitlab::RuggedInstrumentation.active?
Gitlab::RuggedInstrumentation.increment_query_count
Gitlab::RuggedInstrumentation.query_time += duration
Gitlab::RuggedInstrumentation.add_call_details(
feature: method_name,
args: args,
duration: duration,
backtrace: Gitlab::Profiler.clean_backtrace(caller))
end
result
2019-09-30 21:07:59 +05:30
end
end
end
end
end
end