diff -r 843d3b191773 -r 01c9d4161882 test/tools/javac/lambda/LambdaConv21.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/tools/javac/lambda/LambdaConv21.java Sat Nov 17 19:01:03 2012 +0000 @@ -0,0 +1,38 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8003280 + * @summary Add lambda tests + * check that code generation handles void-compatibility correctly + * @compile/fail/ref=LambdaConv21.out -XDrawDiagnostics LambdaConv21.java + */ + +class LambdaConv21 { + + interface SAM_void { + void m(); + } + + interface SAM_java_lang_Void { + Void m(); + } + + static void m_void() { } + + static Void m_java_lang_Void() { return null; } + + static void testExpressionLambda() { + SAM_void s1 = ()->m_void(); //ok + SAM_java_lang_Void s2 = ()->m_void(); //no - incompatible target + SAM_void s3 = ()->m_java_lang_Void(); //no - incompatible target + SAM_java_lang_Void s4 = ()->m_java_lang_Void(); //ok + } + + static void testStatementLambda() { + SAM_void s1 = ()-> { m_void(); }; //ok + SAM_java_lang_Void s2 = ()-> { m_void(); }; //no - missing return value + SAM_void s3 = ()-> { return m_java_lang_Void(); }; //no - unexpected return value + SAM_java_lang_Void s4 = ()-> { return m_java_lang_Void(); }; //ok + SAM_void s5 = ()-> { m_java_lang_Void(); }; //ok + SAM_java_lang_Void s6 = ()-> { m_java_lang_Void(); }; //no - missing return value + } +}