From 010abda64c942e20d481c05366c04320a2bcdbe9 Mon Sep 17 00:00:00 2001 From: Hans Hasselberg Date: Tue, 22 Sep 2020 20:34:09 +0200 Subject: [PATCH 1/2] use service datacenter for dns name (#8704) * Use args.Datacenter instead of configured datacenter --- .changelog/8704.txt | 3 +++ agent/ui_endpoint.go | 11 ++++++----- agent/ui_endpoint_test.go | 10 ++++++++++ 3 files changed, 19 insertions(+), 5 deletions(-) create mode 100644 .changelog/8704.txt diff --git a/.changelog/8704.txt b/.changelog/8704.txt new file mode 100644 index 0000000000..0652e75874 --- /dev/null +++ b/.changelog/8704.txt @@ -0,0 +1,3 @@ +```release-note:bug +ui: show correct datacenter for gateways +``` diff --git a/agent/ui_endpoint.go b/agent/ui_endpoint.go index 202297d986..c6a0cfc4b3 100644 --- a/agent/ui_endpoint.go +++ b/agent/ui_endpoint.go @@ -164,7 +164,7 @@ RPC: // Generate the summary // TODO (gateways) (freddy) Have Internal.ServiceDump return ServiceDump instead. Need to add bexpr filtering for type. - return summarizeServices(out.Nodes.ToServiceDump(), s.agent.config), nil + return summarizeServices(out.Nodes.ToServiceDump(), s.agent.config, args.Datacenter), nil } // UIGatewayServices is used to query all the nodes for services associated with a gateway along with their gateway config @@ -199,10 +199,10 @@ RPC: return nil, err } - return summarizeServices(out.Dump, s.agent.config), nil + return summarizeServices(out.Dump, s.agent.config, args.Datacenter), nil } -func summarizeServices(dump structs.ServiceDump, cfg *config.RuntimeConfig) []*ServiceSummary { +func summarizeServices(dump structs.ServiceDump, cfg *config.RuntimeConfig, datacenter string) []*ServiceSummary { // Collect the summary information var services []structs.ServiceID summary := make(map[structs.ServiceID]*ServiceSummary) @@ -226,7 +226,7 @@ func summarizeServices(dump structs.ServiceDump, cfg *config.RuntimeConfig) []*S if csn.GatewayService != nil { gwsvc := csn.GatewayService sum := getService(gwsvc.Service.ToServiceID()) - modifySummaryForGatewayService(cfg, sum, gwsvc) + modifySummaryForGatewayService(cfg, datacenter, sum, gwsvc) } // Will happen in cases where we only have the GatewayServices mapping @@ -307,6 +307,7 @@ func summarizeServices(dump structs.ServiceDump, cfg *config.RuntimeConfig) []*S func modifySummaryForGatewayService( cfg *config.RuntimeConfig, + datacenter string, sum *ServiceSummary, gwsvc *structs.GatewayService, ) { @@ -319,7 +320,7 @@ func modifySummaryForGatewayService( } dnsAddresses = append(dnsAddresses, serviceIngressDNSName( gwsvc.Service.Name, - cfg.Datacenter, + datacenter, domain, &gwsvc.Service.EnterpriseMeta, )) diff --git a/agent/ui_endpoint_test.go b/agent/ui_endpoint_test.go index c8d4f4caea..adf3f56bde 100644 --- a/agent/ui_endpoint_test.go +++ b/agent/ui_endpoint_test.go @@ -12,6 +12,7 @@ import ( "path/filepath" "testing" + "github.com/hashicorp/consul/agent/config" "github.com/hashicorp/consul/agent/structs" "github.com/hashicorp/consul/api" "github.com/hashicorp/consul/sdk/testutil" @@ -698,3 +699,12 @@ func TestUIGatewayServiceNodes_Ingress(t *testing.T) { } assert.ElementsMatch(t, expect, dump) } + +func TestUIEndpoint_modifySummaryForGatewayService_UseRequestedDCInsteadOfConfigured(t *testing.T) { + dc := "dc2" + cfg := config.RuntimeConfig{Datacenter: "dc1", DNSDomain: "consul"} + sum := ServiceSummary{GatewayConfig: GatewayConfig{}} + gwsvc := structs.GatewayService{Service: structs.ServiceName{Name: "test"}, Port: 42} + modifySummaryForGatewayService(&cfg, dc, &sum, &gwsvc) + require.Equal(t, "test.ingress.dc2.consul:42", sum.GatewayConfig.Addresses[0]) +} From 780d2d79fb2ca9a99c693a79f3637dd72bcaca05 Mon Sep 17 00:00:00 2001 From: Hans Hasselberg Date: Fri, 25 Sep 2020 17:31:42 +0200 Subject: [PATCH 2/2] fix ent error (#8750) --- agent/ui_endpoint_test.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/agent/ui_endpoint_test.go b/agent/ui_endpoint_test.go index adf3f56bde..e1aff4281a 100644 --- a/agent/ui_endpoint_test.go +++ b/agent/ui_endpoint_test.go @@ -706,5 +706,6 @@ func TestUIEndpoint_modifySummaryForGatewayService_UseRequestedDCInsteadOfConfig sum := ServiceSummary{GatewayConfig: GatewayConfig{}} gwsvc := structs.GatewayService{Service: structs.ServiceName{Name: "test"}, Port: 42} modifySummaryForGatewayService(&cfg, dc, &sum, &gwsvc) - require.Equal(t, "test.ingress.dc2.consul:42", sum.GatewayConfig.Addresses[0]) + expected := serviceCanonicalDNSName("test", "ingress", "dc2", "consul", nil) + ":42" + require.Equal(t, expected, sum.GatewayConfig.Addresses[0]) }