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) { diff --git a/command/agent/http.go b/command/agent/http.go index 756b9ea5a9c..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,10 +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) { - http.Redirect(w, req, "/ui/", 307) - return + if req.URL.Path == "/" { + http.Redirect(w, req, "/ui/", 307) + } else { + w.WriteHeader(http.StatusNotFound) + } }) }