Issue1950Test.java
/*
* Copyright (C) 2013-2024 The JavaParser Team.
*
* This file is part of JavaParser.
*
* JavaParser can be used either under the terms of
* a) the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
* b) the terms of the Apache License
*
* You should have received a copy of both licenses in LICENCE.LGPL and
* LICENCE.APACHE. Please refer to those files for details.
*
* JavaParser is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*/
package com.github.javaparser.symbolsolver;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertTrue;
import com.github.javaparser.ParserConfiguration;
import com.github.javaparser.StaticJavaParser;
import com.github.javaparser.ast.CompilationUnit;
import com.github.javaparser.ast.expr.MethodCallExpr;
import com.github.javaparser.resolution.TypeSolver;
import com.github.javaparser.resolution.declarations.ResolvedMethodDeclaration;
import com.github.javaparser.symbolsolver.resolution.AbstractResolutionTest;
import com.github.javaparser.symbolsolver.resolution.typesolvers.ReflectionTypeSolver;
import org.junit.jupiter.api.Test;
public class Issue1950Test extends AbstractResolutionTest {
@Test
public void test() {
TypeSolver typeSolver = new ReflectionTypeSolver(false);
ParserConfiguration config = new ParserConfiguration();
config.setSymbolResolver(new JavaSymbolSolver(typeSolver));
StaticJavaParser.setConfiguration(config);
String s = "import java.util.concurrent.Callable;\n" + "class Foo { \n"
+ " void foo() {\n"
+ " method(()->{});\n"
+ " }\n"
+ " public void method(Runnable lambda) {\n"
+ " }\n"
+ " public <T> void method(Callable<T> lambda) {\n"
+ " }\n"
+ "}";
CompilationUnit cu = StaticJavaParser.parse(s);
MethodCallExpr mce = cu.findFirst(MethodCallExpr.class).get();
ResolvedMethodDeclaration resolved = mce.resolve();
// 15.12.2.5. Choosing the Most Specific Method
// One applicable method m1 is more specific than another applicable method m2, for an invocation with argument
// expressions e1, ..., ek, if any of the following are true:
// m2 is generic, and m1 is inferred to be more specific than m2 for argument expressions e1, ..., ek by
// ��18.5.4.
assertEquals("java.lang.Runnable", resolved.getParam(0).getType().describe());
assertTrue(!resolved.isGeneric());
}
}