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
4dfaba0b
Commit
4dfaba0b
authored
Sep 17, 2020
by
Qingyu Zhao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor topology spec
parent
4f028edc
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
21 additions
and
73 deletions
+21
-73
spec/lib/gitlab/usage_data/topology_spec.rb
spec/lib/gitlab/usage_data/topology_spec.rb
+19
-62
spec/support/helpers/usage_data_helpers.rb
spec/support/helpers/usage_data_helpers.rb
+2
-11
No files found.
spec/lib/gitlab/usage_data/topology_spec.rb
View file @
4dfaba0b
...
@@ -6,7 +6,11 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -6,7 +6,11 @@ RSpec.describe Gitlab::UsageData::Topology do
include
UsageDataHelpers
include
UsageDataHelpers
describe
'#topology_usage_data'
do
describe
'#topology_usage_data'
do
subject
{
described_class
.
new
.
topology_usage_data
}
subject
{
topology
.
topology_usage_data
}
let
(
:topology
)
{
described_class
.
new
}
let
(
:prometheus_client
)
{
Gitlab
::
PrometheusClient
.
new
(
'http://localhost:9090'
)
}
let
(
:fallback
)
{
{}
}
before
do
before
do
# this pins down time shifts when benchmarking durations
# this pins down time shifts when benchmarking durations
...
@@ -16,8 +20,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -16,8 +20,7 @@ RSpec.describe Gitlab::UsageData::Topology do
shared_examples
'query topology data from Prometheus'
do
shared_examples
'query topology data from Prometheus'
do
context
'tracking node metrics'
do
context
'tracking node metrics'
do
it
'contains node level metrics for each instance'
do
it
'contains node level metrics for each instance'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive_app_request_volume_query
,
receive_app_request_volume_query
,
receive_query_apdex_ratio_query
,
receive_query_apdex_ratio_query
,
receive_node_memory_query
,
receive_node_memory_query
,
...
@@ -103,8 +106,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -103,8 +106,7 @@ RSpec.describe Gitlab::UsageData::Topology do
context
'and some node memory metrics are missing'
do
context
'and some node memory metrics are missing'
do
it
'removes the respective entries and includes the failures'
do
it
'removes the respective entries and includes the failures'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive_app_request_volume_query
(
result:
[]),
receive_app_request_volume_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_node_memory_query
(
result:
[]),
receive_node_memory_query
(
result:
[]),
...
@@ -244,8 +246,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -244,8 +246,7 @@ RSpec.describe Gitlab::UsageData::Topology do
end
end
it
'normalizes equivalent instance values and maps them to the same node'
do
it
'normalizes equivalent instance values and maps them to the same node'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive_app_request_volume_query
(
result:
[]),
receive_app_request_volume_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_node_memory_query
(
result:
node_memory_response
),
receive_node_memory_query
(
result:
node_memory_response
),
...
@@ -311,8 +312,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -311,8 +312,7 @@ RSpec.describe Gitlab::UsageData::Topology do
context
'and node metrics are missing but service metrics exist'
do
context
'and node metrics are missing but service metrics exist'
do
it
'still reports service metrics'
do
it
'still reports service metrics'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive_app_request_volume_query
(
result:
[]),
receive_app_request_volume_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_node_memory_query
(
result:
[]),
receive_node_memory_query
(
result:
[]),
...
@@ -387,8 +387,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -387,8 +387,7 @@ RSpec.describe Gitlab::UsageData::Topology do
end
end
it
'filters out unknown service data and reports the unknown services as a failure'
do
it
'filters out unknown service data and reports the unknown services as a failure'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive_app_request_volume_query
(
result:
[]),
receive_app_request_volume_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_query_apdex_ratio_query
(
result:
[]),
receive_node_memory_query
(
result:
[]),
receive_node_memory_query
(
result:
[]),
...
@@ -413,8 +412,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -413,8 +412,7 @@ RSpec.describe Gitlab::UsageData::Topology do
context
'and an error is raised when querying Prometheus'
do
context
'and an error is raised when querying Prometheus'
do
context
'without timeout failures'
do
context
'without timeout failures'
do
it
'returns empty result and executes subsequent queries as usual'
do
it
'returns empty result and executes subsequent queries as usual'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive
(
:query
).
at_least
(
:once
).
and_raise
(
Gitlab
::
PrometheusClient
::
UnexpectedResponseError
)
receive
(
:query
).
at_least
(
:once
).
and_raise
(
Gitlab
::
PrometheusClient
::
UnexpectedResponseError
)
)
)
...
@@ -446,8 +444,7 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -446,8 +444,7 @@ RSpec.describe Gitlab::UsageData::Topology do
with_them
do
with_them
do
it
'returns empty result and cancelled subsequent queries'
do
it
'returns empty result and cancelled subsequent queries'
do
expect_prometheus_api_to
(
expect_prometheus_client_to
(
receive_ready_check_query
,
receive
(
:query
).
and_raise
(
exception
)
receive
(
:query
).
and_raise
(
exception
)
)
)
...
@@ -484,65 +481,25 @@ RSpec.describe Gitlab::UsageData::Topology do
...
@@ -484,65 +481,25 @@ RSpec.describe Gitlab::UsageData::Topology do
end
end
end
end
shared_examples
'try to query Prometheus with given address'
do
context
'can reach a ready Prometheus client'
do
context
'Prometheus is ready'
do
it_behaves_like
'query topology data from Prometheus'
end
context
'Prometheus is not ready'
do
before
do
before
do
# readiness check over HTTPS connection returns false
expect
(
topology
).
to
receive
(
:with_prometheus_client
).
and_yield
(
prometheus_client
)
expect_prometheus_api_to
(
receive_ready_check_query
(
result:
false
))
# readiness check over HTTP connection also returns false
expect_prometheus_api_to
(
receive_ready_check_query
(
result:
false
))
end
end
it_behaves_like
'returns empty result with no failure
s'
it_behaves_like
'query topology data from Prometheu
s'
end
end
context
'Prometheus is not reachable
'
do
context
'can not reach a ready Prometheus client
'
do
before
do
before
do
# HTTPS connection is not reachable
expect
(
topology
).
to
receive
(
:with_prometheus_client
).
and_return
(
fallback
)
expect_prometheus_api_to
(
receive_ready_check_query
(
raise_error:
Errno
::
ECONNREFUSED
))
# HTTP connection is also not reachable
expect_prometheus_api_to
(
receive_ready_check_query
(
raise_error:
Errno
::
ECONNREFUSED
))
end
end
it_behaves_like
'returns empty result with no failures'
it_behaves_like
'returns empty result with no failures'
end
end
end
context
'when Prometheus server address is available from Prometheus settings'
do
before
do
expect
(
Gitlab
::
Prometheus
::
Internal
).
to
receive
(
:prometheus_enabled?
).
and_return
(
true
)
expect
(
Gitlab
::
Prometheus
::
Internal
).
to
receive
(
:uri
).
and_return
(
'http://prom:9090'
)
end
include_examples
'try to query Prometheus with given address'
end
context
'when Prometheus server address is available from Consul service discovery'
do
before
do
expect
(
Gitlab
::
Prometheus
::
Internal
).
to
receive
(
:prometheus_enabled?
).
and_return
(
false
)
expect
(
Gitlab
::
Consul
::
Internal
).
to
receive
(
:api_url
).
and_return
(
'http://127.0.0.1:8500'
)
expect
(
Gitlab
::
Consul
::
Internal
).
to
receive
(
:discover_prometheus_server_address
).
and_return
(
'prom.net:9090'
)
end
include_examples
'try to query Prometheus with given address'
end
context
'when Prometheus server address is not available'
do
before
do
expect
(
Gitlab
::
Prometheus
::
Internal
).
to
receive
(
:prometheus_enabled?
).
and_return
(
false
)
expect
(
Gitlab
::
Consul
::
Internal
).
to
receive
(
:api_url
).
and_return
(
nil
)
end
include_examples
'returns empty result with no failures'
end
context
'when top-level function raises error'
do
context
'when top-level function raises error'
do
it
'returns empty result with generic failure'
do
it
'returns empty result with generic failure'
do
allow
(
Gitlab
::
Prometheus
::
Internal
).
to
receive
(
:prometheus_enabled?
).
and_raise
(
RuntimeError
)
expect
(
topology
).
to
receive
(
:with_prometheus_client
).
and_raise
(
RuntimeError
)
expect
(
subject
[
:topology
]).
to
eq
({
expect
(
subject
[
:topology
]).
to
eq
({
duration_s:
0
,
duration_s:
0
,
...
...
spec/support/helpers/usage_data_helpers.rb
View file @
4dfaba0b
...
@@ -224,17 +224,8 @@ module UsageDataHelpers
...
@@ -224,17 +224,8 @@ module UsageDataHelpers
)
)
end
end
def
expect_prometheus_api_to
(
*
receive_matchers
)
def
expect_prometheus_client_to
(
*
receive_matchers
)
expect_next_instance_of
(
Gitlab
::
PrometheusClient
)
do
|
client
|
receive_matchers
.
each
{
|
m
|
expect
(
prometheus_client
).
to
m
}
receive_matchers
.
each
{
|
m
|
expect
(
client
).
to
m
}
end
end
def
allow_prometheus_queries
allow_next_instance_of
(
Gitlab
::
PrometheusClient
)
do
|
client
|
allow
(
client
).
to
receive
(
:aggregate
).
and_return
({})
allow
(
client
).
to
receive
(
:query
).
and_return
({})
end
end
end
def
for_defined_days_back
(
days:
[
29
,
2
])
def
for_defined_days_back
(
days:
[
29
,
2
])
...
...
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