From 2db1a01cd0e149175c32172f561a2e353a02a79f Mon Sep 17 00:00:00 2001 From: Alexander Kriegisch Date: Thu, 19 Jan 2023 13:13:15 +0100 Subject: [PATCH] Improve Ajc165Tests.testFunkyPointcut_pr272233_2 Add more funky pointcuts concerning 'void[]' and pointcuts matching arrays of generic types. Remove TODO after previously committed bugfix. Signed-off-by: Alexander Kriegisch --- tests/bugs165/pr272233/Iffy2.java | 76 +++++++++++-------- .../org/aspectj/systemtest/ajc165/ajc165.xml | 26 +++++-- 2 files changed, 62 insertions(+), 40 deletions(-) diff --git a/tests/bugs165/pr272233/Iffy2.java b/tests/bugs165/pr272233/Iffy2.java index 2245f7d8da..8c514bdaab 100644 --- a/tests/bugs165/pr272233/Iffy2.java +++ b/tests/bugs165/pr272233/Iffy2.java @@ -1,50 +1,60 @@ import java.util.*; + import org.aspectj.lang.annotation.*; @Aspect class Iffy2 { + // Match getCollectionArray(), getIntegerCollectionArray() @Before("execution(!void *(..))") - public void advice1() {} + public void nonVoid() { } - @Before("execution(!void[] *(..))") - public void advice2() {} + // Do not match anything, because void[] is an illegal type + @Before("execution(void[] *(..))") + public void voidArray() { + // This does not compile in Java + // void[] voids = new void[5]; + } - @Before("execution(!void *(..))") - public void advice3() {} + // Match getCollectionArray() and myVoid(), getIntegerCollectionArray(), because void[] is an illegal type which + // cannot be resolved/matched. The negation of an unmatched type, however, matches any type, similar to how + // !my.UnknownType would also match all other types. + @Before("execution(!void[][] *(..))") + public void nonVoidArray() { } + // Match getCollectionArray(), getIntegerCollectionArray() @Before("execution(*..Collection[] *(..))") - public void advice4() {} + public void wildcardRawCollectionArray() { } + // Match getCollectionArray() @Before("execution(java.util.Collection[] *(..))") - public void advice5() {} - - /** - * TODO: This pointcut is not parsed correctly. Obviously, the combination of - * '*' and '<?>' leads to an AJ core dump with this error message: - *

- * - * org.aspectj.weaver.BCException: malformed org.aspectj.weaver.PointcutDeclaration attribute (length:219) - * org.aspectj.weaver.BCException: Bad type signature * - * at org.aspectj.weaver.AjAttribute.read(AjAttribute.java:137) - * at org.aspectj.weaver.bcel.Utility.readAjAttributes(Utility.java:102) - * at org.aspectj.weaver.bcel.BcelMethod.unpackAjAttributes(BcelMethod.java:197) - * at org.aspectj.weaver.bcel.BcelMethod.<init>(BcelMethod.java:91) - * at org.aspectj.weaver.bcel.BcelObjectType.getDeclaredMethods(BcelObjectType.java:290) - * at org.aspectj.weaver.ReferenceType.getDeclaredMethods(ReferenceType.java:870) - * at org.aspectj.weaver.ResolvedType.getDeclaredAdvice(ResolvedType.java:1028) - * at org.aspectj.weaver.ResolvedType.getDeclaredShadowMungers(ResolvedType.java:1068) - * at org.aspectj.weaver.ResolvedType.collectShadowMungers(ResolvedType.java:868) - * at org.aspectj.weaver.ResolvedType.collectCrosscuttingMembers(ResolvedType.java:794) - * at org.aspectj.weaver.CrosscuttingMembersSet.addOrReplaceAspect(CrosscuttingMembersSet.java:112) - * at org.aspectj.weaver.CrosscuttingMembersSet.addOrReplaceAspect(CrosscuttingMembersSet.java:67) - * at org.aspectj.weaver.bcel.BcelWeaver.prepareForWeave(BcelWeaver.java:512) - * - */ - //@Before("execution(*..Collection[] *(..))") - public void advice6() {} + public void exactGenericCollectionArray() { } + + // Match getCollectionArray() + @Before("execution(*..Collection[] *(..))") + public void wildcardGenericCollectionArray() { } + + // Do not match anything + @Before("execution(*..Collection[] *(..))") + public void wildcardGenericCollectionArrayOfString() { } + + // Match getIntegerCollectionArray() + @Before("execution(*..Collection[] *(..))") + public void wildcardGenericCollectionArrayOfInteger() { } + + // Do not match anything. The fact that primitive type int is illegal as a generic type parameter, is not mentioned + // in any warning. + @Before("execution(*..Collection[] *(..))") + public void wildcardGenericCollectionArrayOfPrimitiveInt() { } + + public void myVoid() { } public Collection[] getCollectionArray() { - return null; + return null; } + + public Collection[] getIntegerCollectionArray() { + return null; + } + } diff --git a/tests/src/test/resources/org/aspectj/systemtest/ajc165/ajc165.xml b/tests/src/test/resources/org/aspectj/systemtest/ajc165/ajc165.xml index f48581f87d..cfdde87009 100644 --- a/tests/src/test/resources/org/aspectj/systemtest/ajc165/ajc165.xml +++ b/tests/src/test/resources/org/aspectj/systemtest/ajc165/ajc165.xml @@ -78,14 +78,26 @@ + + + - - - - - - - + + + + + + + + + + + + + + + +