diff --git a/compiler/testData/codegen/boxWithStdlib/reified/DIExample.kt b/compiler/testData/codegen/boxWithStdlib/reified/DIExample.kt new file mode 100644 index 00000000000..4d8bc710219 --- /dev/null +++ b/compiler/testData/codegen/boxWithStdlib/reified/DIExample.kt @@ -0,0 +1,23 @@ +import kotlin.test.assertEquals + +class Project { + fun getInstance(cls: Class): T = + when (cls.getName()) { + "java.lang.Integer" -> 1 as T + "java.lang.String" -> "OK" as T + else -> null!! + } +} + +inline fun Project.get(t: Any?, p: PropertyMetadata): T = getInstance(javaClass()) + +val project = Project() +val x1: Int by project +val x2: String by project + +fun box(): String { + assertEquals(1, x1) + assertEquals("OK", x2) + + return "OK" +} diff --git a/compiler/tests/org/jetbrains/jet/codegen/generated/BlackBoxWithStdlibCodegenTestGenerated.java b/compiler/tests/org/jetbrains/jet/codegen/generated/BlackBoxWithStdlibCodegenTestGenerated.java index da4923cf34d..258cea4a430 100644 --- a/compiler/tests/org/jetbrains/jet/codegen/generated/BlackBoxWithStdlibCodegenTestGenerated.java +++ b/compiler/tests/org/jetbrains/jet/codegen/generated/BlackBoxWithStdlibCodegenTestGenerated.java @@ -2670,6 +2670,12 @@ public class BlackBoxWithStdlibCodegenTestGenerated extends AbstractBlackBoxCode doTestWithStdlib(fileName); } + @TestMetadata("DIExample.kt") + public void testDIExample() throws Exception { + String fileName = JetTestUtils.navigationMetadata("compiler/testData/codegen/boxWithStdlib/reified/DIExample.kt"); + doTestWithStdlib(fileName); + } + @TestMetadata("defaultJavaClass.kt") public void testDefaultJavaClass() throws Exception { String fileName = JetTestUtils.navigationMetadata("compiler/testData/codegen/boxWithStdlib/reified/defaultJavaClass.kt");