From 39280e7a9472dd1bbb4232179e1291990f2e3876 Mon Sep 17 00:00:00 2001 From: Drew Bailey <2614075+drewbailey@users.noreply.github.com> Date: Fri, 8 Nov 2019 15:34:35 -0500 Subject: [PATCH 1/3] returns a 404 if not found instead of redirect to ui --- command/agent/http.go | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/command/agent/http.go b/command/agent/http.go index 756b9ea5a9c..57f2e0afac8 100644 --- a/command/agent/http.go +++ b/command/agent/http.go @@ -277,6 +277,11 @@ func handleUI(h http.Handler) http.Handler { func handleRootRedirect() http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) { + if req.URL.Path != "/" { + w.WriteHeader(http.StatusNotFound) + return + } + http.Redirect(w, req, "/ui/", 307) return }) From d91a5e619f07d7937a066378bc04886d82017e39 Mon Sep 17 00:00:00 2001 From: Drew Bailey <2614075+drewbailey@users.noreply.github.com> Date: Fri, 8 Nov 2019 15:49:04 -0500 Subject: [PATCH 2/3] update test --- api/allocations_test.go | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/api/allocations_test.go b/api/allocations_test.go index b942ee0e0f5..4f9ab45015f 100644 --- a/api/allocations_test.go +++ b/api/allocations_test.go @@ -2,6 +2,7 @@ package api import ( "context" + "fmt" "os" "reflect" "sort" @@ -265,8 +266,10 @@ func TestAllocations_ExecErrors(t *testing.T) { } job.Canonicalize() + allocID := uuid.Generate() + alloc := &Allocation{ - ID: "", + ID: allocID, Namespace: DefaultNamespace, EvalID: uuid.Generate(), Name: "foo-bar[1]", @@ -280,9 +283,10 @@ func TestAllocations_ExecErrors(t *testing.T) { // make a request that will result in an error // ensure the error is what we expect - _, err := a.Exec(context.Background(), alloc, "bar", false, []string{"command"}, os.Stdin, os.Stdout, os.Stderr, sizeCh, nil) - require.Contains(t, err.Error(), "Unexpected response code: 301") - require.Contains(t, err.Error(), "Moved Permanently") + exitCode, err := a.Exec(context.Background(), alloc, "bar", false, []string{"command"}, os.Stdin, os.Stdout, os.Stderr, sizeCh, nil) + + require.Equal(t, exitCode, -2) + require.Equal(t, err.Error(), fmt.Sprintf("Unknown allocation \"%s\"", allocID)) } func TestAllocations_ShouldMigrate(t *testing.T) { From 29585dd341769282f8c67a421269d84fe14b2d86 Mon Sep 17 00:00:00 2001 From: Drew Bailey <2614075+drewbailey@users.noreply.github.com> Date: Mon, 11 Nov 2019 08:35:56 -0500 Subject: [PATCH 3/3] better func name, swap conditional --- command/agent/http.go | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/command/agent/http.go b/command/agent/http.go index 57f2e0afac8..cb18c7f31e5 100644 --- a/command/agent/http.go +++ b/command/agent/http.go @@ -213,7 +213,7 @@ func (s *HTTPServer) registerHandlers(enableDebug bool) { w.Write([]byte(stubHTML)) }) } - s.mux.Handle("/", handleRootRedirect()) + s.mux.Handle("/", handleRootFallthrough()) if enableDebug { s.mux.HandleFunc("/debug/pprof/", pprof.Index) @@ -275,15 +275,13 @@ func handleUI(h http.Handler) http.Handler { }) } -func handleRootRedirect() http.Handler { +func handleRootFallthrough() http.Handler { return http.HandlerFunc(func(w http.ResponseWriter, req *http.Request) { - if req.URL.Path != "/" { + if req.URL.Path == "/" { + http.Redirect(w, req, "/ui/", 307) + } else { w.WriteHeader(http.StatusNotFound) - return } - - http.Redirect(w, req, "/ui/", 307) - return }) }