From 07d4a356dec0e2f44a6f3eec1ea3affec8932c22 Mon Sep 17 00:00:00 2001 From: Jonas L Date: Tue, 25 Jun 2024 15:34:57 +0200 Subject: [PATCH] fix(exp): configure response headers before sending them (#473) Ensure the headers are configured before we set the status code and send the headers. --- hcloud/exp/mockutils/mockutils.go | 5 ++++- hcloud/exp/mockutils/mockutils_test.go | 13 +++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/hcloud/exp/mockutils/mockutils.go b/hcloud/exp/mockutils/mockutils.go index 51d0774f..8c22fd8e 100644 --- a/hcloud/exp/mockutils/mockutils.go +++ b/hcloud/exp/mockutils/mockutils.go @@ -52,19 +52,22 @@ func Handler(t *testing.T, requests []Request) http.HandlerFunc { expected.Want(t, r) } - w.WriteHeader(expected.Status) switch { case expected.JSON != nil: w.Header().Set("Content-Type", "application/json") + w.WriteHeader(expected.Status) if err := json.NewEncoder(w).Encode(expected.JSON); err != nil { t.Fatal(err) } case expected.JSONRaw != "": w.Header().Set("Content-Type", "application/json") + w.WriteHeader(expected.Status) _, err := w.Write([]byte(expected.JSONRaw)) if err != nil { t.Fatal(err) } + default: + w.WriteHeader(expected.Status) } index++ diff --git a/hcloud/exp/mockutils/mockutils_test.go b/hcloud/exp/mockutils/mockutils_test.go index feb9d142..70f79058 100644 --- a/hcloud/exp/mockutils/mockutils_test.go +++ b/hcloud/exp/mockutils/mockutils_test.go @@ -27,6 +27,10 @@ func TestHandler(t *testing.T) { Status: 400, JSONRaw: `{"error": "failed"}`, }, + { + Method: "GET", Path: "/", + Status: 503, + }, })) defer server.Close() @@ -34,13 +38,22 @@ func TestHandler(t *testing.T) { resp, err := http.Get(server.URL) require.NoError(t, err) assert.Equal(t, 200, resp.StatusCode) + assert.Equal(t, "application/json", resp.Header.Get("Content-Type")) assert.Equal(t, `{"data":"Hello"}`, readBody(t, resp)) // Request 2 resp, err = http.Get(server.URL) require.NoError(t, err) assert.Equal(t, 400, resp.StatusCode) + assert.Equal(t, "application/json", resp.Header.Get("Content-Type")) assert.Equal(t, `{"error": "failed"}`, readBody(t, resp)) + + // Request 3 + resp, err = http.Get(server.URL) + require.NoError(t, err) + assert.Equal(t, 503, resp.StatusCode) + assert.Equal(t, "", resp.Header.Get("Content-Type")) + assert.Equal(t, "", readBody(t, resp)) } func readBody(t *testing.T, resp *http.Response) string {