tests; added assertBusy(...) to get around the time issue in tests due to the async mapping update for fields introduced in tests.
Closes elastic/elasticsearch#351 Original commit: elastic/x-pack-elasticsearch@0df48aa7e8
This commit is contained in:
parent
b63630496f
commit
e148b7e427
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.watcher.test.integration;
|
package org.elasticsearch.watcher.test.integration;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
|
||||||
import org.elasticsearch.action.admin.indices.mapping.get.GetMappingsResponse;
|
import org.elasticsearch.action.admin.indices.mapping.get.GetMappingsResponse;
|
||||||
import org.elasticsearch.cluster.metadata.MappingMetaData;
|
import org.elasticsearch.cluster.metadata.MappingMetaData;
|
||||||
import org.elasticsearch.common.collect.ImmutableOpenMap;
|
import org.elasticsearch.common.collect.ImmutableOpenMap;
|
||||||
|
@ -15,6 +14,7 @@ import org.elasticsearch.watcher.test.AbstractWatcherIntegrationTests;
|
||||||
import org.elasticsearch.watcher.transport.actions.put.PutWatchResponse;
|
import org.elasticsearch.watcher.transport.actions.put.PutWatchResponse;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static org.elasticsearch.common.xcontent.support.XContentMapValues.extractValue;
|
import static org.elasticsearch.common.xcontent.support.XContentMapValues.extractValue;
|
||||||
|
@ -43,7 +43,6 @@ public class HistoryTemplateTimeMappingsTests extends AbstractWatcherIntegration
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@LuceneTestCase.AwaitsFix(bugUrl = "https://github.com/elastic/elasticsearch-watcher/issues/351")
|
|
||||||
public void testTimeFields() throws Exception {
|
public void testTimeFields() throws Exception {
|
||||||
PutWatchResponse putWatchResponse = watcherClient().preparePutWatch("_id").setSource(watchBuilder()
|
PutWatchResponse putWatchResponse = watcherClient().preparePutWatch("_id").setSource(watchBuilder()
|
||||||
.trigger(schedule(interval("5s")))
|
.trigger(schedule(interval("5s")))
|
||||||
|
@ -60,6 +59,9 @@ public class HistoryTemplateTimeMappingsTests extends AbstractWatcherIntegration
|
||||||
// the action should fail as no email server is available
|
// the action should fail as no email server is available
|
||||||
assertWatchWithMinimumActionsCount("_id", WatchRecord.State.EXECUTED, 1);
|
assertWatchWithMinimumActionsCount("_id", WatchRecord.State.EXECUTED, 1);
|
||||||
refresh();
|
refresh();
|
||||||
|
assertBusy(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
GetMappingsResponse mappingsResponse = client().admin().indices().prepareGetMappings().get();
|
GetMappingsResponse mappingsResponse = client().admin().indices().prepareGetMappings().get();
|
||||||
assertThat(mappingsResponse, notNullValue());
|
assertThat(mappingsResponse, notNullValue());
|
||||||
assertThat(mappingsResponse.getMappings().isEmpty(), is(false));
|
assertThat(mappingsResponse.getMappings().isEmpty(), is(false));
|
||||||
|
@ -69,11 +71,18 @@ public class HistoryTemplateTimeMappingsTests extends AbstractWatcherIntegration
|
||||||
}
|
}
|
||||||
MappingMetaData metadata = metadatas.value.get("watch_record");
|
MappingMetaData metadata = metadatas.value.get("watch_record");
|
||||||
assertThat(metadata, notNullValue());
|
assertThat(metadata, notNullValue());
|
||||||
|
try {
|
||||||
Map<String, Object> source = metadata.getSourceAsMap();
|
Map<String, Object> source = metadata.getSourceAsMap();
|
||||||
logger.info("metadata : [{}]", metadata.source().toString());
|
logger.info("checking index [{}] with metadata:\n[{}]", metadatas.key, metadata.source().toString());
|
||||||
assertThat(extractValue("properties.trigger_event.properties.schedule.properties.scheduled_time.type", source), is((Object) "date"));
|
assertThat(extractValue("properties.trigger_event.properties.schedule.properties.scheduled_time.type", source), is((Object) "date"));
|
||||||
assertThat(extractValue("properties.trigger_event.properties.schedule.properties.triggered_time.type", source), is((Object) "date"));
|
assertThat(extractValue("properties.trigger_event.properties.schedule.properties.triggered_time.type", source), is((Object) "date"));
|
||||||
assertThat(extractValue("properties.watch_execution.properties.execution_time.type", source), is((Object) "date"));
|
assertThat(extractValue("properties.watch_execution.properties.execution_time.type", source), is((Object) "date"));
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue