summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/bugs150/LocalVarTableGen.aj26
-rw-r--r--tests/java5/ataspectj/annotationGen/AdviceWithParameters.java0
-rw-r--r--tests/java5/reflection/AdviceWithArgs.aj27
-rw-r--r--tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java6
-rw-r--r--tests/src/org/aspectj/systemtest/ajc150/ajc150.xml6
5 files changed, 65 insertions, 0 deletions
diff --git a/tests/bugs150/LocalVarTableGen.aj b/tests/bugs150/LocalVarTableGen.aj
new file mode 100644
index 000000000..a281dbb11
--- /dev/null
+++ b/tests/bugs150/LocalVarTableGen.aj
@@ -0,0 +1,26 @@
+public aspect LocalVarTableGen {
+
+ int x = 5;
+
+ public String foo(String s) {
+ String myLocal = "" + x + s;
+ return myLocal;
+ }
+
+ public String bar(String s) {
+ String myLocal = "" + x + s;
+ return myLocal;
+ }
+
+ before() : execution(* foo(..)) {
+ System.out.println("before foo");
+ }
+
+ after(String in) returning(String out) :
+ execution(* bar(..)) && args(in)
+ {
+ System.out.println("after bar");
+ }
+
+
+} \ No newline at end of file
diff --git a/tests/java5/ataspectj/annotationGen/AdviceWithParameters.java b/tests/java5/ataspectj/annotationGen/AdviceWithParameters.java
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/tests/java5/ataspectj/annotationGen/AdviceWithParameters.java
diff --git a/tests/java5/reflection/AdviceWithArgs.aj b/tests/java5/reflection/AdviceWithArgs.aj
new file mode 100644
index 000000000..533b38012
--- /dev/null
+++ b/tests/java5/reflection/AdviceWithArgs.aj
@@ -0,0 +1,27 @@
+import org.aspectj.lang.annotation.*;
+import java.lang.reflect.*;
+
+public aspect AdviceWithArgs {
+
+ @SuppressAjWarnings
+ before(String s) : execution(* *(..)) && args(s) {
+ System.out.println(s);
+ }
+
+ public static void main(String[] args) throws Exception {
+ Method[] meths = AdviceWithArgs.class.getMethods();
+ boolean found = false;
+ for (Method meth : meths) {
+ if (meth.isAnnotationPresent(Before.class)) {
+ found = true;
+ Before bAnn = meth.getAnnotation(Before.class);
+ String argNames = bAnn.argNames();
+ if (!argNames.equals("s")) {
+ throw new RuntimeException("Expected 's' but got '" + argNames + "'");
+ }
+ break;
+ }
+ }
+ if (!found) throw new RuntimeException("Did not find expected advice annotation");
+ }
+} \ No newline at end of file
diff --git a/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java b/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
index c692b30d9..3fa9ff605 100644
--- a/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
+++ b/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
@@ -753,6 +753,11 @@ public class Ajc150Tests extends org.aspectj.testing.XMLBasedAjcTestCase {
runTest("double parameter generic abstract type");
}
+
+ public void testArgNamesInAdviceAnnotations() {
+ runTest("arg names in advice annotations");
+ }
+
/*
* Load-time weaving bugs
*/
@@ -778,6 +783,7 @@ public class Ajc150Tests extends org.aspectj.testing.XMLBasedAjcTestCase {
assertNotNull("Should have some relationships but does not",l);
}
+
// helper methods.....
public SyntheticRepository createRepos(File cpentry) {
diff --git a/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml b/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
index fc6457043..7cb13ac68 100644
--- a/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
+++ b/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
@@ -118,6 +118,12 @@
<run class="Simple" classpath="../lib/aspectj/lib/aspectjrt121.jar"/>
</ajc-test>
+ <ajc-test dir="java5/reflection" title="arg names in advice annotations">
+ <compile files="AdviceWithArgs.aj" options="-1.5"></compile>
+ <run class="AdviceWithArgs"/>
+ </ajc-test>
+
+
<ajc-test dir="java5/reflection" pr="114322" title="reflection on abstract ITDs (Billing example)">
<compile files="ReflectBilling.java,Billing.aj" options="-1.5"/>
<run class="ReflectBilling">