From 1eaac2186c5f1a2c3161254f31b950d045cbd5b1 Mon Sep 17 00:00:00 2001 From: Matt Coley Date: Tue, 5 Mar 2019 16:10:07 -0500 Subject: [PATCH 1/3] Update expression resolver to return null instead of blank string. --- src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java b/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java index 7f552755a..258ed8b88 100644 --- a/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java +++ b/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java @@ -121,7 +121,7 @@ else if (e.getCause() != null && e.getCause() instanceof InvalidArgumentExceptio String.format("Error resolving expression [%s]: " + getRootCauseMessage(e), expression), e, interpreter.getLineNumber(), interpreter.getPosition()))); } - return ""; + return null; } private void validateResult(Object result) { From de9a974bd3e4d7cc40f7308e489d6523ccc3f0c0 Mon Sep 17 00:00:00 2001 From: Matt Coley Date: Tue, 5 Mar 2019 16:14:02 -0500 Subject: [PATCH 2/3] slight fix. --- src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java | 2 +- .../java/com/hubspot/jinjava/el/ExpressionResolverTest.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java b/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java index 258ed8b88..e7135f9f6 100644 --- a/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java +++ b/src/main/java/com/hubspot/jinjava/el/ExpressionResolver.java @@ -63,7 +63,7 @@ public ExpressionResolver(JinjavaInterpreter interpreter, ExpressionFactory expr */ public Object resolveExpression(String expression) { if (StringUtils.isBlank(expression)) { - return ""; + return null; } interpreter.getContext().addResolvedExpression(expression.trim()); diff --git a/src/test/java/com/hubspot/jinjava/el/ExpressionResolverTest.java b/src/test/java/com/hubspot/jinjava/el/ExpressionResolverTest.java index 2ab442708..60a86eb1c 100644 --- a/src/test/java/com/hubspot/jinjava/el/ExpressionResolverTest.java +++ b/src/test/java/com/hubspot/jinjava/el/ExpressionResolverTest.java @@ -454,7 +454,7 @@ public void itBlocksDisabledFunctions() { final JinjavaConfig config = JinjavaConfig.newBuilder().withDisabled(disabled).build(); final RenderResult renderResult = jinjava.renderForResult(template, context, config); - assertEquals("hi ", renderResult.getOutput()); + assertEquals("hi ", renderResult.getOutput()); TemplateError e = renderResult.getErrors().get(0); assertThat(e.getItem()).isEqualTo(ErrorItem.FUNCTION); assertThat(e.getReason()).isEqualTo(ErrorReason.DISABLED); From ebcc216031457b240546dd4abeb37c68e18c37d0 Mon Sep 17 00:00:00 2001 From: Matt Coley Date: Tue, 5 Mar 2019 16:17:44 -0500 Subject: [PATCH 3/3] update tests. --- .../hubspot/jinjava/el/ExtendedSyntaxBuilderTest.java | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/test/java/com/hubspot/jinjava/el/ExtendedSyntaxBuilderTest.java b/src/test/java/com/hubspot/jinjava/el/ExtendedSyntaxBuilderTest.java index 1689a7be5..adc95a2c0 100644 --- a/src/test/java/com/hubspot/jinjava/el/ExtendedSyntaxBuilderTest.java +++ b/src/test/java/com/hubspot/jinjava/el/ExtendedSyntaxBuilderTest.java @@ -274,8 +274,8 @@ public void arrayWithNegativeIndices() { assertThat(val("stringToSplit.split('-')")).isEqualTo(new String[]{ "one", "two", "three", "four", "five" }); assertThat(val("stringToSplit.split('-')[-1]")).isEqualTo("five"); - assertThat(val("stringToSplit.split('-')[1.5]")).isEqualTo(""); - assertThat(val("stringToSplit.split('-')[-1.5]")).isEqualTo(""); + assertThat(val("stringToSplit.split('-')[1.5]")).isEqualTo(null); + assertThat(val("stringToSplit.split('-')[-1.5]")).isEqualTo(null); // out of range returns null, as -6 + the length of the array is still // negative, and java doesn't support negative array indices. @@ -287,7 +287,7 @@ public void arrayWithNegativeIndices() { @Test public void invalidNestedAssignmentExpr() { - assertThat(val("content.template_path = 'Custom/Email/Responsive/testing.html'")).isEqualTo(""); + assertThat(val("content.template_path = 'Custom/Email/Responsive/testing.html'")).isEqualTo(null); assertThat(interpreter.getErrorsCopy()).isNotEmpty(); assertThat(interpreter.getErrorsCopy().get(0).getReason()).isEqualTo(ErrorReason.SYNTAX_ERROR); assertThat(interpreter.getErrorsCopy().get(0).getMessage()).containsIgnoringCase("identifier"); @@ -295,7 +295,7 @@ public void invalidNestedAssignmentExpr() { @Test public void invalidIdentifierAssignmentExpr() { - assertThat(val("content = 'Custom/Email/Responsive/testing.html'")).isEqualTo(""); + assertThat(val("content = 'Custom/Email/Responsive/testing.html'")).isEqualTo(null); assertThat(interpreter.getErrorsCopy()).isNotEmpty(); assertThat(interpreter.getErrorsCopy().get(0).getReason()).isEqualTo(ErrorReason.SYNTAX_ERROR); assertThat(interpreter.getErrorsCopy().get(0).getMessage()).containsIgnoringCase("'='"); @@ -303,7 +303,7 @@ public void invalidIdentifierAssignmentExpr() { @Test public void invalidPipeOperatorExpr() { - assertThat(val("topics|1")).isEqualTo(""); + assertThat(val("topics|1")).isEqualTo(null); assertThat(interpreter.getErrorsCopy()).isNotEmpty(); assertThat(interpreter.getErrorsCopy().get(0).getReason()).isEqualTo(ErrorReason.SYNTAX_ERROR); }