|
20 | 20 | import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
21 | 21 | import org.elasticsearch.common.xcontent.XContentParser;
|
22 | 22 | import org.elasticsearch.common.xcontent.XContentType;
|
| 23 | +import org.elasticsearch.script.ScriptEngine; |
23 | 24 | import org.elasticsearch.script.ScriptException;
|
24 | 25 | import org.elasticsearch.script.ScriptMetadata;
|
25 | 26 | import org.elasticsearch.script.ScriptModule;
|
26 | 27 | import org.elasticsearch.script.ScriptService;
|
27 | 28 | import org.elasticsearch.script.StoredScriptSource;
|
| 29 | +import org.elasticsearch.script.TemplateScript; |
28 | 30 | import org.elasticsearch.script.mustache.MustacheScriptEngine;
|
29 | 31 | import org.elasticsearch.test.ESTestCase;
|
30 | 32 | import org.elasticsearch.test.EqualsHashCodeTestUtils;
|
|
40 | 42 | import static org.hamcrest.Matchers.containsString;
|
41 | 43 | import static org.hamcrest.Matchers.equalTo;
|
42 | 44 | import static org.hamcrest.Matchers.notNullValue;
|
| 45 | +import static org.mockito.Matchers.any; |
| 46 | +import static org.mockito.Matchers.eq; |
| 47 | +import static org.mockito.Mockito.doThrow; |
43 | 48 | import static org.mockito.Mockito.mock;
|
| 49 | +import static org.mockito.Mockito.never; |
| 50 | +import static org.mockito.Mockito.times; |
| 51 | +import static org.mockito.Mockito.verify; |
44 | 52 | import static org.mockito.Mockito.when;
|
45 | 53 |
|
46 | 54 | public class TemplateRoleNameTests extends ESTestCase {
|
@@ -183,6 +191,49 @@ public void testValidateWillFailForSyntaxError() {
|
183 | 191 | assertTrue(e.getCause() instanceof ScriptException);
|
184 | 192 | }
|
185 | 193 |
|
| 194 | + public void testValidateWillCompileButNotExecutePainlessScript() { |
| 195 | + final TemplateScript compiledScript = mock(TemplateScript.class); |
| 196 | + doThrow(new IllegalStateException("Validate should not execute painless script")).when(compiledScript).execute(); |
| 197 | + final TemplateScript.Factory scriptFactory = mock(TemplateScript.Factory.class); |
| 198 | + when(scriptFactory.newInstance(any())).thenReturn(compiledScript); |
| 199 | + |
| 200 | + final ScriptEngine scriptEngine = mock(ScriptEngine.class); |
| 201 | + when(scriptEngine.getType()).thenReturn("painless"); |
| 202 | + when(scriptEngine.compile(eq("valid"), eq("params.metedata.group"), any(), |
| 203 | + eq(org.elasticsearch.common.collect.Map.of()))) |
| 204 | + .thenReturn(scriptFactory); |
| 205 | + final ScriptException scriptException = |
| 206 | + new ScriptException("exception", new IllegalStateException(), org.elasticsearch.common.collect.List.of(), |
| 207 | + "bad syntax", "painless"); |
| 208 | + doThrow(scriptException) |
| 209 | + .when(scriptEngine).compile(eq("invalid"), eq("bad syntax"), any(), |
| 210 | + eq(org.elasticsearch.common.collect.Map.of())); |
| 211 | + |
| 212 | + final ScriptService scriptService = new ScriptService(Settings.EMPTY, |
| 213 | + org.elasticsearch.common.collect.Map.of("painless", scriptEngine), ScriptModule.CORE_CONTEXTS) { |
| 214 | + @Override |
| 215 | + protected StoredScriptSource getScriptFromClusterState(String id) { |
| 216 | + if ("valid".equals(id)) { |
| 217 | + return new StoredScriptSource("painless", "params.metedata.group", |
| 218 | + org.elasticsearch.common.collect.Map.of()); |
| 219 | + } else { |
| 220 | + return new StoredScriptSource("painless", "bad syntax", |
| 221 | + org.elasticsearch.common.collect.Map.of()); |
| 222 | + } |
| 223 | + } |
| 224 | + }; |
| 225 | + // Validation succeeds if compilation is successful |
| 226 | + new TemplateRoleName(new BytesArray("{ \"id\":\"valid\" }"), Format.STRING).validate(scriptService); |
| 227 | + verify(scriptEngine, times(1)) |
| 228 | + .compile(eq("valid"), eq("params.metedata.group"), any(), eq(org.elasticsearch.common.collect.Map.of())); |
| 229 | + verify(compiledScript, never()).execute(); |
| 230 | + |
| 231 | + // Validation fails if compilation fails |
| 232 | + final IllegalArgumentException e = expectThrows(IllegalArgumentException.class, |
| 233 | + () -> new TemplateRoleName(new BytesArray("{ \"id\":\"invalid\" }"), Format.STRING).validate(scriptService)); |
| 234 | + assertSame(scriptException, e.getCause()); |
| 235 | + } |
| 236 | + |
186 | 237 | public void testValidationWillFailWhenInlineScriptIsNotEnabled() {
|
187 | 238 | final Settings settings = Settings.builder().put("script.allowed_types", ScriptService.ALLOW_NONE).build();
|
188 | 239 | final ScriptService scriptService = new ScriptService(settings,
|
|
0 commit comments