Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
37b6b9c6
Commit
37b6b9c6
authored
May 09, 2021
by
Hordur Freyr Yngvason
Committed by
Thong Kuah
May 09, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Keep new Prometheus cluster integration in sync with app
parent
0bad4de1
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
183 additions
and
93 deletions
+183
-93
app/models/clusters/applications/prometheus.rb
app/models/clusters/applications/prometheus.rb
+4
-22
app/models/clusters/integrations/prometheus.rb
app/models/clusters/integrations/prometheus.rb
+38
-0
app/services/clusters/applications/prometheus_config_service.rb
...rvices/clusters/applications/prometheus_config_service.rb
+0
-2
app/services/projects/prometheus/alerts/notify_service.rb
app/services/projects/prometheus/alerts/notify_service.rb
+10
-8
changelogs/unreleased/add-alert-manager-token-to-prometheus-cluster-integration.yml
...alert-manager-token-to-prometheus-cluster-integration.yml
+5
-0
db/migrate/20210430034712_add_alert_manager_token_to_clusters_integration_prometheus.rb
...alert_manager_token_to_clusters_integration_prometheus.rb
+10
-0
db/schema_migrations/20210430034712
db/schema_migrations/20210430034712
+1
-0
db/structure.sql
db/structure.sql
+3
-1
lib/gitlab/prometheus/adapter.rb
lib/gitlab/prometheus/adapter.rb
+3
-5
spec/deprecation_toolkit_env.rb
spec/deprecation_toolkit_env.rb
+1
-0
spec/lib/gitlab/prometheus/adapter_spec.rb
spec/lib/gitlab/prometheus/adapter_spec.rb
+2
-2
spec/models/clusters/applications/prometheus_spec.rb
spec/models/clusters/applications/prometheus_spec.rb
+15
-52
spec/models/clusters/integrations/prometheus_spec.rb
spec/models/clusters/integrations/prometheus_spec.rb
+56
-0
spec/services/projects/prometheus/alerts/notify_service_spec.rb
...ervices/projects/prometheus/alerts/notify_service_spec.rb
+35
-1
No files found.
app/models/clusters/applications/prometheus.rb
View file @
37b6b9c6
...
@@ -25,18 +25,15 @@ module Clusters
...
@@ -25,18 +25,15 @@ module Clusters
key:
Settings
.
attr_encrypted_db_key_base_32
,
key:
Settings
.
attr_encrypted_db_key_base_32
,
algorithm:
'aes-256-gcm'
algorithm:
'aes-256-gcm'
default_value_for
(
:alert_manager_token
)
{
SecureRandom
.
hex
}
after_destroy
do
after_destroy
do
run_after_commit
do
cluster
.
find_or_build_integration_prometheus
.
destroy
disable_prometheus_integration
end
end
end
state_machine
:status
do
state_machine
:status
do
after_transition
any
=>
[
:installed
,
:externally_installed
]
do
|
application
|
after_transition
any
=>
[
:installed
,
:externally_installed
]
do
|
application
|
application
.
run_after_commit
do
application
.
cluster
.
find_or_build_integration_prometheus
.
update
(
enabled:
true
,
alert_manager_token:
application
.
alert_manager_token
)
Clusters
::
Applications
::
ActivateServiceWorker
.
perform_async
(
application
.
cluster_id
,
::
PrometheusService
.
to_param
)
# rubocop:disable CodeReuse/ServiceClass
end
end
end
after_transition
any
=>
:updating
do
|
application
|
after_transition
any
=>
:updating
do
|
application
|
...
@@ -103,23 +100,8 @@ module Clusters
...
@@ -103,23 +100,8 @@ module Clusters
files
.
merge
(
'values.yaml'
:
replaced_values
)
files
.
merge
(
'values.yaml'
:
replaced_values
)
end
end
def
generate_alert_manager_token!
unless
alert_manager_token
.
present?
update!
(
alert_manager_token:
generate_token
)
end
end
private
private
def
generate_token
SecureRandom
.
hex
end
def
disable_prometheus_integration
::
Clusters
::
Applications
::
DeactivateServiceWorker
.
perform_async
(
cluster_id
,
::
PrometheusService
.
to_param
)
# rubocop:disable CodeReuse/ServiceClass
end
def
install_knative_metrics
def
install_knative_metrics
return
[]
unless
cluster
.
application_knative_available?
return
[]
unless
cluster
.
application_knative_available?
...
...
app/models/clusters/integrations/prometheus.rb
View file @
37b6b9c6
...
@@ -4,6 +4,7 @@ module Clusters
...
@@ -4,6 +4,7 @@ module Clusters
module
Integrations
module
Integrations
class
Prometheus
<
ApplicationRecord
class
Prometheus
<
ApplicationRecord
include
::
Clusters
::
Concerns
::
PrometheusClient
include
::
Clusters
::
Concerns
::
PrometheusClient
include
AfterCommitQueue
self
.
table_name
=
'clusters_integration_prometheus'
self
.
table_name
=
'clusters_integration_prometheus'
self
.
primary_key
=
:cluster_id
self
.
primary_key
=
:cluster_id
...
@@ -13,9 +14,46 @@ module Clusters
...
@@ -13,9 +14,46 @@ module Clusters
validates
:cluster
,
presence:
true
validates
:cluster
,
presence:
true
validates
:enabled
,
inclusion:
{
in:
[
true
,
false
]
}
validates
:enabled
,
inclusion:
{
in:
[
true
,
false
]
}
attr_encrypted
:alert_manager_token
,
mode: :per_attribute_iv
,
key:
Settings
.
attr_encrypted_db_key_base_32
,
algorithm:
'aes-256-gcm'
default_value_for
(
:alert_manager_token
)
{
SecureRandom
.
hex
}
after_destroy
do
run_after_commit
do
deactivate_project_services
end
end
after_save
do
next
unless
enabled_before_last_save
!=
enabled
run_after_commit
do
if
enabled
activate_project_services
else
deactivate_project_services
end
end
end
def
available?
def
available?
enabled?
enabled?
end
end
private
def
activate_project_services
::
Clusters
::
Applications
::
ActivateServiceWorker
.
perform_async
(
cluster_id
,
::
PrometheusService
.
to_param
)
# rubocop:disable CodeReuse/ServiceClass
end
def
deactivate_project_services
::
Clusters
::
Applications
::
DeactivateServiceWorker
.
perform_async
(
cluster_id
,
::
PrometheusService
.
to_param
)
# rubocop:disable CodeReuse/ServiceClass
end
end
end
end
end
end
end
app/services/clusters/applications/prometheus_config_service.rb
View file @
37b6b9c6
...
@@ -96,8 +96,6 @@ module Clusters
...
@@ -96,8 +96,6 @@ module Clusters
end
end
def
alert_manager_token
def
alert_manager_token
app
.
generate_alert_manager_token!
app
.
alert_manager_token
app
.
alert_manager_token
end
end
...
...
app/services/projects/prometheus/alerts/notify_service.rb
View file @
37b6b9c6
...
@@ -63,7 +63,7 @@ module Projects
...
@@ -63,7 +63,7 @@ module Projects
def
valid_alert_manager_token?
(
token
,
integration
)
def
valid_alert_manager_token?
(
token
,
integration
)
valid_for_manual?
(
token
)
||
valid_for_manual?
(
token
)
||
valid_for_alerts_endpoint?
(
token
,
integration
)
||
valid_for_alerts_endpoint?
(
token
,
integration
)
||
valid_for_
managed
?
(
token
)
valid_for_
cluster
?
(
token
)
end
end
def
valid_for_manual?
(
token
)
def
valid_for_manual?
(
token
)
...
@@ -83,18 +83,20 @@ module Projects
...
@@ -83,18 +83,20 @@ module Projects
compare_token
(
token
,
integration
.
token
)
compare_token
(
token
,
integration
.
token
)
end
end
def
valid_for_managed?
(
token
)
def
valid_for_cluster?
(
token
)
prometheus_application
=
available_prometheus_application
(
project
)
cluster_integration
=
find_cluster_integration
(
project
)
return
false
unless
prometheus_application
return
false
unless
cluster_integration
cluster_integration_token
=
cluster_integration
.
alert_manager_token
if
token
if
token
compare_token
(
token
,
prometheus_application
.
alert_manager
_token
)
compare_token
(
token
,
cluster_integration
_token
)
else
else
prometheus_application
.
alert_manager
_token
.
nil?
cluster_integration
_token
.
nil?
end
end
end
end
def
available_prometheus_applic
ation
(
project
)
def
find_cluster_integr
ation
(
project
)
alert_id
=
gitlab_alert_id
alert_id
=
gitlab_alert_id
return
unless
alert_id
return
unless
alert_id
...
@@ -105,7 +107,7 @@ module Projects
...
@@ -105,7 +107,7 @@ module Projects
return
unless
cluster
&
.
enabled?
return
unless
cluster
&
.
enabled?
return
unless
cluster
.
application_prometheus_available?
return
unless
cluster
.
application_prometheus_available?
cluster
.
application_prometheus
cluster
.
application_prometheus
||
cluster
.
integration_prometheus
end
end
def
find_alert
(
project
,
metric
)
def
find_alert
(
project
,
metric
)
...
...
changelogs/unreleased/add-alert-manager-token-to-prometheus-cluster-integration.yml
0 → 100644
View file @
37b6b9c6
---
title
:
Keep new prometheus cluster integration in sync with old cluster application
merge_request
:
60877
author
:
type
:
changed
db/migrate/20210430034712_add_alert_manager_token_to_clusters_integration_prometheus.rb
0 → 100644
View file @
37b6b9c6
# frozen_string_literal: true
class
AddAlertManagerTokenToClustersIntegrationPrometheus
<
ActiveRecord
::
Migration
[
6.0
]
def
change
change_table
:clusters_integration_prometheus
do
|
t
|
t
.
text
:encrypted_alert_manager_token
t
.
text
:encrypted_alert_manager_token_iv
end
end
end
db/schema_migrations/20210430034712
0 → 100644
View file @
37b6b9c6
6b7436d7712e31ca116204d37270435ccc059ca75a128750e5c39fdddfa020e3
\ No newline at end of file
db/structure.sql
View file @
37b6b9c6
...
@@ -11700,7 +11700,9 @@ CREATE TABLE clusters_integration_prometheus (
...
@@ -11700,7 +11700,9 @@ CREATE TABLE clusters_integration_prometheus (
created_at timestamp with time zone NOT NULL,
created_at timestamp with time zone NOT NULL,
updated_at timestamp with time zone NOT NULL,
updated_at timestamp with time zone NOT NULL,
cluster_id bigint NOT NULL,
cluster_id bigint NOT NULL,
enabled boolean DEFAULT false NOT NULL
enabled boolean DEFAULT false NOT NULL,
encrypted_alert_manager_token text,
encrypted_alert_manager_token_iv text
);
);
CREATE TABLE clusters_kubernetes_namespaces (
CREATE TABLE clusters_kubernetes_namespaces (
lib/gitlab/prometheus/adapter.rb
View file @
37b6b9c6
...
@@ -19,13 +19,11 @@ module Gitlab
...
@@ -19,13 +19,11 @@ module Gitlab
end
end
def
cluster_prometheus_adapter
def
cluster_prometheus_adapter
if
cluster
&
.
integration_prometheus
return
cluster
.
integration_prometheus
end
application
=
cluster
&
.
application_prometheus
application
=
cluster
&
.
application_prometheus
return
application
if
application
&
.
available?
application
if
application
&
.
available?
integration
=
cluster
&
.
integration_prometheus
integration
if
integration
&
.
available?
end
end
private
private
...
...
spec/deprecation_toolkit_env.rb
View file @
37b6b9c6
...
@@ -59,6 +59,7 @@ module DeprecationToolkitEnv
...
@@ -59,6 +59,7 @@ module DeprecationToolkitEnv
activesupport-6.0.3.6/lib/active_support/cache.rb
activesupport-6.0.3.6/lib/active_support/cache.rb
activerecord-6.0.3.6/lib/active_record/relation.rb
activerecord-6.0.3.6/lib/active_record/relation.rb
asciidoctor-2.0.12/lib/asciidoctor/extensions.rb
asciidoctor-2.0.12/lib/asciidoctor/extensions.rb
attr_encrypted-3.1.0/lib/attr_encrypted/adapters/active_record.rb
]
]
end
end
...
...
spec/lib/gitlab/prometheus/adapter_spec.rb
View file @
37b6b9c6
...
@@ -58,8 +58,8 @@ RSpec.describe Gitlab::Prometheus::Adapter do
...
@@ -58,8 +58,8 @@ RSpec.describe Gitlab::Prometheus::Adapter do
context
'with cluster with prometheus integration'
do
context
'with cluster with prometheus integration'
do
let!
(
:prometheus_integration
)
{
create
(
:clusters_integrations_prometheus
,
cluster:
cluster
)
}
let!
(
:prometheus_integration
)
{
create
(
:clusters_integrations_prometheus
,
cluster:
cluster
)
}
it
'returns the
integration instead
'
do
it
'returns the
application
'
do
expect
(
subject
.
prometheus_adapter
).
to
eq
(
prometheus
_integration
)
expect
(
subject
.
prometheus_adapter
).
to
eq
(
prometheus
)
end
end
end
end
end
end
...
...
spec/models/clusters/applications/prometheus_spec.rb
View file @
37b6b9c6
...
@@ -13,16 +13,13 @@ RSpec.describe Clusters::Applications::Prometheus do
...
@@ -13,16 +13,13 @@ RSpec.describe Clusters::Applications::Prometheus do
include_examples
'cluster application initial status specs'
include_examples
'cluster application initial status specs'
describe
'after_destroy'
do
describe
'after_destroy'
do
context
'cluster type is project'
do
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:application
)
{
create
(
:clusters_applications_prometheus
,
:installed
,
cluster:
cluster
)
}
let
(
:application
)
{
create
(
:clusters_applications_prometheus
,
:installed
,
cluster:
cluster
)
}
it
'deactivates prometheus_service after destroy'
do
it
'disables the corresponding integration'
do
expect
(
Clusters
::
Applications
::
DeactivateServiceWorker
)
application
.
destroy!
.
to
receive
(
:perform_async
).
with
(
cluster
.
id
,
'prometheus'
)
application
.
destroy!
expect
(
cluster
.
integration_prometheus
).
not_to
be_enabled
end
end
end
end
end
...
@@ -31,11 +28,10 @@ RSpec.describe Clusters::Applications::Prometheus do
...
@@ -31,11 +28,10 @@ RSpec.describe Clusters::Applications::Prometheus do
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:application
)
{
create
(
:clusters_applications_prometheus
,
:installing
,
cluster:
cluster
)
}
let
(
:application
)
{
create
(
:clusters_applications_prometheus
,
:installing
,
cluster:
cluster
)
}
it
'schedules post installation job'
do
it
'enables the corresponding integration'
do
expect
(
Clusters
::
Applications
::
ActivateServiceWorker
)
.
to
receive
(
:perform_async
).
with
(
cluster
.
id
,
'prometheus'
)
application
.
make_installed
application
.
make_installed
expect
(
cluster
.
integration_prometheus
).
to
be_enabled
end
end
end
end
...
@@ -44,11 +40,10 @@ RSpec.describe Clusters::Applications::Prometheus do
...
@@ -44,11 +40,10 @@ RSpec.describe Clusters::Applications::Prometheus do
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:application
)
{
create
(
:clusters_applications_prometheus
,
:installing
,
cluster:
cluster
)
}
let
(
:application
)
{
create
(
:clusters_applications_prometheus
,
:installing
,
cluster:
cluster
)
}
it
'schedules post installation job'
do
it
'enables the corresponding integration'
do
expect
(
Clusters
::
Applications
::
ActivateServiceWorker
)
.
to
receive
(
:perform_async
).
with
(
cluster
.
id
,
'prometheus'
)
application
.
make_externally_installed!
application
.
make_externally_installed!
expect
(
cluster
.
integration_prometheus
).
to
be_enabled
end
end
end
end
...
@@ -338,42 +333,10 @@ RSpec.describe Clusters::Applications::Prometheus do
...
@@ -338,42 +333,10 @@ RSpec.describe Clusters::Applications::Prometheus do
describe
'alert manager token'
do
describe
'alert manager token'
do
subject
{
create
(
:clusters_applications_prometheus
)
}
subject
{
create
(
:clusters_applications_prometheus
)
}
context
'when not set'
do
it
'is autogenerated on creation'
do
it
'is empty by default'
do
expect
(
subject
.
alert_manager_token
).
to
match
(
/\A\h{32}\z/
)
expect
(
subject
.
alert_manager_token
).
to
be_nil
expect
(
subject
.
encrypted_alert_manager_token
).
not_to
be_nil
expect
(
subject
.
encrypted_alert_manager_token
).
to
be_nil
expect
(
subject
.
encrypted_alert_manager_token_iv
).
not_to
be_nil
expect
(
subject
.
encrypted_alert_manager_token_iv
).
to
be_nil
end
describe
'#generate_alert_manager_token!'
do
it
'generates a token'
do
subject
.
generate_alert_manager_token!
expect
(
subject
.
alert_manager_token
).
to
match
(
/\A\h{32}\z/
)
end
end
end
context
'when set'
do
let
(
:token
)
{
SecureRandom
.
hex
}
before
do
subject
.
update!
(
alert_manager_token:
token
)
end
it
'reads the token'
do
expect
(
subject
.
alert_manager_token
).
to
eq
(
token
)
expect
(
subject
.
encrypted_alert_manager_token
).
not_to
be_nil
expect
(
subject
.
encrypted_alert_manager_token_iv
).
not_to
be_nil
end
describe
'#generate_alert_manager_token!'
do
it
'does not re-generate the token'
do
subject
.
generate_alert_manager_token!
expect
(
subject
.
alert_manager_token
).
to
eq
(
token
)
end
end
end
end
end
end
end
end
spec/models/clusters/integrations/prometheus_spec.rb
View file @
37b6b9c6
...
@@ -15,6 +15,62 @@ RSpec.describe Clusters::Integrations::Prometheus do
...
@@ -15,6 +15,62 @@ RSpec.describe Clusters::Integrations::Prometheus do
it
{
is_expected
.
not_to
allow_value
(
nil
).
for
(
:enabled
)
}
it
{
is_expected
.
not_to
allow_value
(
nil
).
for
(
:enabled
)
}
end
end
describe
'after_destroy'
do
subject
(
:integration
)
{
create
(
:clusters_integrations_prometheus
,
cluster:
cluster
,
enabled:
true
)
}
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
it
'deactivates prometheus_service'
do
expect
(
Clusters
::
Applications
::
DeactivateServiceWorker
)
.
to
receive
(
:perform_async
).
with
(
cluster
.
id
,
'prometheus'
)
integration
.
destroy!
end
end
describe
'after_save'
do
subject
(
:integration
)
{
create
(
:clusters_integrations_prometheus
,
cluster:
cluster
,
enabled:
enabled
)
}
let
(
:cluster
)
{
create
(
:cluster
,
:with_installed_helm
)
}
let
(
:enabled
)
{
true
}
context
'when no change to enabled status'
do
it
'does not touch project services'
do
integration
# ensure integration exists before we set the expectations
expect
(
Clusters
::
Applications
::
DeactivateServiceWorker
)
.
not_to
receive
(
:perform_async
)
expect
(
Clusters
::
Applications
::
ActivateServiceWorker
)
.
not_to
receive
(
:perform_async
)
integration
.
update!
(
enabled:
enabled
)
end
end
context
'when enabling'
do
let
(
:enabled
)
{
false
}
it
'deactivates prometheus_service'
do
expect
(
Clusters
::
Applications
::
ActivateServiceWorker
)
.
to
receive
(
:perform_async
).
with
(
cluster
.
id
,
'prometheus'
)
integration
.
update!
(
enabled:
true
)
end
end
context
'when disabling'
do
let
(
:enabled
)
{
true
}
it
'activates prometheus_service'
do
expect
(
Clusters
::
Applications
::
DeactivateServiceWorker
)
.
to
receive
(
:perform_async
).
with
(
cluster
.
id
,
'prometheus'
)
integration
.
update!
(
enabled:
false
)
end
end
end
describe
'#prometheus_client'
do
describe
'#prometheus_client'
do
include_examples
'#prometheus_client shared'
do
include_examples
'#prometheus_client shared'
do
let
(
:factory
)
{
:clusters_integrations_prometheus
}
let
(
:factory
)
{
:clusters_integrations_prometheus
}
...
...
spec/services/projects/prometheus/alerts/notify_service_spec.rb
View file @
37b6b9c6
...
@@ -62,7 +62,7 @@ RSpec.describe Projects::Prometheus::Alerts::NotifyService do
...
@@ -62,7 +62,7 @@ RSpec.describe Projects::Prometheus::Alerts::NotifyService do
end
end
end
end
context
'with project specific cluster'
do
context
'with project specific cluster
using prometheus application
'
do
where
(
:cluster_enabled
,
:status
,
:configured_token
,
:token_input
,
:result
)
do
where
(
:cluster_enabled
,
:status
,
:configured_token
,
:token_input
,
:result
)
do
true
|
:installed
|
token
|
token
|
:success
true
|
:installed
|
token
|
token
|
:success
true
|
:installed
|
nil
|
nil
|
:success
true
|
:installed
|
nil
|
nil
|
:success
...
@@ -97,6 +97,40 @@ RSpec.describe Projects::Prometheus::Alerts::NotifyService do
...
@@ -97,6 +97,40 @@ RSpec.describe Projects::Prometheus::Alerts::NotifyService do
end
end
end
end
context
'with project specific cluster using prometheus integration'
do
where
(
:cluster_enabled
,
:integration_enabled
,
:configured_token
,
:token_input
,
:result
)
do
true
|
true
|
token
|
token
|
:success
true
|
true
|
nil
|
nil
|
:success
true
|
true
|
token
|
'x'
|
:failure
true
|
true
|
token
|
nil
|
:failure
true
|
false
|
token
|
token
|
:failure
false
|
true
|
token
|
token
|
:failure
false
|
nil
|
nil
|
token
|
:failure
end
with_them
do
before
do
cluster
.
update!
(
enabled:
cluster_enabled
)
unless
integration_enabled
.
nil?
create
(
:clusters_integrations_prometheus
,
cluster:
cluster
,
enabled:
integration_enabled
,
alert_manager_token:
configured_token
)
end
end
case
result
=
params
[
:result
]
when
:success
include_examples
'processes one firing and one resolved prometheus alerts'
when
:failure
it_behaves_like
'alerts service responds with an error and takes no actions'
,
:unauthorized
else
raise
"invalid result:
#{
result
.
inspect
}
"
end
end
end
context
'without project specific cluster'
do
context
'without project specific cluster'
do
let_it_be
(
:cluster
)
{
create
(
:cluster
,
enabled:
true
)
}
let_it_be
(
:cluster
)
{
create
(
:cluster
,
enabled:
true
)
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment