blob: 6fe90b99d2363d7619c60d0812ec3239e24f0b7d [file] [log] [blame]
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* 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.
*/
import java.util.List;
import java.util.ArrayList;
import java.util.Arrays;
import java.io.Serializable;
import java.io.File;
/**
* @test
* @bug 8003280
* @summary Add lambda tests
* Parameter types inferred from target type in generics without wildcard
* @compile InferenceTest2.java
* @run main InferenceTest2
*/
public class InferenceTest2 {
private static void assertTrue(boolean cond) {
if (!cond)
throw new AssertionError();
}
public static void main(String[] args) {
InferenceTest2 test = new InferenceTest2();
//test SAM1<T>
SAM1<String> sam1 = para -> { String result = "";
for(String s : para)
if(s.compareTo(result) > 0)
result = s;
return result; };
List<String> list = Arrays.asList("a", "b", "c");
assertTrue(sam1.m1(list).equals("c"));
test.method1(para -> para.get(0));
//test SAM2<T>
SAM2<String> sam2 = para -> {para = para.substring(0);};
SAM2<Double> sam2_2 = para -> {};
SAM2<File> sam2_3 = para -> { if(para.isDirectory())
System.out.println("directory");
};
//test SAM3<T>
SAM3<String> sam3 = para -> para[0].substring(0, para[0].length()-1);
assertTrue(sam3.m3("hello+").equals("hello"));
SAM3<Integer> sam3_2 = para -> para[0] - para[1];
assertTrue(sam3_2.m3(1, -1) == 2);
SAM3<Double> sam3_3 = para -> para[0] + para[1] + para[2] + para[3];
assertTrue(sam3_3.m3(1.0, 2.0, 3.0, 4.0) == 10.0);
test.method3(para -> para[0] + 1);
//test SAM6<T>
SAM6<String> sam6 = (para1, para2) -> para1.concat(para2);
assertTrue(sam6.m6("hello", "world").equals("helloworld"));
test.method6((para1, para2) -> para1 >= para2? para1 : para2);
}
void method1(SAM1<Integer> sam1) {
List<Integer> list = Arrays.asList(3,2,1);
assertTrue(sam1.m1(list) == 3);
}
void method3(SAM3<Double> sam3) {
assertTrue(sam3.m3(2.5) == 3.5);
}
void method6(SAM6<Long> sam6) {
assertTrue(sam6.m6(5L, -5L) == 5);
}
interface SAM1<T> {
T m1(List<T> x);
}
interface SAM2<T extends Serializable> {
void m2(T x);
}
interface SAM3<T> {
T m3(T... x);
}
interface SAM6<T> {
T m6(T a, T b);
}
}