mirror of https://github.com/hashicorp/consul
ui: Hide all metrics for ingress gateway services (#10858)
parent
1a9b2f09dd
commit
eeeb91beaa
|
@ -0,0 +1,3 @@
|
||||||
|
```release-note:bug
|
||||||
|
ui: Hide all metrics for ingress gateway services
|
||||||
|
```
|
|
@ -25,8 +25,10 @@
|
||||||
@hasMetricsProvider={{@hasMetricsProvider}}
|
@hasMetricsProvider={{@hasMetricsProvider}}
|
||||||
@noMetricsReason={{this.noMetricsReason}}
|
@noMetricsReason={{this.noMetricsReason}}
|
||||||
>
|
>
|
||||||
{{#if (and @hasMetricsProvider (not-eq @service.Service.Kind 'ingress-gateway'))}}
|
{{#if (and @hasMetricsProvider this.mainNotIngressService (not-eq item.Kind 'ingress-gateway'))}}
|
||||||
|
{{!-- One of the only places in the app where it's acceptable to default to 'default' namespace --}}
|
||||||
<TopologyMetrics::Stats
|
<TopologyMetrics::Stats
|
||||||
|
data-test-topology-metrics-downstream-stats
|
||||||
@nspace={{or item.Namespace 'default'}}
|
@nspace={{or item.Namespace 'default'}}
|
||||||
@dc={{item.Datacenter}}
|
@dc={{item.Datacenter}}
|
||||||
@endpoint='downstream-summary-for-service'
|
@endpoint='downstream-summary-for-service'
|
||||||
|
@ -43,7 +45,7 @@
|
||||||
<div class="metrics-header">
|
<div class="metrics-header">
|
||||||
{{@service.Service.Service}}
|
{{@service.Service.Service}}
|
||||||
</div>
|
</div>
|
||||||
{{#if @hasMetricsProvider }}
|
{{#if @hasMetricsProvider}}
|
||||||
<TopologyMetrics::Series
|
<TopologyMetrics::Series
|
||||||
@nspace={{or @service.Service.Namespace 'default'}}
|
@nspace={{or @service.Service.Namespace 'default'}}
|
||||||
@dc={{@dc}}
|
@dc={{@dc}}
|
||||||
|
@ -51,7 +53,7 @@
|
||||||
@protocol={{@topology.Protocol}}
|
@protocol={{@topology.Protocol}}
|
||||||
@noMetricsReason={{this.noMetricsReason}}
|
@noMetricsReason={{this.noMetricsReason}}
|
||||||
/>
|
/>
|
||||||
{{#if (not-eq @service.Service.Kind 'ingress-gateway')}}
|
{{#if this.mainNotIngressService}}
|
||||||
<TopologyMetrics::Stats
|
<TopologyMetrics::Stats
|
||||||
@nspace={{or @service.Service.Namespace 'default'}}
|
@nspace={{or @service.Service.Namespace 'default'}}
|
||||||
@dc={{@dc}}
|
@dc={{@dc}}
|
||||||
|
@ -98,7 +100,8 @@
|
||||||
@item={{item}}
|
@item={{item}}
|
||||||
@service={{@service.Service}}
|
@service={{@service.Service}}
|
||||||
>
|
>
|
||||||
{{#if (and @hasMetricsProvider (not-eq @service.Service.Kind 'ingress-gateway'))}}
|
{{#if (and @hasMetricsProvider this.mainNotIngressService (not-eq item.Kind 'ingress-gateway'))}}
|
||||||
|
{{!-- One of the only places in the app where it's acceptable to default to 'default' namespace --}}
|
||||||
<TopologyMetrics::Stats
|
<TopologyMetrics::Stats
|
||||||
@nspace={{or item.Namespace 'default'}}
|
@nspace={{or item.Namespace 'default'}}
|
||||||
@dc={{item.Datacenter}}
|
@dc={{item.Datacenter}}
|
||||||
|
|
|
@ -84,6 +84,12 @@ export default class TopologyMetrics extends Component {
|
||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get mainNotIngressService() {
|
||||||
|
const kind = get(this.args.service.Service, 'Kind') || '';
|
||||||
|
|
||||||
|
return kind !== 'ingress-gateway';
|
||||||
|
}
|
||||||
|
|
||||||
// =actions
|
// =actions
|
||||||
@action
|
@action
|
||||||
setHeight(el, item) {
|
setHeight(el, item) {
|
||||||
|
@ -98,9 +104,9 @@ export default class TopologyMetrics extends Component {
|
||||||
@action
|
@action
|
||||||
calculate() {
|
calculate() {
|
||||||
if (this.args.isRemoteDC) {
|
if (this.args.isRemoteDC) {
|
||||||
this.noMetricsReason = 'Unable to fetch metrics for a remote datacenter';
|
this.noMetricsReason = 'remote-dc';
|
||||||
} else if (this.args.service.Service.Kind === 'ingress-gateway') {
|
} else if (this.args.service.Service.Kind === 'ingress-gateway') {
|
||||||
this.noMetricsReason = 'Unable to fetch metrics for a ingress gateway';
|
this.noMetricsReason = 'ingress-gateway';
|
||||||
} else {
|
} else {
|
||||||
this.noMetricsReason = null;
|
this.noMetricsReason = null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,16 @@
|
||||||
{{#if @noMetricsReason}}
|
{{#if (or @noMetricsReason @error)}}
|
||||||
<span class="topology-metrics-error">
|
<span data-test-topology-metrics-status class="topology-metrics-status-error">
|
||||||
Unable to load metrics
|
{{#if (eq @noMetricsReason 'ingress-gateway')}}
|
||||||
<span>
|
{{t "components.consul.topology-metrics.status.ingress-gateway"}}
|
||||||
<Tooltip>{{@noMetricsReason}}</Tooltip>
|
{{else if (eq @noMetricsReason 'remote-dc')}}
|
||||||
</span>
|
{{t "components.consul.topology-metrics.status.error"}}
|
||||||
|
<span
|
||||||
|
{{tooltip (t "components.consul.topology-metrics.status.remote-dc")}}
|
||||||
|
/>
|
||||||
|
{{else if @error}}
|
||||||
|
{{t "components.consul.topology-metrics.status.error"}}
|
||||||
|
{{/if}}
|
||||||
</span>
|
</span>
|
||||||
{{else if @error}}
|
|
||||||
<span class="topology-metrics-error">Unable to load metrics</span>
|
|
||||||
{{else}}
|
{{else}}
|
||||||
<span class="topology-metrics-loader">Loading Metrics</span>
|
<span class="topology-metrics-status-loader">{{t "components.consul.topology-metrics.status.loading"}}</span>
|
||||||
{{/if}}
|
{{/if}}
|
|
@ -1,5 +1,5 @@
|
||||||
.topology-metrics-error,
|
.topology-metrics-status-error,
|
||||||
.topology-metrics-loader {
|
.topology-metrics-status-loader {
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
font-size: 0.875rem;
|
font-size: 0.875rem;
|
||||||
color: $gray-500;
|
color: $gray-500;
|
||||||
|
@ -13,6 +13,6 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
span.topology-metrics-loader::after {
|
span.topology-metrics-status-loader::after {
|
||||||
@extend %with-loading-icon, %as-pseudo;
|
@extend %with-loading-icon, %as-pseudo;
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,6 +72,9 @@ ${
|
||||||
const allowed = hasPerms ? false : fake.random.boolean();
|
const allowed = hasPerms ? false : fake.random.boolean();
|
||||||
return `
|
return `
|
||||||
{
|
{
|
||||||
|
${(Math.random(1) > 0.3) ? `
|
||||||
|
"Kind": "${fake.helpers.randomize(['mesh-gateway', 'ingress-gateway', 'terminating-gateway', ''])}",
|
||||||
|
` : ''}
|
||||||
"Name": "${item.Name}",
|
"Name": "${item.Name}",
|
||||||
"Datacenter": "${item.Datacenter}",
|
"Datacenter": "${item.Datacenter}",
|
||||||
"Namespace": "${item.Namespace}",
|
"Namespace": "${item.Namespace}",
|
||||||
|
@ -98,6 +101,9 @@ ${
|
||||||
const allowed = hasPerms ? false : fake.random.boolean();
|
const allowed = hasPerms ? false : fake.random.boolean();
|
||||||
return `
|
return `
|
||||||
{
|
{
|
||||||
|
${(Math.random(1) > 0.3) ? `
|
||||||
|
"Kind": "${fake.helpers.randomize(['mesh-gateway', 'ingress-gateway', 'terminating-gateway', ''])}",
|
||||||
|
` : ''}
|
||||||
"Name": "${item.Name}",
|
"Name": "${item.Name}",
|
||||||
"Datacenter": "${item.Datacenter}",
|
"Datacenter": "${item.Datacenter}",
|
||||||
"Namespace": "${item.Namespace}",
|
"Namespace": "${item.Namespace}",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
@setupApplicationTest
|
@setupApplicationTest
|
||||||
Feature: dc / services / show / topology / stats
|
Feature: dc / services / show / topology / stats
|
||||||
Scenario: Given metrics is disabled,the Topology tab should not display metrics
|
Scenario: Given metrics is disabled, the Topology tab should not display metrics
|
||||||
Given 1 datacenter model with the value "dc1"
|
Given 1 datacenter model with the value "dc1"
|
||||||
And 1 node models
|
And 1 node models
|
||||||
And 1 service model from yaml
|
And 1 service model from yaml
|
||||||
|
@ -33,4 +33,51 @@ Feature: dc / services / show / topology / stats
|
||||||
---
|
---
|
||||||
And I see topology on the tabs
|
And I see topology on the tabs
|
||||||
And I see the "[data-test-topology-metrics-stats]" element
|
And I see the "[data-test-topology-metrics-stats]" element
|
||||||
|
Scenario: Given metrics is enabled, metrics stats are disabled for an ingress gateway Topology
|
||||||
|
Given 1 datacenter model with the value "dc1"
|
||||||
|
Given a "prometheus" metrics provider
|
||||||
|
And 1 node models
|
||||||
|
And 1 service model from yaml
|
||||||
|
---
|
||||||
|
- Service:
|
||||||
|
Name: ingress-gateway
|
||||||
|
Kind: ingress-gateway
|
||||||
|
ID: ingress-gateway-with-id
|
||||||
|
---
|
||||||
|
When I visit the service page for yaml
|
||||||
|
---
|
||||||
|
dc: dc1
|
||||||
|
service: ingress-gateway
|
||||||
|
---
|
||||||
|
And I see topology on the tabs
|
||||||
|
And I don't see the "[data-test-topology-metrics-stats]" element
|
||||||
|
And I see the "[data-test-topology-metrics-status]" element
|
||||||
|
Scenario: Given metrics is enabled, metric stats are disabled for ingress gateway as downstream services
|
||||||
|
Given 1 datacenter model with the value "dc1"
|
||||||
|
Given a "prometheus" metrics provider
|
||||||
|
And 1 node models
|
||||||
|
And 1 service model from yaml
|
||||||
|
---
|
||||||
|
- Service:
|
||||||
|
Name: service-0
|
||||||
|
ID: service-0-with-id
|
||||||
|
---
|
||||||
|
And 1 topology model from yaml
|
||||||
|
---
|
||||||
|
Upstreams: []
|
||||||
|
Downstreams:
|
||||||
|
- Name: db
|
||||||
|
Namespace: @namespace
|
||||||
|
Datacenter: dc1
|
||||||
|
Intention: {}
|
||||||
|
Kind: ingress-gateway
|
||||||
|
---
|
||||||
|
When I visit the service page for yaml
|
||||||
|
---
|
||||||
|
dc: dc1
|
||||||
|
service: service-0
|
||||||
|
---
|
||||||
|
And I see topology on the tabs
|
||||||
|
And I see the "[data-test-sparkline]" element
|
||||||
|
And I don't see the "[data-test-topology-metrics-downstream-stats]" element
|
||||||
|
|
||||||
|
|
|
@ -160,9 +160,13 @@ topology-metrics:
|
||||||
header: No traffic
|
header: No traffic
|
||||||
body: Add "{upstream}" as an explicit upstream of "{downstream}" or set the "{downstream}" proxy to "transparent" mode to enable traffic.
|
body: Add "{upstream}" as an explicit upstream of "{downstream}" or set the "{downstream}" proxy to "transparent" mode to enable traffic.
|
||||||
action: Documentation
|
action: Documentation
|
||||||
|
status:
|
||||||
|
error: Unable to load metrics
|
||||||
|
remote-dc: Unable to fetch metrics for a remote datacenter
|
||||||
|
loading: Loading metrics
|
||||||
|
ingress-gateway: Viewing metrics for Ingress Gateways is not currently supported in the UI.
|
||||||
source:
|
source:
|
||||||
header: This is not a registered Consul service. It’s a routing configuration that routes traffic to real services in Consul. For more information, read our documentation.
|
header: This is not a registered Consul service. It’s a routing configuration that routes traffic to real services in Consul. For more information, read our documentation.
|
||||||
menu-title: About Routing Configs
|
menu-title: About Routing Configs
|
||||||
links:
|
links:
|
||||||
documentation: Documentation
|
documentation: Documentation
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue