2012-11-17 19:01:03 +00:00
|
|
|
/*
|
2015-05-21 11:41:04 -07:00
|
|
|
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved.
|
2012-11-17 19:01:03 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code 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 General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
2015-08-31 17:33:34 +01:00
|
|
|
* @bug 8003280 8004102 8006694 8129962
|
2012-11-17 19:01:03 +00:00
|
|
|
* @summary Add lambda tests
|
|
|
|
* perform several automated checks in lambda conversion, esp. around accessibility
|
2013-01-23 20:57:40 +00:00
|
|
|
* temporarily workaround combo tests are causing time out in several platforms
|
2015-08-31 17:33:34 +01:00
|
|
|
* @library /tools/javac/lib
|
|
|
|
* @modules jdk.compiler/com.sun.tools.javac.api
|
|
|
|
* jdk.compiler/com.sun.tools.javac.code
|
|
|
|
* jdk.compiler/com.sun.tools.javac.comp
|
|
|
|
* jdk.compiler/com.sun.tools.javac.main
|
|
|
|
* jdk.compiler/com.sun.tools.javac.tree
|
|
|
|
* jdk.compiler/com.sun.tools.javac.util
|
|
|
|
* @build combo.ComboTestHelper
|
|
|
|
* @run main FunctionalInterfaceConversionTest
|
2012-11-17 19:01:03 +00:00
|
|
|
*/
|
|
|
|
|
2013-01-08 13:47:57 +00:00
|
|
|
import java.io.IOException;
|
2015-08-31 17:33:34 +01:00
|
|
|
|
|
|
|
import combo.ComboInstance;
|
|
|
|
import combo.ComboParameter;
|
|
|
|
import combo.ComboTask.Result;
|
|
|
|
import combo.ComboTestHelper;
|
|
|
|
|
|
|
|
|
|
|
|
public class FunctionalInterfaceConversionTest extends ComboInstance<FunctionalInterfaceConversionTest> {
|
|
|
|
|
|
|
|
enum PackageKind implements ComboParameter {
|
2012-11-17 19:01:03 +00:00
|
|
|
NO_PKG(""),
|
|
|
|
PKG_A("a");
|
|
|
|
|
|
|
|
String pkg;
|
|
|
|
|
|
|
|
PackageKind(String pkg) {
|
|
|
|
this.pkg = pkg;
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
@Override
|
|
|
|
public String expand(String optParameter) {
|
2012-11-17 19:01:03 +00:00
|
|
|
return this == NO_PKG ?
|
|
|
|
"" :
|
|
|
|
"package " + pkg + ";";
|
|
|
|
}
|
|
|
|
|
|
|
|
String getImportStat() {
|
|
|
|
return this == NO_PKG ?
|
|
|
|
"" :
|
|
|
|
"import " + pkg + ".*;";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
enum SamKind implements ComboParameter {
|
2012-11-17 19:01:03 +00:00
|
|
|
CLASS("public class Sam { }"),
|
|
|
|
ABSTACT_CLASS("public abstract class Sam { }"),
|
|
|
|
ANNOTATION("public @interface Sam { }"),
|
|
|
|
ENUM("public enum Sam { }"),
|
2015-08-31 17:33:34 +01:00
|
|
|
INTERFACE("public interface Sam { \n #{METH1}; \n }");
|
2012-11-17 19:01:03 +00:00
|
|
|
|
|
|
|
String sam_str;
|
|
|
|
|
|
|
|
SamKind(String sam_str) {
|
|
|
|
this.sam_str = sam_str;
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
@Override
|
|
|
|
public String expand(String optParameter) {
|
|
|
|
return sam_str;
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
enum ModifierKind implements ComboParameter {
|
2012-11-17 19:01:03 +00:00
|
|
|
PUBLIC("public"),
|
|
|
|
PACKAGE("");
|
|
|
|
|
|
|
|
String modifier_str;
|
|
|
|
|
|
|
|
ModifierKind(String modifier_str) {
|
|
|
|
this.modifier_str = modifier_str;
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
@Override
|
|
|
|
public String expand(String optParameter) {
|
|
|
|
return modifier_str;
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
enum TypeKind implements ComboParameter {
|
2012-11-17 19:01:03 +00:00
|
|
|
EXCEPTION("Exception"),
|
|
|
|
PKG_CLASS("PackageClass");
|
|
|
|
|
|
|
|
String typeStr;
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
TypeKind(String typeStr) {
|
2012-11-17 19:01:03 +00:00
|
|
|
this.typeStr = typeStr;
|
|
|
|
}
|
2015-08-31 17:33:34 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String expand(String optParameter) {
|
|
|
|
return typeStr;
|
|
|
|
}
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
enum ExprKind implements ComboParameter {
|
2012-11-30 15:14:25 +00:00
|
|
|
LAMBDA("x -> null"),
|
|
|
|
MREF("this::m");
|
|
|
|
|
|
|
|
String exprStr;
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
ExprKind(String exprStr) {
|
2012-11-30 15:14:25 +00:00
|
|
|
this.exprStr = exprStr;
|
|
|
|
}
|
2015-08-31 17:33:34 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String expand(String optParameter) {
|
|
|
|
return exprStr;
|
|
|
|
}
|
2012-11-30 15:14:25 +00:00
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
enum MethodKind implements ComboParameter {
|
2012-11-17 19:01:03 +00:00
|
|
|
NONE(""),
|
2015-08-31 17:33:34 +01:00
|
|
|
NON_GENERIC("public abstract #{RET} m(#{ARG} s) throws #{THROWN};"),
|
|
|
|
GENERIC("public abstract <X> #{RET} m(#{ARG} s) throws #{THROWN};");
|
2012-11-17 19:01:03 +00:00
|
|
|
|
|
|
|
String methodTemplate;
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
MethodKind(String methodTemplate) {
|
2012-11-17 19:01:03 +00:00
|
|
|
this.methodTemplate = methodTemplate;
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
@Override
|
|
|
|
public String expand(String optParameter) {
|
|
|
|
return methodTemplate;
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
2015-08-31 17:33:34 +01:00
|
|
|
new ComboTestHelper<FunctionalInterfaceConversionTest>()
|
|
|
|
.withDimension("PKG", (x, pkg) -> x.samPkg = pkg, PackageKind.values())
|
|
|
|
.withDimension("MOD", (x, mod) -> x.modKind = mod, ModifierKind.values())
|
|
|
|
.withDimension("CLAZZ", (x, sam) -> x.samKind = sam, SamKind.values())
|
|
|
|
.withDimension("METH1", (x, meth) -> x.samMeth = meth, MethodKind.values())
|
|
|
|
.withDimension("METH2", (x, meth) -> x.clientMeth = meth, MethodKind.values())
|
|
|
|
.withDimension("RET", (x, ret) -> x.retType = ret, TypeKind.values())
|
|
|
|
.withDimension("ARG", (x, arg) -> x.argType = arg, TypeKind.values())
|
|
|
|
.withDimension("THROWN", (x, thrown) -> x.thrownType = thrown, TypeKind.values())
|
|
|
|
.withDimension("EXPR", (x, expr) -> x.exprKind = expr, ExprKind.values())
|
|
|
|
.run(FunctionalInterfaceConversionTest::new);
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
PackageKind samPkg;
|
|
|
|
ModifierKind modKind;
|
|
|
|
SamKind samKind;
|
2012-11-30 15:14:25 +00:00
|
|
|
MethodKind samMeth;
|
|
|
|
MethodKind clientMeth;
|
2012-11-17 19:01:03 +00:00
|
|
|
TypeKind retType;
|
|
|
|
TypeKind argType;
|
|
|
|
TypeKind thrownType;
|
2012-11-30 15:14:25 +00:00
|
|
|
ExprKind exprKind;
|
2012-11-17 19:01:03 +00:00
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
String samSource = "#{PKG} \n #{CLAZZ}";
|
|
|
|
String pkgClassSource = "#{PKG}\n #{MOD} class PackageClass extends Exception { }";
|
|
|
|
String clientSource = "#{IMP}\n abstract class Client { \n" +
|
|
|
|
" Sam s = #{EXPR};\n" +
|
|
|
|
" #{METH2} \n }";
|
2012-11-17 19:01:03 +00:00
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
@Override
|
|
|
|
public void doWork() throws IOException {
|
2017-09-01 14:04:20 +02:00
|
|
|
newCompilationTask()
|
2015-08-31 17:33:34 +01:00
|
|
|
.withSourceFromTemplate("Sam", samSource)
|
|
|
|
.withSourceFromTemplate("PackageClass", pkgClassSource)
|
|
|
|
.withSourceFromTemplate("Client", clientSource, this::importStmt)
|
2017-09-01 14:04:20 +02:00
|
|
|
.analyze(this::check);
|
2015-08-31 17:33:34 +01:00
|
|
|
}
|
2012-11-17 19:01:03 +00:00
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
ComboParameter importStmt(String name) {
|
|
|
|
switch (name) {
|
|
|
|
case "IMP": return new ComboParameter.Constant<>(samPkg.getImportStat());
|
|
|
|
default: return null;
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-31 17:33:34 +01:00
|
|
|
void check(Result<?> res) {
|
|
|
|
if (res.hasErrors() == checkSamConversion()) {
|
|
|
|
fail("Unexpected compilation result; " + res.compilationInfo());
|
2012-11-17 19:01:03 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
boolean checkSamConversion() {
|
|
|
|
if (samKind != SamKind.INTERFACE) {
|
|
|
|
//sam type must be an interface
|
|
|
|
return false;
|
2012-11-30 15:14:25 +00:00
|
|
|
} else if (samMeth == MethodKind.NONE) {
|
|
|
|
//interface must have at least a method
|
|
|
|
return false;
|
|
|
|
} else if (exprKind == ExprKind.LAMBDA &&
|
|
|
|
samMeth != MethodKind.NON_GENERIC) {
|
|
|
|
//target method for lambda must be non-generic
|
|
|
|
return false;
|
|
|
|
} else if (exprKind == ExprKind.MREF &&
|
|
|
|
clientMeth == MethodKind.NONE) {
|
2012-11-17 19:01:03 +00:00
|
|
|
return false;
|
|
|
|
} else if (samPkg != PackageKind.NO_PKG &&
|
|
|
|
modKind != ModifierKind.PUBLIC &&
|
|
|
|
(retType == TypeKind.PKG_CLASS ||
|
|
|
|
argType == TypeKind.PKG_CLASS ||
|
|
|
|
thrownType == TypeKind.PKG_CLASS)) {
|
|
|
|
//target must not contain inaccessible types
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|