aboutsummaryrefslogtreecommitdiffstats
path: root/tests/bugs154/pr148381
diff options
context:
space:
mode:
Diffstat (limited to 'tests/bugs154/pr148381')
-rw-r--r--tests/bugs154/pr148381/error1/META-INF/aop.xml5
-rw-r--r--tests/bugs154/pr148381/error1/Main.java12
-rw-r--r--tests/bugs154/pr148381/error1/Monitor.java29
-rw-r--r--tests/bugs154/pr148381/error1/PerformanceMonitor.java9
-rw-r--r--tests/bugs154/pr148381/error1/code.jarbin0 -> 1799 bytes
-rw-r--r--tests/bugs154/pr148381/error1/readme2
-rwxr-xr-xtests/bugs154/pr148381/error1/rebuild.sh2
-rw-r--r--tests/bugs154/pr148381/error2/META-INF/aop.xml5
-rw-r--r--tests/bugs154/pr148381/error2/Main.java12
-rw-r--r--tests/bugs154/pr148381/error2/Monitor.java29
-rw-r--r--tests/bugs154/pr148381/error2/PerformanceMonitor.java9
-rw-r--r--tests/bugs154/pr148381/error2/code.jarbin0 -> 1799 bytes
-rw-r--r--tests/bugs154/pr148381/error2/readme2
-rwxr-xr-xtests/bugs154/pr148381/error2/rebuild.sh2
-rw-r--r--tests/bugs154/pr148381/error3/META-INF/aop.xml5
-rw-r--r--tests/bugs154/pr148381/error3/Main.java12
-rw-r--r--tests/bugs154/pr148381/error3/Monitor.java23
-rw-r--r--tests/bugs154/pr148381/error3/PerformanceMonitor.java9
-rw-r--r--tests/bugs154/pr148381/error3/code.jarbin0 -> 1770 bytes
-rw-r--r--tests/bugs154/pr148381/error3/readme2
-rwxr-xr-xtests/bugs154/pr148381/error3/rebuild.sh2
-rw-r--r--tests/bugs154/pr148381/readme7
-rw-r--r--tests/bugs154/pr148381/simple/META-INF/aop.xml5
-rw-r--r--tests/bugs154/pr148381/simple/Main.java12
-rw-r--r--tests/bugs154/pr148381/simple/Monitor.java28
-rw-r--r--tests/bugs154/pr148381/simple/PerformanceMonitor.java9
-rw-r--r--tests/bugs154/pr148381/simple/code.jarbin0 -> 1803 bytes
27 files changed, 232 insertions, 0 deletions
diff --git a/tests/bugs154/pr148381/error1/META-INF/aop.xml b/tests/bugs154/pr148381/error1/META-INF/aop.xml
new file mode 100644
index 000000000..942caa29e
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/META-INF/aop.xml
@@ -0,0 +1,5 @@
+<aspectj>
+ <aspects>
+ <aspect name="test.Monitor"/>
+ </aspects>
+</aspectj>
diff --git a/tests/bugs154/pr148381/error1/Main.java b/tests/bugs154/pr148381/error1/Main.java
new file mode 100644
index 000000000..16aef2686
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/Main.java
@@ -0,0 +1,12 @@
+package test;
+
+public class Main {
+ public static void main(String[] args) {
+ new Main().foo();
+ }
+
+ @PerformanceMonitor(expected=1000)
+ public void foo() {
+
+ }
+}
diff --git a/tests/bugs154/pr148381/error1/Monitor.java b/tests/bugs154/pr148381/error1/Monitor.java
new file mode 100644
index 000000000..540faa807
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/Monitor.java
@@ -0,0 +1,29 @@
+package test;
+
+import org.aspectj.lang.ProceedingJoinPoint;
+import org.aspectj.lang.annotation.Around;
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Pointcut;
+
+@Aspect
+class Monitor {
+ @Pointcut(value="execution(@PerformanceMonitor * *(..)) && @annotation(monitoringAnnot)", argNames="monitoringAnnot")
+ public void monitored(PerformanceMonitor monitoringAnnot) {}
+
+ // Not enough entries in argNames
+ @Around(value="monitored(monitoringAnnot)", argNames="pjp")
+ public Object flagExpectationMismatch(ProceedingJoinPoint pjp, PerformanceMonitor monitoringAnnot) throws Throwable {
+ //long start = System.nanoTime();
+ Object ret = pjp.proceed();
+ //long end = System.nanoTime();
+
+ //if(end - start > monitoringAnnot.expected()) {
+ // System.out.println("Method " + pjp.getSignature().toShortString() + " took longer than expected\n\t"
+ // + "Max expected = " + monitoringAnnot.expected() + ", actual = " + (end-start));
+ //}
+
+ System.out.println("This method was intercepted by the advice: "+pjp.getSignature().toShortString());
+ return ret;
+ }
+}
+
diff --git a/tests/bugs154/pr148381/error1/PerformanceMonitor.java b/tests/bugs154/pr148381/error1/PerformanceMonitor.java
new file mode 100644
index 000000000..e9f6aa3b2
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/PerformanceMonitor.java
@@ -0,0 +1,9 @@
+package test;
+
+import java.lang.annotation.*;
+
+@Retention(RetentionPolicy.RUNTIME)
+@Target(ElementType.METHOD)
+@interface PerformanceMonitor {
+ public int expected();
+}
diff --git a/tests/bugs154/pr148381/error1/code.jar b/tests/bugs154/pr148381/error1/code.jar
new file mode 100644
index 000000000..6852cb874
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/code.jar
Binary files differ
diff --git a/tests/bugs154/pr148381/error1/readme b/tests/bugs154/pr148381/error1/readme
new file mode 100644
index 000000000..1ea0ea5fd
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/readme
@@ -0,0 +1,2 @@
+Error scenario one
+- incorrect number of 'names' in argNames compared the method it is attached to
diff --git a/tests/bugs154/pr148381/error1/rebuild.sh b/tests/bugs154/pr148381/error1/rebuild.sh
new file mode 100755
index 000000000..5cb9a02eb
--- /dev/null
+++ b/tests/bugs154/pr148381/error1/rebuild.sh
@@ -0,0 +1,2 @@
+javac *.java -d .
+jar -cvMf code.jar test
diff --git a/tests/bugs154/pr148381/error2/META-INF/aop.xml b/tests/bugs154/pr148381/error2/META-INF/aop.xml
new file mode 100644
index 000000000..942caa29e
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/META-INF/aop.xml
@@ -0,0 +1,5 @@
+<aspectj>
+ <aspects>
+ <aspect name="test.Monitor"/>
+ </aspects>
+</aspectj>
diff --git a/tests/bugs154/pr148381/error2/Main.java b/tests/bugs154/pr148381/error2/Main.java
new file mode 100644
index 000000000..16aef2686
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/Main.java
@@ -0,0 +1,12 @@
+package test;
+
+public class Main {
+ public static void main(String[] args) {
+ new Main().foo();
+ }
+
+ @PerformanceMonitor(expected=1000)
+ public void foo() {
+
+ }
+}
diff --git a/tests/bugs154/pr148381/error2/Monitor.java b/tests/bugs154/pr148381/error2/Monitor.java
new file mode 100644
index 000000000..180e10b9b
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/Monitor.java
@@ -0,0 +1,29 @@
+package test;
+
+import org.aspectj.lang.ProceedingJoinPoint;
+import org.aspectj.lang.annotation.Around;
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Pointcut;
+
+@Aspect
+class Monitor {
+ @Pointcut(value="execution(@PerformanceMonitor * *(..)) && @annotation(monitoringAnnot)", argNames="monitoringAnnot")
+ public void monitored(PerformanceMonitor monitoringAnnot) {}
+
+ // Not enough entries in argNames
+ @Around(value="monitored(monitoringAnnot)", argNames="")
+ public Object flagExpectationMismatch(ProceedingJoinPoint pjp, PerformanceMonitor monitoringAnnot) throws Throwable {
+ //long start = System.nanoTime();
+ Object ret = pjp.proceed();
+ //long end = System.nanoTime();
+
+ //if(end - start > monitoringAnnot.expected()) {
+ // System.out.println("Method " + pjp.getSignature().toShortString() + " took longer than expected\n\t"
+ // + "Max expected = " + monitoringAnnot.expected() + ", actual = " + (end-start));
+ //}
+
+ System.out.println("This method was intercepted by the advice: "+pjp.getSignature().toShortString());
+ return ret;
+ }
+}
+
diff --git a/tests/bugs154/pr148381/error2/PerformanceMonitor.java b/tests/bugs154/pr148381/error2/PerformanceMonitor.java
new file mode 100644
index 000000000..e9f6aa3b2
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/PerformanceMonitor.java
@@ -0,0 +1,9 @@
+package test;
+
+import java.lang.annotation.*;
+
+@Retention(RetentionPolicy.RUNTIME)
+@Target(ElementType.METHOD)
+@interface PerformanceMonitor {
+ public int expected();
+}
diff --git a/tests/bugs154/pr148381/error2/code.jar b/tests/bugs154/pr148381/error2/code.jar
new file mode 100644
index 000000000..6c01b77f5
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/code.jar
Binary files differ
diff --git a/tests/bugs154/pr148381/error2/readme b/tests/bugs154/pr148381/error2/readme
new file mode 100644
index 000000000..7b4e58391
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/readme
@@ -0,0 +1,2 @@
+Error scenario two
+- blank argNames supplied
diff --git a/tests/bugs154/pr148381/error2/rebuild.sh b/tests/bugs154/pr148381/error2/rebuild.sh
new file mode 100755
index 000000000..5cb9a02eb
--- /dev/null
+++ b/tests/bugs154/pr148381/error2/rebuild.sh
@@ -0,0 +1,2 @@
+javac *.java -d .
+jar -cvMf code.jar test
diff --git a/tests/bugs154/pr148381/error3/META-INF/aop.xml b/tests/bugs154/pr148381/error3/META-INF/aop.xml
new file mode 100644
index 000000000..942caa29e
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/META-INF/aop.xml
@@ -0,0 +1,5 @@
+<aspectj>
+ <aspects>
+ <aspect name="test.Monitor"/>
+ </aspects>
+</aspectj>
diff --git a/tests/bugs154/pr148381/error3/Main.java b/tests/bugs154/pr148381/error3/Main.java
new file mode 100644
index 000000000..16aef2686
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/Main.java
@@ -0,0 +1,12 @@
+package test;
+
+public class Main {
+ public static void main(String[] args) {
+ new Main().foo();
+ }
+
+ @PerformanceMonitor(expected=1000)
+ public void foo() {
+
+ }
+}
diff --git a/tests/bugs154/pr148381/error3/Monitor.java b/tests/bugs154/pr148381/error3/Monitor.java
new file mode 100644
index 000000000..de51569c2
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/Monitor.java
@@ -0,0 +1,23 @@
+package test;
+
+import org.aspectj.lang.ProceedingJoinPoint;
+import org.aspectj.lang.annotation.*;
+
+class Foo {}
+
+@Aspect
+class Monitor {
+ @Around(value="execution(* *(..))",argNames="")
+ public void b(Foo aa) {}
+ @Pointcut(value="execution(* *(..))",argNames="")
+ public void a(Foo aa) {}
+ @Before(value="execution(* *(..))",argNames="")
+ public void c(Foo aa) {}
+ @After(value="execution(* *(..))",argNames="a,b,c")
+ public void d(Foo aa) {}
+ @AfterThrowing(value="execution(* *(..))",argNames="")
+ public void e(Foo aa) {}
+ @AfterReturning(value="execution(* *(..))",argNames="")
+ public void f(Foo aa) {}
+}
+
diff --git a/tests/bugs154/pr148381/error3/PerformanceMonitor.java b/tests/bugs154/pr148381/error3/PerformanceMonitor.java
new file mode 100644
index 000000000..e9f6aa3b2
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/PerformanceMonitor.java
@@ -0,0 +1,9 @@
+package test;
+
+import java.lang.annotation.*;
+
+@Retention(RetentionPolicy.RUNTIME)
+@Target(ElementType.METHOD)
+@interface PerformanceMonitor {
+ public int expected();
+}
diff --git a/tests/bugs154/pr148381/error3/code.jar b/tests/bugs154/pr148381/error3/code.jar
new file mode 100644
index 000000000..91e15cf6f
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/code.jar
Binary files differ
diff --git a/tests/bugs154/pr148381/error3/readme b/tests/bugs154/pr148381/error3/readme
new file mode 100644
index 000000000..213f7dc0b
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/readme
@@ -0,0 +1,2 @@
+Error scenario two
+- wrong argNames for multiple pieces of advice
diff --git a/tests/bugs154/pr148381/error3/rebuild.sh b/tests/bugs154/pr148381/error3/rebuild.sh
new file mode 100755
index 000000000..5cb9a02eb
--- /dev/null
+++ b/tests/bugs154/pr148381/error3/rebuild.sh
@@ -0,0 +1,2 @@
+javac *.java -d .
+jar -cvMf code.jar test
diff --git a/tests/bugs154/pr148381/readme b/tests/bugs154/pr148381/readme
new file mode 100644
index 000000000..51cfb57a1
--- /dev/null
+++ b/tests/bugs154/pr148381/readme
@@ -0,0 +1,7 @@
+rebuilding code.jar is done with:
+
+javac *.java
+jar -cvMf code.jar test
+
+Basically you need to ensure the classes have no local variable tables - that is the default behaviour for javac
+
diff --git a/tests/bugs154/pr148381/simple/META-INF/aop.xml b/tests/bugs154/pr148381/simple/META-INF/aop.xml
new file mode 100644
index 000000000..942caa29e
--- /dev/null
+++ b/tests/bugs154/pr148381/simple/META-INF/aop.xml
@@ -0,0 +1,5 @@
+<aspectj>
+ <aspects>
+ <aspect name="test.Monitor"/>
+ </aspects>
+</aspectj>
diff --git a/tests/bugs154/pr148381/simple/Main.java b/tests/bugs154/pr148381/simple/Main.java
new file mode 100644
index 000000000..16aef2686
--- /dev/null
+++ b/tests/bugs154/pr148381/simple/Main.java
@@ -0,0 +1,12 @@
+package test;
+
+public class Main {
+ public static void main(String[] args) {
+ new Main().foo();
+ }
+
+ @PerformanceMonitor(expected=1000)
+ public void foo() {
+
+ }
+}
diff --git a/tests/bugs154/pr148381/simple/Monitor.java b/tests/bugs154/pr148381/simple/Monitor.java
new file mode 100644
index 000000000..fdba651ce
--- /dev/null
+++ b/tests/bugs154/pr148381/simple/Monitor.java
@@ -0,0 +1,28 @@
+package test;
+
+import org.aspectj.lang.ProceedingJoinPoint;
+import org.aspectj.lang.annotation.Around;
+import org.aspectj.lang.annotation.Aspect;
+import org.aspectj.lang.annotation.Pointcut;
+
+@Aspect
+class Monitor {
+ @Pointcut(value="execution(@PerformanceMonitor * *(..)) && @annotation(monitoringAnnot)", argNames="monitoringAnnot")
+ public void monitored(PerformanceMonitor monitoringAnnot) {}
+
+ @Around(value="monitored(monitoringAnnot)", argNames="pjp, monitoringAnnot")
+ public Object flagExpectationMismatch(ProceedingJoinPoint pjp, PerformanceMonitor monitoringAnnot) throws Throwable {
+ //long start = System.nanoTime();
+ Object ret = pjp.proceed();
+ //long end = System.nanoTime();
+
+ //if(end - start > monitoringAnnot.expected()) {
+ // System.out.println("Method " + pjp.getSignature().toShortString() + " took longer than expected\n\t"
+ // + "Max expected = " + monitoringAnnot.expected() + ", actual = " + (end-start));
+ //}
+
+ System.out.println("This method was intercepted by the advice: "+pjp.getSignature().toShortString());
+ return ret;
+ }
+}
+
diff --git a/tests/bugs154/pr148381/simple/PerformanceMonitor.java b/tests/bugs154/pr148381/simple/PerformanceMonitor.java
new file mode 100644
index 000000000..e9f6aa3b2
--- /dev/null
+++ b/tests/bugs154/pr148381/simple/PerformanceMonitor.java
@@ -0,0 +1,9 @@
+package test;
+
+import java.lang.annotation.*;
+
+@Retention(RetentionPolicy.RUNTIME)
+@Target(ElementType.METHOD)
+@interface PerformanceMonitor {
+ public int expected();
+}
diff --git a/tests/bugs154/pr148381/simple/code.jar b/tests/bugs154/pr148381/simple/code.jar
new file mode 100644
index 000000000..4a30b29a1
--- /dev/null
+++ b/tests/bugs154/pr148381/simple/code.jar
Binary files differ