[TEST] Wait for all ML index template before ML security tests (elastic/x-pack-elasticsearch#1148)

Previously we were only waiting for the results index template

Original commit: elastic/x-pack-elasticsearch@3a9e6ab82f
This commit is contained in:
David Roberts 2017-04-21 07:50:10 +01:00 committed by GitHub
parent fc316bd947
commit 5b19b8e7f0
1 changed files with 49 additions and 26 deletions

View File

@ -9,6 +9,7 @@ import com.carrotsearch.randomizedtesting.annotations.Name;
import com.carrotsearch.randomizedtesting.annotations.ParametersFactory; import com.carrotsearch.randomizedtesting.annotations.ParametersFactory;
import org.apache.http.HttpStatus; import org.apache.http.HttpStatus;
import org.elasticsearch.common.CheckedFunction;
import org.elasticsearch.common.settings.SecureString; import org.elasticsearch.common.settings.SecureString;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.util.concurrent.ThreadContext; import org.elasticsearch.common.util.concurrent.ThreadContext;
@ -17,16 +18,18 @@ import org.elasticsearch.test.rest.yaml.ClientYamlTestResponse;
import org.elasticsearch.test.rest.yaml.ESClientYamlSuiteTestCase; import org.elasticsearch.test.rest.yaml.ESClientYamlSuiteTestCase;
import org.elasticsearch.xpack.ml.MachineLearningTemplateRegistry; import org.elasticsearch.xpack.ml.MachineLearningTemplateRegistry;
import org.elasticsearch.xpack.ml.integration.MlRestTestStateCleaner; import org.elasticsearch.xpack.ml.integration.MlRestTestStateCleaner;
import org.elasticsearch.xpack.ml.job.persistence.AnomalyDetectorsIndex;
import org.elasticsearch.xpack.security.SecurityLifecycleService; import org.elasticsearch.xpack.security.SecurityLifecycleService;
import org.junit.After; import org.junit.After;
import org.junit.Before; import org.junit.Before;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.atomic.AtomicReference; import java.util.concurrent.atomic.AtomicReference;
import java.util.function.Supplier;
import static org.elasticsearch.xpack.security.authc.support.UsernamePasswordToken.basicAuthHeaderValue; import static org.elasticsearch.xpack.security.authc.support.UsernamePasswordToken.basicAuthHeaderValue;
@ -46,40 +49,60 @@ public class MlWithSecurityIT extends ESClientYamlSuiteTestCase {
} }
/** /**
* Waits for the Security and .ml-anomalies templates to be created by the {@link SecurityLifecycleService} * Waits for the Security template to be created by the {@link SecurityLifecycleService} and
* and {@link MachineLearningTemplateRegistry}. * the Machine Learning templates to be created by {@link MachineLearningTemplateRegistry}
*/ */
@Before @Before
public void waitForIndexTemplates() throws Exception { public void waitForTemplates() throws Exception {
String templateApi = "indices.exists_template"; List<String> templates = new ArrayList<>();
Map<String, String> securityParams = Collections.singletonMap("name", SecurityLifecycleService.SECURITY_TEMPLATE_NAME); templates.add(SecurityLifecycleService.SECURITY_TEMPLATE_NAME);
Map<String, String> anomaliesParams = Collections.singletonMap("name", AnomalyDetectorsIndex.jobResultsIndexPrefix()); templates.addAll(Arrays.asList(MachineLearningTemplateRegistry.TEMPLATE_NAMES));
Map<String, String> headers = Collections.singletonMap("Authorization",
basicAuthHeaderValue(TEST_ADMIN_USERNAME, new SecureString(TEST_ADMIN_PASSWORD.toCharArray())));
for (Map<String, String> params : Arrays.asList(securityParams, anomaliesParams)) { for (String template : templates) {
AtomicReference<IOException> exceptionHolder = new AtomicReference<>(); awaitCallApi("indices.exists_template", Collections.singletonMap("name", template), Collections.emptyList(),
awaitBusy(() -> { response -> true,
try { () -> "Exception when waiting for [" + template + "] template to be created");
ClientYamlTestResponse response = getAdminExecutionContext().callApi(templateApi, params, Collections.emptyList(), }
headers); }
if (response.getStatusCode() == HttpStatus.SC_OK) {
exceptionHolder.set(null); /**
return true; * Executes an API call using the admin context, waiting for it to succeed.
} */
} catch (IOException e) { private void awaitCallApi(String apiName,
exceptionHolder.set(e); Map<String, String> params,
List<Map<String, Object>> bodies,
CheckedFunction<ClientYamlTestResponse, Boolean, IOException> success,
Supplier<String> error) throws Exception {
AtomicReference<IOException> exceptionHolder = new AtomicReference<>();
awaitBusy(() -> {
try {
ClientYamlTestResponse response = callApi(apiName, params, bodies);
if (response.getStatusCode() == HttpStatus.SC_OK) {
exceptionHolder.set(null);
return success.apply(response);
} }
return false; return false;
}); } catch (IOException e) {
exceptionHolder.set(e);
IOException exception = exceptionHolder.get();
if (exception != null) {
throw new IllegalStateException("Exception when waiting for index template to be created", exception);
} }
return false;
});
IOException exception = exceptionHolder.get();
if (exception != null) {
throw new IllegalStateException(error.get(), exception);
} }
} }
private ClientYamlTestResponse callApi(String apiName,
Map<String, String> params,
List<Map<String, Object>> bodies) throws IOException {
Map<String, String> headers = Collections.singletonMap("Authorization",
basicAuthHeaderValue(TEST_ADMIN_USERNAME, new SecureString(TEST_ADMIN_PASSWORD.toCharArray())));
return getAdminExecutionContext().callApi(apiName, params, bodies, headers);
}
@ParametersFactory @ParametersFactory
public static Iterable<Object[]> parameters() throws Exception { public static Iterable<Object[]> parameters() throws Exception {
return ESClientYamlSuiteTestCase.createParameters(); return ESClientYamlSuiteTestCase.createParameters();