aboutsummaryrefslogtreecommitdiffstats
path: root/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/Issue314.java
diff options
context:
space:
mode:
Diffstat (limited to 'javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/Issue314.java')
-rw-r--r--javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/Issue314.java58
1 files changed, 58 insertions, 0 deletions
diff --git a/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/Issue314.java b/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/Issue314.java
new file mode 100644
index 000000000..b20ff7914
--- /dev/null
+++ b/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/Issue314.java
@@ -0,0 +1,58 @@
+package com.github.javaparser.symbolsolver;
+
+import com.github.javaparser.JavaParser;
+import com.github.javaparser.ast.CompilationUnit;
+import com.github.javaparser.ast.expr.*;
+import com.github.javaparser.resolution.declarations.ResolvedValueDeclaration;
+import com.github.javaparser.resolution.types.ResolvedType;
+import com.github.javaparser.symbolsolver.javaparser.Navigator;
+import com.github.javaparser.symbolsolver.javaparsermodel.JavaParserFacade;
+import com.github.javaparser.symbolsolver.model.resolution.SymbolReference;
+import com.github.javaparser.symbolsolver.model.resolution.TypeSolver;
+import com.github.javaparser.symbolsolver.resolution.AbstractResolutionTest;
+import com.github.javaparser.symbolsolver.resolution.typesolvers.ReflectionTypeSolver;
+import org.junit.Before;
+import org.junit.Test;
+
+import java.io.FileNotFoundException;
+
+import static org.junit.Assert.assertEquals;
+
+public class Issue314 extends AbstractResolutionTest{
+
+ private TypeSolver typeResolver;
+ private JavaParserFacade javaParserFacade;
+
+ private ResolvedType getExpressionType(TypeSolver typeSolver, Expression expression) {
+ return JavaParserFacade.get(typeSolver).getType(expression);
+ }
+
+ @Before
+ public void setup() {
+ typeResolver = new ReflectionTypeSolver();
+ javaParserFacade = JavaParserFacade.get(typeResolver);
+ }
+
+ @Test
+ public void resolveReferenceToFieldInheritedByInterface() {
+ String code = "package foo.bar;\n"+
+ "interface A {\n" +
+ " int a = 0;\n" +
+ " }\n" +
+ " \n" +
+ " class B implements A {\n" +
+ " int getA() {\n" +
+ " return a;\n" +
+ " }\n" +
+ " }";
+ CompilationUnit cu = JavaParser.parse(code);
+ NameExpr refToA = Navigator.findNameExpression(Navigator.demandClass(cu, "B"), "a").get();
+ SymbolReference<? extends ResolvedValueDeclaration> symbolReference = javaParserFacade.solve(refToA);
+ assertEquals(true, symbolReference.isSolved());
+ assertEquals(true, symbolReference.getCorrespondingDeclaration().isField());
+ assertEquals("a", symbolReference.getCorrespondingDeclaration().getName());
+ }
+
+
+
+}