From 0996b78326fd8d41ba32e4670085599b5e63f542 Mon Sep 17 00:00:00 2001 From: machine424 Date: Thu, 9 Nov 2023 15:38:35 +0100 Subject: [PATCH] remote_write: add a unit test to make sure the write client sends the extra http headers as expected This will help letting prometheus off the hook from situations like https://github.com/prometheus/prometheus/issues/13030 Signed-off-by: machine424 --- storage/remote/client_test.go | 40 +++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) diff --git a/storage/remote/client_test.go b/storage/remote/client_test.go index 33ae7e4686..2acb8e279a 100644 --- a/storage/remote/client_test.go +++ b/storage/remote/client_test.go @@ -168,3 +168,43 @@ func TestRetryAfterDuration(t *testing.T) { require.Equal(t, c.expected, retryAfterDuration(c.tInput), c.name) } } + +func TestClientHeaders(t *testing.T) { + headersToSend := map[string]string{"Foo": "Bar", "Baz": "qux"} + + var called bool + server := httptest.NewServer( + http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + called = true + receivedHeaders := r.Header + for name, value := range headersToSend { + require.Equal( + t, + []string{value}, + receivedHeaders.Values(name), + "expected %v to be part of the received headers %v", + headersToSend, + receivedHeaders, + ) + } + }), + ) + defer server.Close() + + serverURL, err := url.Parse(server.URL) + require.NoError(t, err) + + conf := &ClientConfig{ + URL: &config_util.URL{URL: serverURL}, + Timeout: model.Duration(time.Second), + Headers: headersToSend, + } + + c, err := NewWriteClient("c", conf) + require.NoError(t, err) + + err = c.Store(context.Background(), []byte{}, 0) + require.NoError(t, err) + + require.True(t, called, "The remote server wasn't called") +}