Commit bb353382 authored by Thong Kuah's avatar Thong Kuah

Refactor Prometheus Adapter to take in cluster

This allows us the choice not to call project.deployment_platform which
could be incorrect if that is called after the deployment has been done.
parent 43323f0c
...@@ -23,7 +23,7 @@ module Projects ...@@ -23,7 +23,7 @@ module Projects
private private
def prometheus_adapter def prometheus_adapter
@prometheus_adapter ||= ::Prometheus::AdapterService.new(project).prometheus_adapter @prometheus_adapter ||= ::Prometheus::AdapterService.new(project, project.deployment_platform&.cluster).prometheus_adapter
end end
def require_prometheus_metrics! def require_prometheus_metrics!
......
...@@ -223,7 +223,7 @@ class Environment < ApplicationRecord ...@@ -223,7 +223,7 @@ class Environment < ApplicationRecord
# rubocop: disable CodeReuse/ServiceClass # rubocop: disable CodeReuse/ServiceClass
def prometheus_adapter def prometheus_adapter
@prometheus_adapter ||= Prometheus::AdapterService.new(project, deployment_platform).prometheus_adapter @prometheus_adapter ||= Prometheus::AdapterService.new(project, deployment_platform&.cluster).prometheus_adapter
end end
# rubocop: enable CodeReuse/ServiceClass # rubocop: enable CodeReuse/ServiceClass
......
...@@ -2,18 +2,13 @@ ...@@ -2,18 +2,13 @@
module Prometheus module Prometheus
class AdapterService class AdapterService
def initialize(project, deployment_platform = nil) attr_reader :project, :cluster
@project = project
@deployment_platform = if deployment_platform def initialize(project, cluster)
deployment_platform @project = project
else @cluster = cluster
project.deployment_platform
end
end end
attr_reader :deployment_platform, :project
def prometheus_adapter def prometheus_adapter
@prometheus_adapter ||= if service_prometheus_adapter.can_query? @prometheus_adapter ||= if service_prometheus_adapter.can_query?
service_prometheus_adapter service_prometheus_adapter
...@@ -27,7 +22,7 @@ module Prometheus ...@@ -27,7 +22,7 @@ module Prometheus
end end
def cluster_prometheus_adapter def cluster_prometheus_adapter
application = deployment_platform&.cluster&.application_prometheus application = cluster&.application_prometheus
application if application&.available? application if application&.available?
end end
......
...@@ -81,7 +81,7 @@ module EE ...@@ -81,7 +81,7 @@ module EE
end end
def cluster_prometheus_adapter def cluster_prometheus_adapter
@cluster_prometheus_adapter ||= Prometheus::AdapterService.new(project, deployment_platform).cluster_prometheus_adapter @cluster_prometheus_adapter ||= Prometheus::AdapterService.new(project, deployment_platform&.cluster).cluster_prometheus_adapter
end end
def protected? def protected?
......
...@@ -3,13 +3,12 @@ ...@@ -3,13 +3,12 @@
require 'spec_helper' require 'spec_helper'
describe Prometheus::AdapterService do describe Prometheus::AdapterService do
let(:project) { create(:project) } let_it_be(:project) { create(:project) }
let_it_be(:cluster, reload: true) { create(:cluster, :provided_by_user, environment_scope: '*', projects: [project]) }
subject { described_class.new(project) } subject { described_class.new(project, cluster) }
describe '#prometheus_adapter' do describe '#prometheus_adapter' do
let(:cluster) { create(:cluster, :provided_by_user, environment_scope: '*', projects: [project]) }
context 'prometheus service can execute queries' do context 'prometheus service can execute queries' do
let(:prometheus_service) { double(:prometheus_service, can_query?: true) } let(:prometheus_service) { double(:prometheus_service, can_query?: true) }
......
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