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
3a52a62d
Commit
3a52a62d
authored
Nov 09, 2021
by
Dominic Bauer
Committed by
Gabriel Mazetto
Nov 09, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Rescue from network errors when querying Prometheus in the background
parent
2a01cce5
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
18 additions
and
36 deletions
+18
-36
lib/gitlab/prometheus/queries/validate_query.rb
lib/gitlab/prometheus/queries/validate_query.rb
+1
-1
lib/gitlab/prometheus_client.rb
lib/gitlab/prometheus_client.rb
+2
-6
spec/lib/gitlab/prometheus_client_spec.rb
spec/lib/gitlab/prometheus_client_spec.rb
+7
-29
spec/models/concerns/prometheus_adapter_spec.rb
spec/models/concerns/prometheus_adapter_spec.rb
+8
-0
No files found.
lib/gitlab/prometheus/queries/validate_query.rb
View file @
3a52a62d
...
@@ -7,7 +7,7 @@ module Gitlab
...
@@ -7,7 +7,7 @@ module Gitlab
def
query
(
query
)
def
query
(
query
)
client_query
(
query
)
client_query
(
query
)
{
valid:
true
}
{
valid:
true
}
rescue
Gitlab
::
PrometheusClient
::
QueryError
,
Gitlab
::
HTTP
::
BlockedUrl
Error
=>
ex
rescue
Gitlab
::
PrometheusClient
::
QueryError
,
Gitlab
::
PrometheusClient
::
Connection
Error
=>
ex
{
valid:
false
,
error:
ex
.
message
}
{
valid:
false
,
error:
ex
.
message
}
end
end
...
...
lib/gitlab/prometheus_client.rb
View file @
3a52a62d
...
@@ -151,12 +151,8 @@ module Gitlab
...
@@ -151,12 +151,8 @@ module Gitlab
def
get
(
path
,
args
)
def
get
(
path
,
args
)
Gitlab
::
HTTP
.
get
(
path
,
{
query:
args
}.
merge
(
http_options
)
)
Gitlab
::
HTTP
.
get
(
path
,
{
query:
args
}.
merge
(
http_options
)
)
rescue
SocketError
rescue
*
Gitlab
::
HTTP
::
HTTP_ERRORS
=>
e
raise
PrometheusClient
::
ConnectionError
,
"Can't connect to
#{
api_url
}
"
raise
PrometheusClient
::
ConnectionError
,
e
.
message
rescue
OpenSSL
::
SSL
::
SSLError
raise
PrometheusClient
::
ConnectionError
,
"
#{
api_url
}
contains invalid SSL data"
rescue
Errno
::
ECONNREFUSED
raise
PrometheusClient
::
ConnectionError
,
'Connection refused'
end
end
def
handle_management_api_response
(
response
)
def
handle_management_api_response
(
response
)
...
...
spec/lib/gitlab/prometheus_client_spec.rb
View file @
3a52a62d
...
@@ -107,36 +107,14 @@ RSpec.describe Gitlab::PrometheusClient do
...
@@ -107,36 +107,14 @@ RSpec.describe Gitlab::PrometheusClient do
let
(
:prometheus_url
)
{
"https://prometheus.invalid.example.com/api/v1/query?query=1"
}
let
(
:prometheus_url
)
{
"https://prometheus.invalid.example.com/api/v1/query?query=1"
}
shared_examples
'exceptions are raised'
do
shared_examples
'exceptions are raised'
do
it
'raises a Gitlab::PrometheusClient::ConnectionError error when a SocketError is rescued'
do
Gitlab
::
HTTP
::
HTTP_ERRORS
.
each
do
|
error
|
req_stub
=
stub_prometheus_request_with_exception
(
prometheus_url
,
SocketError
)
it
"raises a Gitlab::PrometheusClient::ConnectionError when a
#{
error
}
is rescued"
do
req_stub
=
stub_prometheus_request_with_exception
(
prometheus_url
,
error
.
new
)
expect
{
subject
}
expect
{
subject
}
.
to
raise_error
(
Gitlab
::
PrometheusClient
::
ConnectionError
,
"Can't connect to
#{
prometheus_url
}
"
)
.
to
raise_error
(
Gitlab
::
PrometheusClient
::
ConnectionError
,
kind_of
(
String
))
expect
(
req_stub
).
to
have_been_requested
expect
(
req_stub
).
to
have_been_requested
end
end
it
'raises a Gitlab::PrometheusClient::ConnectionError error when a SSLError is rescued'
do
req_stub
=
stub_prometheus_request_with_exception
(
prometheus_url
,
OpenSSL
::
SSL
::
SSLError
)
expect
{
subject
}
.
to
raise_error
(
Gitlab
::
PrometheusClient
::
ConnectionError
,
"
#{
prometheus_url
}
contains invalid SSL data"
)
expect
(
req_stub
).
to
have_been_requested
end
it
'raises a Gitlab::PrometheusClient::ConnectionError error when a Gitlab::HTTP::ResponseError is rescued'
do
req_stub
=
stub_prometheus_request_with_exception
(
prometheus_url
,
Gitlab
::
HTTP
::
ResponseError
)
expect
{
subject
}
.
to
raise_error
(
Gitlab
::
PrometheusClient
::
ConnectionError
,
"Network connection error"
)
expect
(
req_stub
).
to
have_been_requested
end
it
'raises a Gitlab::PrometheusClient::ConnectionError error when a Gitlab::HTTP::ResponseError with a code is rescued'
do
req_stub
=
stub_prometheus_request_with_exception
(
prometheus_url
,
Gitlab
::
HTTP
::
ResponseError
.
new
(
code:
400
))
expect
{
subject
}
.
to
raise_error
(
Gitlab
::
PrometheusClient
::
ConnectionError
,
"Network connection error"
)
expect
(
req_stub
).
to
have_been_requested
end
end
end
end
...
...
spec/models/concerns/prometheus_adapter_spec.rb
View file @
3a52a62d
...
@@ -165,6 +165,14 @@ RSpec.describe PrometheusAdapter, :use_clean_rails_memory_store_caching do
...
@@ -165,6 +165,14 @@ RSpec.describe PrometheusAdapter, :use_clean_rails_memory_store_caching do
it
{
is_expected
.
to
eq
(
success:
false
,
result:
%(#{status} - "QUERY FAILED!")
)
}
it
{
is_expected
.
to
eq
(
success:
false
,
result:
%(#{status} - "QUERY FAILED!")
)
}
end
end
end
end
context
"when client raises Gitlab::PrometheusClient::ConnectionError"
do
before
do
stub_any_prometheus_request
.
to_raise
(
Gitlab
::
PrometheusClient
::
ConnectionError
)
end
it
{
is_expected
.
to
include
(
success:
false
,
result:
kind_of
(
String
))
}
end
end
end
describe
'#build_query_args'
do
describe
'#build_query_args'
do
...
...
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