agent/grpc: always close the conn when dialing fails.

This commit is contained in:
Daniel Nephin 2020-09-15 14:11:48 -04:00
parent e6ffd987a3
commit f14145e6d9
2 changed files with 32 additions and 5 deletions

View File

@ -85,12 +85,13 @@ func newDialer(servers ServerLocator, wrapper TLSWrapper) func(context.Context,
server, err := servers.ServerForAddr(addr) server, err := servers.ServerForAddr(addr)
if err != nil { if err != nil {
// TODO: should conn be closed in this case, as it is in other error cases? conn.Close()
return nil, err return nil, err
} }
if server.UseTLS { if server.UseTLS {
if wrapper == nil { if wrapper == nil {
conn.Close()
return nil, fmt.Errorf("TLS enabled but got nil TLS wrapper") return nil, fmt.Errorf("TLS enabled but got nil TLS wrapper")
} }
@ -111,7 +112,7 @@ func newDialer(servers ServerLocator, wrapper TLSWrapper) func(context.Context,
_, err = conn.Write([]byte{pool.RPCGRPC}) _, err = conn.Write([]byte{pool.RPCGRPC})
if err != nil { if err != nil {
// TODO: should conn be closed in this case, as it is in other error cases? conn.Close()
return nil, err return nil, err
} }

View File

@ -3,6 +3,7 @@ package grpc
import ( import (
"context" "context"
"fmt" "fmt"
"net"
"strings" "strings"
"testing" "testing"
"time" "time"
@ -14,11 +15,36 @@ import (
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
func TestNewDialer(t *testing.T) { func TestNewDialer_WithTLSWrapper(t *testing.T) {
// TODO: conn is closed on errors lis, err := net.Listen("tcp", "127.0.0.1:0")
// TODO: with TLS enabled require.NoError(t, err)
t.Cleanup(logError(t, lis.Close))
builder := resolver.NewServerResolverBuilder(resolver.Config{})
builder.AddServer(&metadata.Server{
Name: "server-1",
ID: "ID1",
Datacenter: "dc1",
Addr: lis.Addr(),
UseTLS: true,
})
var called bool
wrapper := func(_ string, conn net.Conn) (net.Conn, error) {
called = true
return conn, nil
}
dial := newDialer(builder, wrapper)
ctx := context.Background()
conn, err := dial(ctx, lis.Addr().String())
require.NoError(t, err)
require.NoError(t, conn.Close())
require.True(t, called, "expected TLSWrapper to be called")
} }
// TODO: integration test TestNewDialer with TLS and rcp server, when the rpc
// exists as an isolated component.
func TestClientConnPool_IntegrationWithGRPCResolver_Failover(t *testing.T) { func TestClientConnPool_IntegrationWithGRPCResolver_Failover(t *testing.T) {
count := 4 count := 4
cfg := resolver.Config{Scheme: newScheme(t.Name())} cfg := resolver.Config{Scheme: newScheme(t.Name())}