Fix merge result

See gh-25706
This commit is contained in:
Juergen Hoeller 2020-09-05 13:12:19 +02:00
parent 9d7849c539
commit 3fd89c3ac1
1 changed files with 0 additions and 55 deletions

View File

@ -83,61 +83,6 @@ class SpelCompilerTests {
return 42; return 42;
} }
} }
@Test // gh-25706
void defaultMethodInvocation() {
SpelParserConfiguration config = new SpelParserConfiguration(SpelCompilerMode.IMMEDIATE, null);
SpelExpressionParser parser = new SpelExpressionParser(config);
StandardEvaluationContext context = new StandardEvaluationContext();
Item item = new Item();
context.setRootObject(item);
Expression expression = parser.parseExpression("#root.isEditable2()");
assertThat(SpelCompiler.compile(expression)).isFalse();
assertThat(expression.getValue(context)).isEqualTo(false);
assertThat(SpelCompiler.compile(expression)).isTrue();
SpelCompilationCoverageTests.assertIsCompiled(expression);
assertThat(expression.getValue(context)).isEqualTo(false);
context.setVariable("user", new User());
expression = parser.parseExpression("#root.isEditable(#user)");
assertThat(SpelCompiler.compile(expression)).isFalse();
assertThat(expression.getValue(context)).isEqualTo(true);
assertThat(SpelCompiler.compile(expression)).isTrue();
SpelCompilationCoverageTests.assertIsCompiled(expression);
assertThat(expression.getValue(context)).isEqualTo(true);
}
public static class User {
boolean isAdmin() {
return true;
}
}
public static class Item implements Editable {
// some fields
private String someField = "";
// some getters and setters
@Override
public boolean hasSomeProperty() {
return someField != null;
}
}
public interface Editable {
default boolean isEditable(User user) {
return user.isAdmin() && hasSomeProperty();
}
default boolean isEditable2() {
return false;
}
boolean hasSomeProperty();
}
public static class User { public static class User {