From 19d274c7223cd00f983014cf9ddf64773652b845 Mon Sep 17 00:00:00 2001 From: Juan Antonio Osorio Date: Wed, 8 Nov 2023 13:35:32 +0200 Subject: [PATCH 1/4] Hook up minder healthcheck to database health The intention is to link minder's health with the database and keep the db connection open for longer. --- internal/controlplane/handlers.go | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/internal/controlplane/handlers.go b/internal/controlplane/handlers.go index 011be38fcb..fed9447482 100644 --- a/internal/controlplane/handlers.go +++ b/internal/controlplane/handlers.go @@ -25,6 +25,9 @@ package controlplane import ( "context" + "google.golang.org/grpc/codes" + "google.golang.org/grpc/status" + pb "github.com/stacklok/minder/pkg/api/protobuf/go/minder/v1" ) @@ -32,11 +35,9 @@ import ( const PaginationLimit = 10 // CheckHealth is a simple health check for monitoring -// The lintcheck is disabled because the unused-receiver is required by -// the implementation. UnimplementedHealthServiceServer is initialized -// within the Server struct -// -//revive:disable:unused-receiver func (s *Server) CheckHealth(_ context.Context, _ *pb.CheckHealthRequest) (*pb.CheckHealthResponse, error) { + if err := s.store.CheckHealth(); err != nil { + return nil, status.Errorf(codes.Internal, "failed to check health: %v", err) + } return &pb.CheckHealthResponse{Status: "OK"}, nil } From 6120da6fe401cf4febc1df5ed3fe7528fe3f75d7 Mon Sep 17 00:00:00 2001 From: Juan Antonio Osorio Date: Wed, 8 Nov 2023 13:44:12 +0200 Subject: [PATCH 2/4] add store to check health unit test. --- internal/controlplane/handlers_test.go | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/internal/controlplane/handlers_test.go b/internal/controlplane/handlers_test.go index ffd39e8f74..bb5a22dba1 100644 --- a/internal/controlplane/handlers_test.go +++ b/internal/controlplane/handlers_test.go @@ -18,13 +18,25 @@ import ( "context" "testing" + "github.com/golang/mock/gomock" + + mockdb "github.com/stacklok/minder/database/mock" pb "github.com/stacklok/minder/pkg/api/protobuf/go/minder/v1" ) func TestCheckHealth(t *testing.T) { t.Parallel() - server := Server{} + ctrl := gomock.NewController(t) + defer ctrl.Finish() + + mockStore := mockdb.NewMockStore(ctrl) + + mockStore.EXPECT().CheckHealth().Return(nil) + + server := Server{ + store: mockStore, + } response, err := server.CheckHealth(context.Background(), &pb.CheckHealthRequest{}) if err != nil { t.Errorf("Error in CheckHealth: %v", err) From 104f64eaa9afc5e378c278375db8d0160f10b3fc Mon Sep 17 00:00:00 2001 From: Juan Antonio Osorio Date: Wed, 8 Nov 2023 14:02:10 +0200 Subject: [PATCH 3/4] Remove invalid healthcheck test --- internal/controlplane/server_test.go | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/internal/controlplane/server_test.go b/internal/controlplane/server_test.go index 82f0b677f9..ae1a2e3424 100644 --- a/internal/controlplane/server_test.go +++ b/internal/controlplane/server_test.go @@ -122,22 +122,6 @@ func generateTokenKey(t *testing.T) string { return tokenKeyPath } -func TestHealth(t *testing.T) { - t.Parallel() - - conn, err := getgRPCConnection() - if err != nil { - t.Fatalf("Failed to dial bufnet: %v", err) - } - defer conn.Close() - - client := pb.NewHealthServiceClient(conn) - _, err = client.CheckHealth(context.Background(), &pb.CheckHealthRequest{}) - if err != nil { - t.Fatalf("Failed to get health: %v", err) - } -} - func TestWebhook(t *testing.T) { t.Parallel() From 2010a4b2f41cdb3fc64724e309f75abc0a8e319e Mon Sep 17 00:00:00 2001 From: Juan Antonio Osorio Date: Wed, 8 Nov 2023 14:03:19 +0200 Subject: [PATCH 4/4] Remove unused test functions --- internal/controlplane/server_test.go | 16 ---------------- 1 file changed, 16 deletions(-) diff --git a/internal/controlplane/server_test.go b/internal/controlplane/server_test.go index ae1a2e3424..440af1e2c9 100644 --- a/internal/controlplane/server_test.go +++ b/internal/controlplane/server_test.go @@ -18,7 +18,6 @@ package controlplane import ( "context" "log" - "net" "net/http" "net/http/httptest" "os" @@ -29,7 +28,6 @@ import ( "github.com/golang/mock/gomock" "github.com/stretchr/testify/require" "google.golang.org/grpc" - "google.golang.org/grpc/credentials/insecure" "google.golang.org/grpc/test/bufconn" mockdb "github.com/stacklok/minder/database/mock" @@ -69,20 +67,6 @@ func init() { // It would be nice if we could Close() the httpServer, but we leak it in the test instead } -func bufDialer(context.Context, string) (net.Conn, error) { - return lis.Dial() -} - -func getgRPCConnection() (*grpc.ClientConn, error) { - conn, err := grpc.DialContext(context.Background(), "bufnet", - grpc.WithContextDialer(bufDialer), - grpc.WithTransportCredentials(insecure.NewCredentials())) - if err != nil { - return nil, err - } - return conn, nil -} - func newDefaultServer(t *testing.T, mockStore *mockdb.MockStore) *Server { t.Helper()