Fix SAMLRealmTests#testReadIdpMetadataFromHttps failures

This commit fixes failures in SAMLRealmTests#testReadIdpMetadataFromHttps. The main test failure is
caused by the test relying too much on timing with a sleep; the sleep has been removed and replaced
with an assert busy. The second issue that was fixed in the test, is the test makes two requests to
the webserver but only one request is queued in the MockWebServer leading to a NPE.

relates elastic/x-pack-elasticsearch#3667

Original commit: elastic/x-pack-elasticsearch@6c7076c990
This commit is contained in:
jaymode 2018-01-22 12:20:52 -07:00
parent e577d2b776
commit 698ad62150
1 changed files with 2 additions and 2 deletions

View File

@ -115,6 +115,7 @@ public class SamlRealmTests extends SamlTestCase {
try (MockWebServer proxyServer = new MockWebServer(sslService.sslContext(Settings.EMPTY), false)) { try (MockWebServer proxyServer = new MockWebServer(sslService.sslContext(Settings.EMPTY), false)) {
proxyServer.start(); proxyServer.start();
proxyServer.enqueue(new MockResponse().setResponseCode(200).setBody(body).addHeader("Content-Type", "application/xml")); proxyServer.enqueue(new MockResponse().setResponseCode(200).setBody(body).addHeader("Content-Type", "application/xml"));
proxyServer.enqueue(new MockResponse().setResponseCode(200).setBody(body).addHeader("Content-Type", "application/xml"));
assertEquals(0, proxyServer.requests().size()); assertEquals(0, proxyServer.requests().size());
Tuple<RealmConfig, SSLService> config = buildConfig("https://localhost:" + proxyServer.getPort()); Tuple<RealmConfig, SSLService> config = buildConfig("https://localhost:" + proxyServer.getPort());
@ -126,8 +127,7 @@ public class SamlRealmTests extends SamlTestCase {
final int firstRequestCount = proxyServer.requests().size(); final int firstRequestCount = proxyServer.requests().size();
assertThat(firstRequestCount, greaterThanOrEqualTo(1)); assertThat(firstRequestCount, greaterThanOrEqualTo(1));
assertIdp1MetadataParsedCorrectly(tuple.v2().get()); assertIdp1MetadataParsedCorrectly(tuple.v2().get());
Thread.sleep(METADATA_REFRESH + 10); assertBusy(() -> assertThat(proxyServer.requests().size(), greaterThan(firstRequestCount)));
assertThat(proxyServer.requests().size(), greaterThan(firstRequestCount));
} finally { } finally {
tuple.v1().destroy(); tuple.v1().destroy();
} }