test/integration: use short timeouts with distinct requests to prevent hangs

Signed-off-by: Monis Khan <mok@vmware.com>
This commit is contained in:
Monis Khan 2021-08-27 16:10:06 -04:00
parent 41c017c9da
commit ba80b691e1
No known key found for this signature in database
GPG Key ID: 52C90ADA01B269B8

View File

@ -392,7 +392,9 @@ func requireDiscoveryEndpointsAreNotFound(t *testing.T, supervisorScheme, superv
func requireEndpointNotFound(t *testing.T, url, host, caBundle string) { func requireEndpointNotFound(t *testing.T, url, host, caBundle string) {
t.Helper() t.Helper()
httpClient := newHTTPClient(t, caBundle, nil) httpClient := newHTTPClient(t, caBundle, nil)
ctx, cancel := context.WithTimeout(context.Background(), 2*time.Minute)
testlib.RequireEventually(t, func(requireEventually *require.Assertions) {
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel() defer cancel()
requestNonExistentPath, err := http.NewRequestWithContext(ctx, http.MethodGet, url, nil) requestNonExistentPath, err := http.NewRequestWithContext(ctx, http.MethodGet, url, nil)
@ -400,7 +402,6 @@ func requireEndpointNotFound(t *testing.T, url, host, caBundle string) {
requestNonExistentPath.Host = host requestNonExistentPath.Host = host
testlib.RequireEventually(t, func(requireEventually *require.Assertions) {
response, err := httpClient.Do(requestNonExistentPath) response, err := httpClient.Do(requestNonExistentPath)
requireEventually.NoError(err) requireEventually.NoError(err)
requireEventually.NoError(response.Body.Close()) requireEventually.NoError(response.Body.Close())
@ -411,10 +412,11 @@ func requireEndpointNotFound(t *testing.T, url, host, caBundle string) {
func requireEndpointHasTLSErrorBecauseCertificatesAreNotReady(t *testing.T, url string) { func requireEndpointHasTLSErrorBecauseCertificatesAreNotReady(t *testing.T, url string) {
t.Helper() t.Helper()
httpClient := newHTTPClient(t, "", nil) httpClient := newHTTPClient(t, "", nil)
ctx, cancel := context.WithTimeout(context.Background(), 2*time.Minute)
defer cancel()
testlib.RequireEventually(t, func(requireEventually *require.Assertions) { testlib.RequireEventually(t, func(requireEventually *require.Assertions) {
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
request, err := http.NewRequestWithContext(ctx, http.MethodGet, url, nil) request, err := http.NewRequestWithContext(ctx, http.MethodGet, url, nil)
requireEventually.NoError(err) requireEventually.NoError(err)
@ -534,7 +536,14 @@ func requireSuccessEndpointResponse(t *testing.T, endpointURL, issuer, caBundle
t.Helper() t.Helper()
httpClient := newHTTPClient(t, caBundle, dnsOverrides) httpClient := newHTTPClient(t, caBundle, dnsOverrides)
ctx, cancel := context.WithTimeout(context.Background(), 2*time.Minute) issuerURL, err := url.Parse(issuer)
require.NoError(t, err)
// Fetch that discovery endpoint. Give it some time for the endpoint to come into existence.
var response *http.Response
var responseBody []byte
testlib.RequireEventually(t, func(requireEventually *require.Assertions) {
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel() defer cancel()
// Define a request to the new discovery endpoint which should have been created by an FederationDomain. // Define a request to the new discovery endpoint which should have been created by an FederationDomain.
@ -544,20 +553,13 @@ func requireSuccessEndpointResponse(t *testing.T, endpointURL, issuer, caBundle
endpointURL, endpointURL,
nil, nil,
) )
require.NoError(t, err) requireEventually.NoError(err)
issuerURL, err := url.Parse(issuer)
require.NoError(t, err)
// Set the host header on the request to match the issuer's hostname, which could potentially be different // Set the host header on the request to match the issuer's hostname, which could potentially be different
// from the public ingress address, e.g. when a load balancer is used, so we want to test here that the host // from the public ingress address, e.g. when a load balancer is used, so we want to test here that the host
// header is respected by the supervisor server. // header is respected by the supervisor server.
requestDiscoveryEndpoint.Host = issuerURL.Host requestDiscoveryEndpoint.Host = issuerURL.Host
// Fetch that discovery endpoint. Give it some time for the endpoint to come into existence.
var response *http.Response
var responseBody []byte
testlib.RequireEventually(t, func(requireEventually *require.Assertions) {
var err error
response, err = httpClient.Do(requestDiscoveryEndpoint) response, err = httpClient.Do(requestDiscoveryEndpoint)
requireEventually.NoError(err) requireEventually.NoError(err)
defer func() { _ = response.Body.Close() }() defer func() { _ = response.Body.Close() }()