aboutsummaryrefslogtreecommitdiff
path: root/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/resolution/JavaParserFacadeResolutionTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/resolution/JavaParserFacadeResolutionTest.java')
-rw-r--r--javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/resolution/JavaParserFacadeResolutionTest.java163
1 files changed, 163 insertions, 0 deletions
diff --git a/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/resolution/JavaParserFacadeResolutionTest.java b/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/resolution/JavaParserFacadeResolutionTest.java
new file mode 100644
index 000000000..37fec2647
--- /dev/null
+++ b/javaparser-symbol-solver-testing/src/test/java/com/github/javaparser/symbolsolver/resolution/JavaParserFacadeResolutionTest.java
@@ -0,0 +1,163 @@
+/*
+ * Copyright 2016 Federico Tomassetti
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.github.javaparser.symbolsolver.resolution;
+
+import com.github.javaparser.*;
+import com.github.javaparser.ast.CompilationUnit;
+import com.github.javaparser.ast.body.ClassOrInterfaceDeclaration;
+import com.github.javaparser.ast.body.FieldDeclaration;
+import com.github.javaparser.ast.expr.Expression;
+import com.github.javaparser.ast.expr.MethodCallExpr;
+import com.github.javaparser.ast.expr.NameExpr;
+import com.github.javaparser.ast.stmt.CatchClause;
+import com.github.javaparser.ast.stmt.TryStmt;
+import com.github.javaparser.ast.type.Type;
+import com.github.javaparser.resolution.MethodUsage;
+import com.github.javaparser.resolution.declarations.ResolvedTypeDeclaration;
+import com.github.javaparser.resolution.declarations.ResolvedValueDeclaration;
+import com.github.javaparser.resolution.types.ResolvedReferenceType;
+import com.github.javaparser.resolution.types.ResolvedType;
+import com.github.javaparser.resolution.types.ResolvedUnionType;
+import com.github.javaparser.symbolsolver.JavaSymbolSolver;
+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.typesolvers.ReflectionTypeSolver;
+import org.junit.Test;
+
+import static org.junit.Assert.assertEquals;
+
+
+public class JavaParserFacadeResolutionTest extends AbstractResolutionTest {
+
+ @Test
+ public void typeDeclarationSuperClassImplicitlyIncludeObject() {
+ CompilationUnit cu = parseSample("Generics");
+ ClassOrInterfaceDeclaration clazz = Navigator.demandClass(cu, "Generics");
+ ResolvedTypeDeclaration typeDeclaration = JavaParserFacade.get(new ReflectionTypeSolver()).getTypeDeclaration(clazz);
+ ResolvedReferenceType superclass = typeDeclaration.asClass().getSuperClass();
+ assertEquals(Object.class.getCanonicalName(), superclass.getQualifiedName());
+ }
+
+ // See issue 42
+ @Test
+ public void solvingReferenceToUnsupportedOperationException() {
+ String code = "public class Bla {\n" +
+ " public void main()\n" +
+ " {\n" +
+ " try\n" +
+ " {\n" +
+ " int i = 0;\n" +
+ " }\n" +
+ " catch (UnsupportedOperationException e)\n" +
+ " {\n" +
+ " String s;\n" +
+ " e.getMessage();\n" +
+ " }\n" +
+ " }\n" +
+ "}";
+ MethodCallExpr methodCallExpr = Navigator.findNodeOfGivenClass(JavaParser.parse(code), MethodCallExpr.class);
+ MethodUsage methodUsage = JavaParserFacade.get(new ReflectionTypeSolver()).solveMethodAsUsage(methodCallExpr);
+ assertEquals("java.lang.Throwable.getMessage()", methodUsage.getQualifiedSignature());
+ }
+
+ // See issue 46
+ @Test
+ public void solvingReferenceToCatchClauseParam() {
+ String code = "public class Bla {\n" +
+ " public void main()\n" +
+ " {\n" +
+ " try\n" +
+ " {\n" +
+ " int i = 0;\n" +
+ " }\n" +
+ " catch (UnsupportedOperationException e)\n" +
+ " {\n" +
+ " String s;\n" +
+ " e.getMessage();\n" +
+ " }\n" +
+ " }\n" +
+ "}";
+ MethodCallExpr methodCallExpr = Navigator.findNodeOfGivenClass(JavaParser.parse(code), MethodCallExpr.class);
+ NameExpr nameE = (NameExpr)methodCallExpr.getScope().get();
+ SymbolReference<? extends ResolvedValueDeclaration> symbolReference = JavaParserFacade.get(new ReflectionTypeSolver()).solve(nameE);
+ assertEquals(true, symbolReference.isSolved());
+ assertEquals(true, symbolReference.getCorrespondingDeclaration().isParameter());
+ assertEquals("e", symbolReference.getCorrespondingDeclaration().asParameter().getName());
+ assertEquals("java.lang.UnsupportedOperationException", symbolReference.getCorrespondingDeclaration().asParameter().getType().asReferenceType().getQualifiedName());
+ }
+
+ // See issue 47
+ @Test
+ public void solvingReferenceToAnAncestorInternalClass() {
+ String code = "public class Foo {\n" +
+ " public class Base {\n" +
+ " public class X {\n" +
+ " }\n" +
+ " }\n" +
+ "\n" +
+ " public class Derived extends Base {\n" +
+ " public X x = null;\n" +
+ " }\n" +
+ "}";
+ FieldDeclaration fieldDeclaration = Navigator.findNodeOfGivenClass(JavaParser.parse(code), FieldDeclaration.class);
+ Type jpType = fieldDeclaration.getCommonType();
+ ResolvedType jssType = JavaParserFacade.get(new ReflectionTypeSolver()).convertToUsage(jpType);
+ assertEquals("Foo.Base.X", jssType.asReferenceType().getQualifiedName());
+ }
+
+ // See issue 119
+ @Test
+ public void solveTryWithResourceVariable() {
+ String code = "import java.util.Scanner; class A { void foo() { try (Scanner sc = new Scanner(System.in)) {\n" +
+ " sc.nextLine();\n" +
+ "} } }";
+ CompilationUnit cu = JavaParser.parse(code);
+ MethodCallExpr methodCallExpr = Navigator.findMethodCall(cu, "nextLine").get();
+ Expression scope = methodCallExpr.getScope().get();
+ ResolvedType type = JavaParserFacade.get(new ReflectionTypeSolver()).getType(scope);
+ assertEquals(true, type.isReferenceType());
+ assertEquals("java.util.Scanner", type.asReferenceType().getQualifiedName());
+ }
+
+ private CompilationUnit parseWithTypeSolver(String code) {
+ TypeSolver typeSolver = new ReflectionTypeSolver();
+ ParserConfiguration parserConfiguration = new ParserConfiguration();
+ parserConfiguration.setSymbolResolver(new JavaSymbolSolver(typeSolver));
+ JavaParser javaParser = new JavaParser(parserConfiguration);
+ return javaParser.parse(ParseStart.COMPILATION_UNIT, new StringProvider(code)).getResult().get();
+ }
+
+ @Test
+ public void solveMultiCatchType() {
+ String code = "class A {\n" +
+ " public void foo() {\n" +
+ " try {\n" +
+ " \n" +
+ " } catch (IllegalStateException | IllegalArgumentException e) {\n" +
+ " \n" +
+ " }\n" +
+ " }\n" +
+ " }";
+ CompilationUnit cu = parseWithTypeSolver(code);
+ CatchClause catchClause = Navigator.findNodeOfGivenClass(cu, CatchClause.class);
+ Type jpType = catchClause.getParameter().getType();
+ ResolvedType jssType = jpType.resolve();
+ assertEquals(true, jssType instanceof ResolvedUnionType);
+ }
+}