Skip to content

Commit

Permalink
[Release 1.12 Patch] Fix 3204: consul to accept hostnames again (#3209)
Browse files Browse the repository at this point in the history
Signed-off-by: Bernd Verst <[email protected]>
  • Loading branch information
berndverst authored Nov 6, 2023
1 parent c23b191 commit 8001503
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 1 deletion.
8 changes: 7 additions & 1 deletion nameresolution/consul/consul.go
Original file line number Diff line number Diff line change
Expand Up @@ -166,7 +166,13 @@ func formatAddress(address string, port string) (addr string, err error) {
return fmt.Sprintf("[%s]:%s", address, port), nil
}

return "", fmt.Errorf("invalid ip address %s", address)
// addr is not a valid IP address
// use net.JoinHostPort to format address if address is a valid hostname
if _, err := net.LookupHost(address); err == nil {
return net.JoinHostPort(address, port), nil
}

return "", fmt.Errorf("invalid ip address or unreachable hostname: %s", address)
}

// getConfig configuration from metadata, defaults are best suited for self-hosted mode.
Expand Down
30 changes: 30 additions & 0 deletions nameresolution/consul/consul_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,36 @@ func TestResolveID(t *testing.T) {
assert.Equal(t, "[2001:db8:3333:4444:5555:6666:7777:8888]:50005", addr)
},
},
{
"should get localhost (hostname) from service",
nr.ResolveRequest{
ID: "test-app",
},
func(t *testing.T, req nr.ResolveRequest) {
t.Helper()
mock := mockClient{
mockHealth: mockHealth{
serviceResult: []*consul.ServiceEntry{
{
Service: &consul.AgentService{
Address: "localhost",
Port: 8600,
Meta: map[string]string{
"DAPR_PORT": "50005",
},
},
},
},
},
}
resolver := newResolver(logger.NewLogger("test"), &mock)
resolver.config = testConfig

addr, _ := resolver.ResolveID(req)

assert.Equal(t, "localhost:50005", addr)
},
},
{
"should get random address from service",
nr.ResolveRequest{
Expand Down

0 comments on commit 8001503

Please sign in to comment.