diff options
Diffstat (limited to 'tests/bugs166')
-rw-r--r-- | tests/bugs166/pr286473/Anno.java | 11 | ||||
-rw-r--r-- | tests/bugs166/pr286473/Bottom.java | 5 | ||||
-rw-r--r-- | tests/bugs166/pr286473/LTWTest.java | 56 | ||||
-rw-r--r-- | tests/bugs166/pr286473/Mark.java | 13 | ||||
-rw-r--r-- | tests/bugs166/pr286473/Middle.java | 5 | ||||
-rw-r--r-- | tests/bugs166/pr286473/Top.java | 5 | ||||
-rw-r--r-- | tests/bugs166/pr286473/aop.xml | 6 |
7 files changed, 101 insertions, 0 deletions
diff --git a/tests/bugs166/pr286473/Anno.java b/tests/bugs166/pr286473/Anno.java new file mode 100644 index 000000000..d7fce2edc --- /dev/null +++ b/tests/bugs166/pr286473/Anno.java @@ -0,0 +1,11 @@ + +import java.lang.annotation.ElementType; +import java.lang.annotation.Retention; +import java.lang.annotation.RetentionPolicy; +import java.lang.annotation.Target; + +@Retention(RetentionPolicy.RUNTIME) +@Target(ElementType.TYPE) +public @interface Anno { + +} diff --git a/tests/bugs166/pr286473/Bottom.java b/tests/bugs166/pr286473/Bottom.java new file mode 100644 index 000000000..531cf417d --- /dev/null +++ b/tests/bugs166/pr286473/Bottom.java @@ -0,0 +1,5 @@ + +@Anno +public class Bottom extends Middle { + public void bottom() {} +} diff --git a/tests/bugs166/pr286473/LTWTest.java b/tests/bugs166/pr286473/LTWTest.java new file mode 100644 index 000000000..59b596f86 --- /dev/null +++ b/tests/bugs166/pr286473/LTWTest.java @@ -0,0 +1,56 @@ + +import java.lang.reflect.Method; +import java.util.*; + +public class LTWTest { + + public void noDoubles() throws Exception { + Method[] methods = Bottom.class.getMethods(); + System.out.println("Bottom.getMethods()"); + boolean broken = false; + List<String> l = new ArrayList<String>(); + for (Method method : methods) { + if (!method.getDeclaringClass().equals(Object.class)) { + l.add(method.getName() + " : " + method.getDeclaringClass().getName()); + } + if (method.getDeclaringClass().equals(Bottom.class)) { + if (method.getName().equals("markMethod")) { + broken=true; + } + } + } + Collections.sort(l); + for (String s: l) { + System.out.println(s); + } + if (broken) { + throw new IllegalStateException("Bottom.getMethods() should not include a markMethod() declared by Bottom"); + } + } + + public void grandChildInherits() throws Exception { + Method[] methods = Bottom.class.getDeclaredMethods(); + for (Method method : methods) { + if (method.getName().equals("markMethod")) +throw new RuntimeException(); +// assertThat(method.getName(), not(equalTo("doSomething"))); + } + +/* + methods = Bottom.class.getMethods(); + for (Method method : methods) { + if (method.getName().equals("doSomething")) { + System.out.println(method.getDeclaringClass().getName()); + } + } +*/ + + } + + public static void main(String[] args) throws Exception { + LTWTest t = new LTWTest(); + t.noDoubles(); + t.grandChildInherits(); + } + +} diff --git a/tests/bugs166/pr286473/Mark.java b/tests/bugs166/pr286473/Mark.java new file mode 100644 index 000000000..cbe018a11 --- /dev/null +++ b/tests/bugs166/pr286473/Mark.java @@ -0,0 +1,13 @@ +public aspect Mark { + + public static interface IMarker { + + } + + public String IMarker.markMethod() { + return "something done"; + } + + declare parents : ((@Anno *)) implements IMarker; + +} diff --git a/tests/bugs166/pr286473/Middle.java b/tests/bugs166/pr286473/Middle.java new file mode 100644 index 000000000..7dddb06cf --- /dev/null +++ b/tests/bugs166/pr286473/Middle.java @@ -0,0 +1,5 @@ + +@Anno +public class Middle extends Top { + public void middle() {} +} diff --git a/tests/bugs166/pr286473/Top.java b/tests/bugs166/pr286473/Top.java new file mode 100644 index 000000000..f38360097 --- /dev/null +++ b/tests/bugs166/pr286473/Top.java @@ -0,0 +1,5 @@ + +@Anno +public class Top { + +} diff --git a/tests/bugs166/pr286473/aop.xml b/tests/bugs166/pr286473/aop.xml new file mode 100644 index 000000000..31fb5fe1c --- /dev/null +++ b/tests/bugs166/pr286473/aop.xml @@ -0,0 +1,6 @@ +<aspectj> + <aspects> + <aspect name="Mark"/> + </aspects> + <weaver options="-showWeaveInfo -Xset:completeBinaryTypes=true"/> +</aspectj> |