Merge pull request #10526 from MaineC/bug-fix/10397-update-templates-not-recompiled
Closes #10397: Fix updating indexed search templates.
This commit is contained in:
commit
f857f9e47c
|
@ -25,6 +25,7 @@ import com.google.common.cache.CacheBuilder;
|
||||||
import com.google.common.cache.RemovalListener;
|
import com.google.common.cache.RemovalListener;
|
||||||
import com.google.common.cache.RemovalNotification;
|
import com.google.common.cache.RemovalNotification;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.elasticsearch.ElasticsearchIllegalArgumentException;
|
import org.elasticsearch.ElasticsearchIllegalArgumentException;
|
||||||
import org.elasticsearch.ElasticsearchIllegalStateException;
|
import org.elasticsearch.ElasticsearchIllegalStateException;
|
||||||
|
@ -34,6 +35,7 @@ import org.elasticsearch.action.delete.DeleteResponse;
|
||||||
import org.elasticsearch.action.get.GetRequest;
|
import org.elasticsearch.action.get.GetRequest;
|
||||||
import org.elasticsearch.action.get.GetResponse;
|
import org.elasticsearch.action.get.GetResponse;
|
||||||
import org.elasticsearch.action.index.IndexRequest;
|
import org.elasticsearch.action.index.IndexRequest;
|
||||||
|
import org.elasticsearch.action.index.IndexRequestBuilder;
|
||||||
import org.elasticsearch.action.index.IndexResponse;
|
import org.elasticsearch.action.index.IndexResponse;
|
||||||
import org.elasticsearch.action.indexedscripts.delete.DeleteIndexedScriptRequest;
|
import org.elasticsearch.action.indexedscripts.delete.DeleteIndexedScriptRequest;
|
||||||
import org.elasticsearch.action.indexedscripts.get.GetIndexedScriptRequest;
|
import org.elasticsearch.action.indexedscripts.get.GetIndexedScriptRequest;
|
||||||
|
@ -72,6 +74,7 @@ import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Map.Entry;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
@ -236,30 +239,32 @@ public class ScriptService extends AbstractComponent implements Closeable {
|
||||||
/**
|
/**
|
||||||
* Compiles a script straight-away, or returns the previously compiled and cached script, without checking if it can be executed based on settings.
|
* Compiles a script straight-away, or returns the previously compiled and cached script, without checking if it can be executed based on settings.
|
||||||
*/
|
*/
|
||||||
public CompiledScript compileInternal(String lang, String script, ScriptType scriptType) {
|
public CompiledScript compileInternal(String lang, final String scriptOrId, final ScriptType scriptType) {
|
||||||
assert script != null;
|
assert scriptOrId != null;
|
||||||
assert scriptType != null;
|
assert scriptType != null;
|
||||||
if (lang == null) {
|
if (lang == null) {
|
||||||
lang = defaultLang;
|
lang = defaultLang;
|
||||||
}
|
}
|
||||||
if (logger.isTraceEnabled()) {
|
if (logger.isTraceEnabled()) {
|
||||||
logger.trace("Compiling lang: [{}] type: [{}] script: {}", lang, scriptType, script);
|
logger.trace("Compiling lang: [{}] type: [{}] script: {}", lang, scriptType, scriptOrId);
|
||||||
}
|
}
|
||||||
|
|
||||||
ScriptEngineService scriptEngineService = getScriptEngineServiceForLang(lang);
|
ScriptEngineService scriptEngineService = getScriptEngineServiceForLang(lang);
|
||||||
CacheKey cacheKey = newCacheKey(scriptEngineService, script);
|
CacheKey cacheKey = newCacheKey(scriptEngineService, scriptOrId);
|
||||||
|
|
||||||
if (scriptType == ScriptType.FILE) {
|
if (scriptType == ScriptType.FILE) {
|
||||||
CompiledScript compiled = staticCache.get(cacheKey); //On disk scripts will be loaded into the staticCache by the listener
|
CompiledScript compiled = staticCache.get(cacheKey); //On disk scripts will be loaded into the staticCache by the listener
|
||||||
if (compiled == null) {
|
if (compiled == null) {
|
||||||
throw new ElasticsearchIllegalArgumentException("Unable to find on disk script " + script);
|
throw new ElasticsearchIllegalArgumentException("Unable to find on disk script " + scriptOrId);
|
||||||
}
|
}
|
||||||
return compiled;
|
return compiled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String script = scriptOrId;
|
||||||
if (scriptType == ScriptType.INDEXED) {
|
if (scriptType == ScriptType.INDEXED) {
|
||||||
final IndexedScript indexedScript = new IndexedScript(lang, script);
|
final IndexedScript indexedScript = new IndexedScript(lang, scriptOrId);
|
||||||
script = getScriptFromIndex(indexedScript.lang, indexedScript.id);
|
script = getScriptFromIndex(indexedScript.lang, indexedScript.id);
|
||||||
|
cacheKey = newCacheKey(scriptEngineService, script);
|
||||||
}
|
}
|
||||||
|
|
||||||
CompiledScript compiled = cache.getIfPresent(cacheKey);
|
CompiledScript compiled = cache.getIfPresent(cacheKey);
|
||||||
|
|
|
@ -20,9 +20,11 @@ package org.elasticsearch.index.query;
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
import com.google.common.collect.Maps;
|
||||||
|
|
||||||
|
import org.elasticsearch.action.index.IndexRequest.OpType;
|
||||||
import org.elasticsearch.action.index.IndexRequestBuilder;
|
import org.elasticsearch.action.index.IndexRequestBuilder;
|
||||||
import org.elasticsearch.action.indexedscripts.delete.DeleteIndexedScriptResponse;
|
import org.elasticsearch.action.indexedscripts.delete.DeleteIndexedScriptResponse;
|
||||||
import org.elasticsearch.action.indexedscripts.get.GetIndexedScriptResponse;
|
import org.elasticsearch.action.indexedscripts.get.GetIndexedScriptResponse;
|
||||||
|
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptRequestBuilder;
|
||||||
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptResponse;
|
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptResponse;
|
||||||
import org.elasticsearch.action.search.SearchPhaseExecutionException;
|
import org.elasticsearch.action.search.SearchPhaseExecutionException;
|
||||||
import org.elasticsearch.action.search.SearchRequest;
|
import org.elasticsearch.action.search.SearchRequest;
|
||||||
|
@ -372,6 +374,48 @@ public class TemplateQueryTest extends ElasticsearchIntegrationTest {
|
||||||
assertHitCount(sr, 4);
|
assertHitCount(sr, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Relates to #10397
|
||||||
|
@Test
|
||||||
|
public void testIndexedTemplateOverwrite() throws Exception {
|
||||||
|
createIndex("testindex");
|
||||||
|
ensureGreen("testindex");
|
||||||
|
|
||||||
|
index("testindex", "test", "1", jsonBuilder().startObject().field("searchtext", "dev1").endObject());
|
||||||
|
refresh();
|
||||||
|
|
||||||
|
int iterations = randomIntBetween(2, 11);
|
||||||
|
for (int i = 1; i < iterations; i++) {
|
||||||
|
PutIndexedScriptResponse scriptResponse = client().preparePutIndexedScript(MustacheScriptEngineService.NAME, "git01",
|
||||||
|
"{\"query\": {\"match\": {\"searchtext\": {\"query\": \"{{P_Keyword1}}\",\"type\": \"ooophrase_prefix\"}}}}").get();
|
||||||
|
assertEquals(i * 2 - 1, scriptResponse.getVersion());
|
||||||
|
|
||||||
|
GetIndexedScriptResponse getResponse = client().prepareGetIndexedScript(MustacheScriptEngineService.NAME, "git01").get();
|
||||||
|
assertTrue(getResponse.isExists());
|
||||||
|
|
||||||
|
Map<String, Object> templateParams = Maps.newHashMap();
|
||||||
|
templateParams.put("P_Keyword1", "dev");
|
||||||
|
|
||||||
|
try {
|
||||||
|
client().prepareSearch("testindex").setTypes("test").
|
||||||
|
setTemplateName("git01").setTemplateType(ScriptService.ScriptType.INDEXED).setTemplateParams(templateParams).get();
|
||||||
|
fail("Broken test template is parsing w/o error.");
|
||||||
|
} catch (SearchPhaseExecutionException e) {
|
||||||
|
// the above is expected to fail
|
||||||
|
}
|
||||||
|
|
||||||
|
PutIndexedScriptRequestBuilder builder = client()
|
||||||
|
.preparePutIndexedScript(MustacheScriptEngineService.NAME, "git01",
|
||||||
|
"{\"query\": {\"match\": {\"searchtext\": {\"query\": \"{{P_Keyword1}}\",\"type\": \"phrase_prefix\"}}}}")
|
||||||
|
.setOpType(OpType.INDEX);
|
||||||
|
scriptResponse = builder.get();
|
||||||
|
assertEquals(i * 2, scriptResponse.getVersion());
|
||||||
|
SearchResponse searchResponse = client().prepareSearch("testindex").setTypes("test").
|
||||||
|
setTemplateName("git01").setTemplateType(ScriptService.ScriptType.INDEXED).setTemplateParams(templateParams).get();
|
||||||
|
assertHitCount(searchResponse, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexedTemplateWithArray() throws Exception {
|
public void testIndexedTemplateWithArray() throws Exception {
|
||||||
createIndex(ScriptService.SCRIPT_INDEX);
|
createIndex(ScriptService.SCRIPT_INDEX);
|
||||||
|
|
|
@ -22,6 +22,7 @@ package org.elasticsearch.script;
|
||||||
|
|
||||||
import org.elasticsearch.ExceptionsHelper;
|
import org.elasticsearch.ExceptionsHelper;
|
||||||
import org.elasticsearch.action.index.IndexRequestBuilder;
|
import org.elasticsearch.action.index.IndexRequestBuilder;
|
||||||
|
import org.elasticsearch.action.indexedscripts.put.PutIndexedScriptResponse;
|
||||||
import org.elasticsearch.action.search.SearchResponse;
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
import org.elasticsearch.common.settings.ImmutableSettings;
|
import org.elasticsearch.common.settings.ImmutableSettings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -87,6 +88,30 @@ public class IndexedScriptTests extends ElasticsearchIntegrationTest {
|
||||||
assertThat((Integer)sh.field("test2").getValue(), equalTo(6));
|
assertThat((Integer)sh.field("test2").getValue(), equalTo(6));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Relates to #10397
|
||||||
|
@Test
|
||||||
|
public void testUpdateScripts() {
|
||||||
|
createIndex("test_index");
|
||||||
|
ensureGreen("test_index");
|
||||||
|
client().prepareIndex("test_index", "test_type", "1").setSource("{\"foo\":\"bar\"}").get();
|
||||||
|
flush("test_index");
|
||||||
|
|
||||||
|
int iterations = randomIntBetween(2, 11);
|
||||||
|
for (int i = 1; i < iterations; i++) {
|
||||||
|
PutIndexedScriptResponse response =
|
||||||
|
client().preparePutIndexedScript(GroovyScriptEngineService.NAME, "script1", "{\"script\":\"" + i + "\"}").get();
|
||||||
|
assertEquals(i, response.getVersion());
|
||||||
|
|
||||||
|
String query = "{"
|
||||||
|
+ " \"query\" : { \"match_all\": {}}, "
|
||||||
|
+ " \"script_fields\" : { \"test_field\" : { \"script_id\" : \"script1\", \"lang\":\"groovy\" } } }";
|
||||||
|
SearchResponse searchResponse = client().prepareSearch().setSource(query).setIndices("test_index").setTypes("test_type").get();
|
||||||
|
assertHitCount(searchResponse, 1);
|
||||||
|
SearchHit sh = searchResponse.getHits().getAt(0);
|
||||||
|
assertThat((Integer)sh.field("test_field").getValue(), equalTo(i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDisabledUpdateIndexedScriptsOnly() {
|
public void testDisabledUpdateIndexedScriptsOnly() {
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
|
|
Loading…
Reference in New Issue