mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 06:17:27 -08:00
remote-write: refactor TestClientRetryAfter
The new version features a set of test cases that simplify the addition of new HTTP status codes. Signed-off-by: William Dumont <william.dumont@grafana.com>
This commit is contained in:
parent
9b85354acd
commit
febd62a23e
|
@ -85,12 +85,21 @@ func TestStoreHTTPErrorHandling(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestClientRetryAfter(t *testing.T) {
|
func TestClientRetryAfter(t *testing.T) {
|
||||||
server := httptest.NewServer(
|
setupServer := func(statusCode int) *httptest.Server {
|
||||||
|
return httptest.NewServer(
|
||||||
http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
http.Error(w, longErrMessage, http.StatusTooManyRequests)
|
http.Error(w, longErrMessage, statusCode)
|
||||||
}),
|
}),
|
||||||
)
|
)
|
||||||
defer server.Close()
|
}
|
||||||
|
|
||||||
|
getClientConfig := func(serverURL *url.URL, retryOnRateLimit bool) *ClientConfig {
|
||||||
|
return &ClientConfig{
|
||||||
|
URL: &config_util.URL{URL: serverURL},
|
||||||
|
Timeout: model.Duration(time.Second),
|
||||||
|
RetryOnRateLimit: retryOnRateLimit,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
getClient := func(conf *ClientConfig) WriteClient {
|
getClient := func(conf *ClientConfig) WriteClient {
|
||||||
hash, err := toHash(conf)
|
hash, err := toHash(conf)
|
||||||
|
@ -100,30 +109,31 @@ func TestClientRetryAfter(t *testing.T) {
|
||||||
return c
|
return c
|
||||||
}
|
}
|
||||||
|
|
||||||
|
testCases := []struct {
|
||||||
|
name string
|
||||||
|
statusCode int
|
||||||
|
retryOnRateLimit bool
|
||||||
|
expectedRecoverable bool
|
||||||
|
}{
|
||||||
|
{"TooManyRequests - No Retry", http.StatusTooManyRequests, false, false},
|
||||||
|
{"TooManyRequests - With Retry", http.StatusTooManyRequests, true, true},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tc := range testCases {
|
||||||
|
t.Run(tc.name, func(t *testing.T) {
|
||||||
|
server := setupServer(tc.statusCode)
|
||||||
|
defer server.Close()
|
||||||
|
|
||||||
serverURL, err := url.Parse(server.URL)
|
serverURL, err := url.Parse(server.URL)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
conf := &ClientConfig{
|
c := getClient(getClientConfig(serverURL, tc.retryOnRateLimit))
|
||||||
URL: &config_util.URL{URL: serverURL},
|
|
||||||
Timeout: model.Duration(time.Second),
|
|
||||||
RetryOnRateLimit: false,
|
|
||||||
}
|
|
||||||
|
|
||||||
var recErr RecoverableError
|
var recErr RecoverableError
|
||||||
|
|
||||||
c := getClient(conf)
|
|
||||||
err = c.Store(context.Background(), []byte{}, 0)
|
err = c.Store(context.Background(), []byte{}, 0)
|
||||||
require.False(t, errors.As(err, &recErr), "Recoverable error not expected.")
|
require.Equal(t, tc.expectedRecoverable, errors.As(err, &recErr), "Mismatch in expected recoverable error status.")
|
||||||
|
})
|
||||||
conf = &ClientConfig{
|
|
||||||
URL: &config_util.URL{URL: serverURL},
|
|
||||||
Timeout: model.Duration(time.Second),
|
|
||||||
RetryOnRateLimit: true,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
c = getClient(conf)
|
|
||||||
err = c.Store(context.Background(), []byte{}, 0)
|
|
||||||
require.True(t, errors.As(err, &recErr), "Recoverable error was expected.")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRetryAfterDuration(t *testing.T) {
|
func TestRetryAfterDuration(t *testing.T) {
|
||||||
|
|
Loading…
Reference in a new issue