From db66f37be247fe182ed9494b066de1a866cfbd1b Mon Sep 17 00:00:00 2001 From: decfox Date: Wed, 3 Apr 2024 12:46:00 +0530 Subject: [PATCH] feat: add health check response for oohelperd --- internal/oohelperd/handler.go | 15 ++++++++++++++- internal/oohelperd/handler_test.go | 10 +++++++++- 2 files changed, 23 insertions(+), 2 deletions(-) diff --git a/internal/oohelperd/handler.go b/internal/oohelperd/handler.go index dd76c42cdc..3938e99dc4 100644 --- a/internal/oohelperd/handler.go +++ b/internal/oohelperd/handler.go @@ -148,7 +148,20 @@ func (h *Handler) ServeHTTP(w http.ResponseWriter, req *http.Request) { version.Version, )) - // we only handle the POST method + // handle GET method for health check + if req.Method == "GET" { + metricRequestsCount.WithLabelValues("200", "ok").Inc() + resp := map[string]string{ + "message": "Hello OONItarian!", + } + data, err := json.Marshal(resp) + runtimex.PanicOnError(err, "json.Marshal failed") + w.Header().Add("Content-Type", "application/json") + w.Write(data) + return + } + + // we only handle the POST method for response generation if req.Method != "POST" { metricRequestsCount.WithLabelValues("400", "bad_request_method").Inc() w.WriteHeader(400) diff --git a/internal/oohelperd/handler_test.go b/internal/oohelperd/handler_test.go index 8285e6faae..7444124cbe 100644 --- a/internal/oohelperd/handler_test.go +++ b/internal/oohelperd/handler_test.go @@ -100,12 +100,20 @@ func TestHandlerWorkingAsIntended(t *testing.T) { expectations := []expectationSpec{{ name: "check for invalid method", - reqMethod: "GET", + reqMethod: "PUT", reqContentType: "", reqBody: strings.NewReader(""), respStatusCode: 400, respContentType: "", parseBody: false, + }, { + name: "check for health message", + reqMethod: "GET", + reqContentType: "", + reqBody: strings.NewReader(""), + respStatusCode: 200, + respContentType: "application/json", + parseBody: true, }, { name: "check for error reading request body", reqMethod: "POST",