From 2ebe2f847c535180873ff9ca94a853b19d4943a2 Mon Sep 17 00:00:00 2001 From: Anton Miniailo Date: Sun, 28 Jul 2024 22:53:26 -0400 Subject: [PATCH 1/2] Fix flaky test again. --- lib/srv/alpnproxy/local_proxy_test.go | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/lib/srv/alpnproxy/local_proxy_test.go b/lib/srv/alpnproxy/local_proxy_test.go index efb89fb66da5b..f9c7f24716ce2 100644 --- a/lib/srv/alpnproxy/local_proxy_test.go +++ b/lib/srv/alpnproxy/local_proxy_test.go @@ -533,12 +533,18 @@ func TestKubeMiddleware(t *testing.T) { err := km.CheckAndSetDefaults() require.NoError(t, err) - rw := responsewriters.NewMemoryResponseWriter() - // HandleRequest will reissue certificate if needed. - km.HandleRequest(rw, req) - - // request timed out. - require.Equal(t, http.StatusInternalServerError, rw.Status()) + var rw *responsewriters.MemoryResponseWriter + // We use `require.Eventually` to avoid a very rare test flakiness case when reissue goroutine manages to + // successfully finish before the parent goroutine has a chance to check the context (and see that it's expired). + require.Eventually(t, func() bool { + rw = responsewriters.NewMemoryResponseWriter() + // HandleRequest will reissue certificate if needed. + km.HandleRequest(rw, req) + + // request timed out. + return rw.Status() == http.StatusInternalServerError + + }, time.Second, 100*time.Millisecond) require.Contains(t, rw.Buffer().String(), "context canceled") // just let the reissuing goroutine some time to replace certs. From b805b1b14debbf500d2d2e536fdae7e4d139837c Mon Sep 17 00:00:00 2001 From: Anton Miniailo Date: Mon, 29 Jul 2024 23:16:12 -0400 Subject: [PATCH 2/2] Increase timeout to 5 seconds. --- lib/srv/alpnproxy/local_proxy_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/srv/alpnproxy/local_proxy_test.go b/lib/srv/alpnproxy/local_proxy_test.go index f9c7f24716ce2..c025bd41f41be 100644 --- a/lib/srv/alpnproxy/local_proxy_test.go +++ b/lib/srv/alpnproxy/local_proxy_test.go @@ -544,7 +544,7 @@ func TestKubeMiddleware(t *testing.T) { // request timed out. return rw.Status() == http.StatusInternalServerError - }, time.Second, 100*time.Millisecond) + }, 5*time.Second, 100*time.Millisecond) require.Contains(t, rw.Buffer().String(), "context canceled") // just let the reissuing goroutine some time to replace certs.