Bring Watcher inline with es script changes

This change allows watcher to compile against the latest es core scripting changes.
Instantiate compiled scripts and use those in tests.

Original commit: elastic/x-pack-elasticsearch@edd46a089f
This commit is contained in:
Brian Murphy 2015-07-12 22:00:48 -04:00
parent 4cf56aef12
commit 53a5aa373b
3 changed files with 20 additions and 13 deletions

View File

@ -61,7 +61,7 @@ public class XMustacheScriptEngineService extends AbstractComponent implements S
* Execute a compiled template object (as retrieved from the compile method) * Execute a compiled template object (as retrieved from the compile method)
* and fill potential place holders with the variables given. * and fill potential place holders with the variables given.
* *
* @param template * @param compiledScript
* compiled template object. * compiled template object.
* @param vars * @param vars
* map of variables to use during substitution. * map of variables to use during substitution.
@ -69,10 +69,10 @@ public class XMustacheScriptEngineService extends AbstractComponent implements S
* @return the processed string with all given variables substitued. * @return the processed string with all given variables substitued.
* */ * */
@Override @Override
public Object execute(Object template, Map<String, Object> vars) { public Object execute(CompiledScript compiledScript, Map<String, Object> vars) {
BytesStreamOutput result = new BytesStreamOutput(); BytesStreamOutput result = new BytesStreamOutput();
UTF8StreamWriter writer = utf8StreamWriter().setOutput(result); UTF8StreamWriter writer = utf8StreamWriter().setOutput(result);
((Mustache) template).execute(writer, vars); ((Mustache) compiledScript.compiled()).execute(writer, vars);
try { try {
writer.flush(); writer.flush();
} catch (IOException e) { } catch (IOException e) {
@ -103,13 +103,13 @@ public class XMustacheScriptEngineService extends AbstractComponent implements S
} }
@Override @Override
public ExecutableScript executable(Object mustache, public ExecutableScript executable(CompiledScript compiledScript,
@Nullable Map<String, Object> vars) { @Nullable Map<String, Object> vars) {
return new MustacheExecutableScript((Mustache) mustache, vars); return new MustacheExecutableScript((Mustache) compiledScript.compiled(), vars);
} }
@Override @Override
public SearchScript search(Object compiledScript, SearchLookup lookup, public SearchScript search(CompiledScript compiledScript, SearchLookup lookup,
@Nullable Map<String, Object> vars) { @Nullable Map<String, Object> vars) {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
} }

View File

@ -8,6 +8,8 @@ package org.elasticsearch.watcher.support.template.xmustache;
import org.elasticsearch.common.bytes.BytesReference; import org.elasticsearch.common.bytes.BytesReference;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.script.CompiledScript;
import org.elasticsearch.script.ScriptService;
import org.elasticsearch.test.ElasticsearchTestCase; import org.elasticsearch.test.ElasticsearchTestCase;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@ -37,7 +39,8 @@ public class XMustacheScriptEngineTests extends ElasticsearchTestCase {
+ "\"negative\": {\"term\": {\"body\": {\"value\": \"solr\"}" + "}}, \"negative_boost\": {{boost_val}} } }}"; + "\"negative\": {\"term\": {\"body\": {\"value\": \"solr\"}" + "}}, \"negative_boost\": {{boost_val}} } }}";
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
vars.put("boost_val", "0.3"); vars.put("boost_val", "0.3");
BytesReference o = (BytesReference) engine.execute(engine.compile(template), vars); CompiledScript compiledScript = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
BytesReference o = (BytesReference) engine.execute(compiledScript, vars);
assertEquals("GET _search {\"query\": {\"boosting\": {\"positive\": {\"match\": {\"body\": \"gift\"}}," assertEquals("GET _search {\"query\": {\"boosting\": {\"positive\": {\"match\": {\"body\": \"gift\"}},"
+ "\"negative\": {\"term\": {\"body\": {\"value\": \"solr\"}}}, \"negative_boost\": 0.3 } }}", + "\"negative\": {\"term\": {\"body\": {\"value\": \"solr\"}}}, \"negative_boost\": 0.3 } }}",
new String(o.toBytes(), Charset.forName("UTF-8"))); new String(o.toBytes(), Charset.forName("UTF-8")));
@ -48,7 +51,8 @@ public class XMustacheScriptEngineTests extends ElasticsearchTestCase {
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
vars.put("boost_val", "0.3"); vars.put("boost_val", "0.3");
vars.put("body_val", "\"quick brown\""); vars.put("body_val", "\"quick brown\"");
BytesReference o = (BytesReference) engine.execute(engine.compile(template), vars); CompiledScript compiledScript = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
BytesReference o = (BytesReference) engine.execute(compiledScript, vars);
assertEquals("GET _search {\"query\": {\"boosting\": {\"positive\": {\"match\": {\"body\": \"gift\"}}," assertEquals("GET _search {\"query\": {\"boosting\": {\"positive\": {\"match\": {\"body\": \"gift\"}},"
+ "\"negative\": {\"term\": {\"body\": {\"value\": \"\\\"quick brown\\\"\"}}}, \"negative_boost\": 0.3 } }}", + "\"negative\": {\"term\": {\"body\": {\"value\": \"\\\"quick brown\\\"\"}}}, \"negative_boost\": 0.3 } }}",
new String(o.toBytes(), Charset.forName("UTF-8"))); new String(o.toBytes(), Charset.forName("UTF-8")));
@ -73,7 +77,8 @@ public class XMustacheScriptEngineTests extends ElasticsearchTestCase {
vars.put("test_var1", var1Writer.toString()); vars.put("test_var1", var1Writer.toString());
vars.put("test_var2", var2Writer.toString()); vars.put("test_var2", var2Writer.toString());
BytesReference o = (BytesReference) engine.execute(engine.compile(template), vars); CompiledScript compiledScript = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
BytesReference o = (BytesReference) engine.execute(compiledScript, vars);
String s1 = o.toUtf8(); String s1 = o.toUtf8();
String s2 = prefix + " " + var1Writer.toString() + " " + var2Writer.toString(); String s2 = prefix + " " + var1Writer.toString() + " " + var2Writer.toString();
assertEquals(s1, s2); assertEquals(s1, s2);

View File

@ -13,7 +13,9 @@ import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentType; import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.script.CompiledScript;
import org.elasticsearch.script.ScriptEngineService; import org.elasticsearch.script.ScriptEngineService;
import org.elasticsearch.script.ScriptService;
import org.elasticsearch.test.ElasticsearchTestCase; import org.elasticsearch.test.ElasticsearchTestCase;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
@ -40,7 +42,7 @@ public class XMustacheTests extends ElasticsearchTestCase {
@Test @Test
public void testArrayAccess() throws Exception { public void testArrayAccess() throws Exception {
String template = "{{data.0}} {{data.1}}"; String template = "{{data.0}} {{data.1}}";
Object mustache = engine.compile(template); CompiledScript mustache = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
Object data = randomFrom( Object data = randomFrom(
new String[] { "foo", "bar" }, new String[] { "foo", "bar" },
@ -57,7 +59,7 @@ public class XMustacheTests extends ElasticsearchTestCase {
@Test @Test
public void testArrayInArrayAccess() throws Exception { public void testArrayInArrayAccess() throws Exception {
String template = "{{data.0.0}} {{data.0.1}}"; String template = "{{data.0.0}} {{data.0.1}}";
Object mustache = engine.compile(template); CompiledScript mustache = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
Object data = randomFrom( Object data = randomFrom(
new String[][] { new String[] {"foo", "bar" }}, new String[][] { new String[] {"foo", "bar" }},
@ -75,7 +77,7 @@ public class XMustacheTests extends ElasticsearchTestCase {
@Test @Test
public void testMapInArrayAccess() throws Exception { public void testMapInArrayAccess() throws Exception {
String template = "{{data.0.key}} {{data.1.key}}"; String template = "{{data.0.key}} {{data.1.key}}";
Object mustache = engine.compile(template); CompiledScript mustache = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
Map<String, Object> vars = new HashMap<>(); Map<String, Object> vars = new HashMap<>();
Object data = randomFrom( Object data = randomFrom(
new Map[] { ImmutableMap.<String, Object>of("key", "foo"), ImmutableMap.<String, Object>of("key", "bar") }, new Map[] { ImmutableMap.<String, Object>of("key", "foo"), ImmutableMap.<String, Object>of("key", "bar") },
@ -132,7 +134,7 @@ public class XMustacheTests extends ElasticsearchTestCase {
Map<String, Object> dataMap = new HashMap<>(); Map<String, Object> dataMap = new HashMap<>();
dataMap.put("data", unescaped.toString()); dataMap.put("data", unescaped.toString());
Object mustache = engine.compile(template); CompiledScript mustache = new CompiledScript(ScriptService.ScriptType.INLINE, "inline", "mustache", engine.compile(template));
Object output = engine.execute(mustache, dataMap); Object output = engine.execute(mustache, dataMap);
assertThat(output, notNullValue()); assertThat(output, notNullValue());