From 5c1588730e5a45fd4e78cd20971ce20ef51f6952 Mon Sep 17 00:00:00 2001 From: Daniil Fedotov Date: Fri, 28 Jun 2024 16:19:24 -0400 Subject: [PATCH] Fix url schema for grpc.NewClient --- pkg/kanx/client.go | 6 ++++++ pkg/kanx/kanx_test.go | 14 ++++++++------ 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/pkg/kanx/client.go b/pkg/kanx/client.go index 2de1d85194..80f996aaf8 100644 --- a/pkg/kanx/client.go +++ b/pkg/kanx/client.go @@ -4,6 +4,7 @@ import ( "context" "io" "net" + "net/url" "google.golang.org/grpc" "google.golang.org/grpc/credentials/insecure" @@ -16,6 +17,11 @@ func newGRPCConnection(addr string) (*grpc.ClientConn, error) { var opts []grpc.DialOption opts = append(opts, grpc.WithTransportCredentials(insecure.NewCredentials())) opts = append(opts, grpc.WithContextDialer(unixDialer)) + // Add passthrough scheme if there is no scheme defined in the address + u, err := url.Parse(addr) + if err == nil && u.Scheme == "" { + addr = "passthrough:///" + addr + } return grpc.NewClient(addr, opts...) } diff --git a/pkg/kanx/kanx_test.go b/pkg/kanx/kanx_test.go index 97b7289ece..ba5666d711 100644 --- a/pkg/kanx/kanx_test.go +++ b/pkg/kanx/kanx_test.go @@ -40,12 +40,14 @@ func newTestServer(dir string) *Server { } } -func serverReady(ctx context.Context, addr string) { +func serverReady(ctx context.Context, addr string, c *C) { ctx, can := context.WithTimeout(ctx, 10*time.Second) defer can() for { select { case <-ctx.Done(): + c.Error("Timeout waiting for server to be ready") + c.Fail() return default: } @@ -61,7 +63,7 @@ func (s *KanXSuite) TestServerCancellation(c *C) { addr := path.Join(d, "kanx.sock") ctx, can := context.WithCancel(context.Background()) go func() { - serverReady(ctx, addr) + serverReady(ctx, addr, c) can() }() err := newTestServer(d).Serve(ctx, addr) @@ -77,7 +79,7 @@ func (s *KanXSuite) TestShortProcess(c *C) { err := newTestServer(d).Serve(ctx, addr) c.Assert(err, IsNil) }() - serverReady(ctx, addr) + serverReady(ctx, addr, c) p, err := CreateProcess(ctx, addr, "echo", []string{"hello"}) c.Assert(err, IsNil) @@ -115,7 +117,7 @@ func (s *KanXSuite) TestLongProcess(c *C) { err := server.Serve(ctx, addr) c.Assert(err, IsNil) }() - serverReady(ctx, addr) + serverReady(ctx, addr, c) p, err := CreateProcess(ctx, addr, "tail", []string{"-f", "/dev/null"}) c.Assert(err, IsNil) @@ -168,7 +170,7 @@ func (s *KanXSuite) TestError(c *C) { err := server.Serve(ctx, addr) c.Assert(err, IsNil) }() - serverReady(ctx, addr) + serverReady(ctx, addr, c) p, err := CreateProcess(ctx, addr, "tail", []string{"-f", "/dev/null"}) c.Assert(err, IsNil) @@ -225,7 +227,7 @@ func (s *KanXSuite) TestParallelStdout(c *C) { err := server.Serve(ctx, addr) c.Assert(err, IsNil) }() - serverReady(ctx, addr) + serverReady(ctx, addr, c) p, err := CreateProcess(ctx, addr, "yes", nil) c.Assert(err, IsNil)