aboutsummaryrefslogtreecommitdiffstats
path: root/src/test/javassist/JvstTest5.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/javassist/JvstTest5.java')
-rw-r--r--src/test/javassist/JvstTest5.java24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/test/javassist/JvstTest5.java b/src/test/javassist/JvstTest5.java
index dce27ab1..cd0158e4 100644
--- a/src/test/javassist/JvstTest5.java
+++ b/src/test/javassist/JvstTest5.java
@@ -643,4 +643,28 @@ public class JvstTest5 extends JvstTestRoot {
//expected:<Man feed(Bear)> but was:<Keeper feed(Animal)>
assertEquals(javacResult, javassistResult);
}
+
+ public void testMultipleNestedClasses() throws Exception {
+ CtClass outer = sloader.makeClass("javassist.MultipleNestedClasses");
+ CtClass nested1 = outer.makeNestedClass("Nested1", true);
+ CtClass nested2 = outer.makeNestedClass("Nested2", true);
+
+ InnerClassesAttribute outerICA = (InnerClassesAttribute)
+ outer.getClassFile2().getAttribute(InnerClassesAttribute.tag);
+ assertEquals(2, outerICA.tableLength());
+ assertEquals("javassist.MultipleNestedClasses$Nested1", outerICA.innerClass(0));
+ assertEquals("javassist.MultipleNestedClasses$Nested2", outerICA.innerClass(1));
+
+ InnerClassesAttribute nested1ICA = (InnerClassesAttribute)
+ nested1.getClassFile2().getAttribute(InnerClassesAttribute.tag);
+ assertEquals(1, nested1ICA.tableLength());
+ assertEquals("javassist.MultipleNestedClasses", nested1ICA.outerClass(0));
+ assertEquals("javassist.MultipleNestedClasses$Nested1", nested1ICA.innerClass(0));
+
+ InnerClassesAttribute nested2ICA = (InnerClassesAttribute)
+ nested2.getClassFile2().getAttribute(InnerClassesAttribute.tag);
+ assertEquals(1, nested2ICA.tableLength());
+ assertEquals("javassist.MultipleNestedClasses", nested2ICA.outerClass(0));
+ assertEquals("javassist.MultipleNestedClasses$Nested2", nested2ICA.innerClass(0));
+ }
}