From 80bbdfd145d6e7ffb8076ebbfb5467d340956a2d Mon Sep 17 00:00:00 2001 From: Michal Pristas Date: Wed, 12 May 2021 13:23:33 +0200 Subject: [PATCH] [Elastic Agent] Fixed status reporting (#25584) [Elastic Agent] Fixed status reporting (#25584) --- x-pack/elastic-agent/pkg/agent/cmd/run.go | 9 +++++ .../pkg/core/monitoring/server/handler.go | 4 +-- .../core/monitoring/server/process_test.go | 33 +++++++++++++++++++ 3 files changed, 44 insertions(+), 2 deletions(-) diff --git a/x-pack/elastic-agent/pkg/agent/cmd/run.go b/x-pack/elastic-agent/pkg/agent/cmd/run.go index e49d60b59370..5fa7ad112216 100644 --- a/x-pack/elastic-agent/pkg/agent/cmd/run.go +++ b/x-pack/elastic-agent/pkg/agent/cmd/run.go @@ -215,6 +215,15 @@ func reexecPath() (string, error) { } func getOverwrites(rawConfig *config.Config) error { + cfg, err := configuration.NewFromConfig(rawConfig) + if err != nil { + return err + } + + if !cfg.Fleet.Enabled { + // overrides should apply only for fleet mode + return nil + } path := paths.AgentConfigFile() store := storage.NewDiskStore(path) diff --git a/x-pack/elastic-agent/pkg/core/monitoring/server/handler.go b/x-pack/elastic-agent/pkg/core/monitoring/server/handler.go index dfb50d7e0246..482ce82b819a 100644 --- a/x-pack/elastic-agent/pkg/core/monitoring/server/handler.go +++ b/x-pack/elastic-agent/pkg/core/monitoring/server/handler.go @@ -27,8 +27,6 @@ type apiHandler struct { func (h *apiHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { err := h.innerFn(w, r) if err != nil { - writeResponse(w, unexpectedErrorWithReason(err.Error())) - switch e := err.(type) { case apiError: w.WriteHeader(e.Status()) @@ -36,6 +34,8 @@ func (h *apiHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) { w.WriteHeader(http.StatusInternalServerError) } + + writeResponse(w, unexpectedErrorWithReason(err.Error())) } } diff --git a/x-pack/elastic-agent/pkg/core/monitoring/server/process_test.go b/x-pack/elastic-agent/pkg/core/monitoring/server/process_test.go index e518322749b8..029516ca9e93 100644 --- a/x-pack/elastic-agent/pkg/core/monitoring/server/process_test.go +++ b/x-pack/elastic-agent/pkg/core/monitoring/server/process_test.go @@ -4,6 +4,7 @@ package server import ( + "errors" "net/http" "testing" @@ -54,3 +55,35 @@ func TestParseID(t *testing.T) { }) } } + +func TestStatusErr(t *testing.T) { + cases := map[string]struct { + Error error + ExpectedStatusCode int + }{ + "no error": {nil, 0}, + "normal error": {errors.New("something bad happened"), http.StatusInternalServerError}, + "status bound err - not found": {errorWithStatus(http.StatusNotFound, errors.New("something was not found")), http.StatusNotFound}, + "status bound err - internal": {errorWithStatus(http.StatusInternalServerError, errors.New("something was not found")), http.StatusInternalServerError}, + "status bound err - bad request": {errorWithStatus(http.StatusBadRequest, errors.New("something really bad happened")), http.StatusBadRequest}, + } + + dummyHandler := func(err error) func(w http.ResponseWriter, r *http.Request) error { + return func(w http.ResponseWriter, r *http.Request) error { + return err + } + } + + for name, tc := range cases { + t.Run(name, func(t *testing.T) { + h := createHandler(dummyHandler(tc.Error)) + tw := &testWriter{} + r, err := http.NewRequest("GET", "", nil) + require.NoError(t, err) + + h.ServeHTTP(tw, r) + + require.Equal(t, tc.ExpectedStatusCode, tw.statusCode) + }) + } +}