aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/ajcTestsFailing.xml112
-rw-r--r--tests/new/binaryWarnings/injars/app-ajc-1.1.jarbin0 -> 1143 bytes
-rw-r--r--tests/new/binaryWarnings/injars/app-javac-1.4.jarbin0 -> 1208 bytes
-rw-r--r--tests/new/binaryWarnings/readme.txt43
-rw-r--r--tests/new/binaryWarnings/src/app/Main.java55
-rw-r--r--tests/new/binaryWarnings/src/aspects/MainWarnings.java56
6 files changed, 266 insertions, 0 deletions
diff --git a/tests/ajcTestsFailing.xml b/tests/ajcTestsFailing.xml
index 41665da25..711108e0a 100644
--- a/tests/ajcTestsFailing.xml
+++ b/tests/ajcTestsFailing.xml
@@ -4,7 +4,119 @@
<!-- contains valid tests that the compiler has never passed -->
<suite>
+ <!-- expected messages the same for these tests. note:
+ - that pointcut-and not supported in message text TODO
+ - no test on adviceexecution()
+ - only verifying by line number now
+ (not flagging error in filename. Binary filenames are
+ listed as, e.g., app.Main.class.
+ Should get from filename attribute)
+ -->
+ <ajc-test dir="new/binaryWarnings/src" pr="37020"
+ title="declare warnings on main">
+ <compile files="aspects/MainWarnings.java,app/Main.java">
+ <message kind="warning" file="app/Main.java"
+ line="6" text="set(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="8" text="set(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="12" text="get(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="14" text="set(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="16" text="call(Main.new())"/>
+ <message kind="warning" file="app/Main.java"
+ line="19" text="call(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="23" text="execution(Main.new())"/>
+ <message kind="warning" file="app/Main.java"
+ line="26" text="execution(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="29" text="get(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="31" text="set(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="33" text="handler(RuntimeException)"/>
+ <message kind="warning" file="app/Main.java"
+ line="35" text="withincode(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="42" text="withincode(void Main.stop())"/>
+ <message kind="warning" file="app/Main.java"
+ line="50" text="preinitialization(app.C.new())"/>
+ </compile>
+
+ <run class="app.Main"/>
+ </ajc-test>
+ <ajc-test dir="new/binaryWarnings/src" pr="37020"
+ title="declare warnings on binary javac 1.4 classes">
+ <compile files="aspects/MainWarnings.java,../injars/app-javac-1.4.jar">
+ <message kind="warning" file="app/Main.java"
+ line="6" text="set(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="8" text="set(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="12" text="get(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="14" text="set(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="16" text="call(Main.new())"/>
+ <message kind="warning" file="app/Main.java"
+ line="19" text="call(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="23" text="execution(Main.new())"/>
+ <message kind="warning" file="app/Main.java"
+ line="26" text="execution(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="29" text="get(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="31" text="set(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="33" text="handler(RuntimeException)"/>
+ <message kind="warning" file="app/Main.java"
+ line="35" text="withincode(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="42" text="withincode(void Main.stop())"/>
+ <message kind="warning" file="app/Main.java"
+ line="50" text="preinitialization(app.C.new())"/>
+ </compile>
+ <run class="app.Main"/>
+ </ajc-test>
+ <ajc-test dir="new/binaryWarnings/src" pr="37023"
+ title="declare warnings on binary ajc 1.1 classes">
+ <compile files="aspects/MainWarnings.java,../injars/app-ajc-1.1.jar">
+ <message kind="warning" file="app/Main.java"
+ line="6" text="set(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="8" text="set(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="12" text="get(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="14" text="set(String Main.staticString)"/>
+ <message kind="warning" file="app/Main.java"
+ line="16" text="call(Main.new())"/>
+ <message kind="warning" file="app/Main.java"
+ line="19" text="call(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="23" text="execution(Main.new())"/>
+ <message kind="warning" file="app/Main.java"
+ line="26" text="execution(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="29" text="get(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="31" text="set(String Main.s)"/>
+ <message kind="warning" file="app/Main.java"
+ line="33" text="handler(RuntimeException)"/>
+ <message kind="warning" file="app/Main.java"
+ line="35" text="withincode(void Main.go(String))"/>
+ <message kind="warning" file="app/Main.java"
+ line="42" text="withincode(void Main.stop())"/>
+ <message kind="warning" file="app/Main.java"
+ line="50" text="preinitialization(app.C.new())"/>
+
+ </compile>
+ <run class="app.Main"/>
+ </ajc-test>
</suite>
diff --git a/tests/new/binaryWarnings/injars/app-ajc-1.1.jar b/tests/new/binaryWarnings/injars/app-ajc-1.1.jar
new file mode 100644
index 000000000..c05b42247
--- /dev/null
+++ b/tests/new/binaryWarnings/injars/app-ajc-1.1.jar
Binary files differ
diff --git a/tests/new/binaryWarnings/injars/app-javac-1.4.jar b/tests/new/binaryWarnings/injars/app-javac-1.4.jar
new file mode 100644
index 000000000..c16325897
--- /dev/null
+++ b/tests/new/binaryWarnings/injars/app-javac-1.4.jar
Binary files differ
diff --git a/tests/new/binaryWarnings/readme.txt b/tests/new/binaryWarnings/readme.txt
new file mode 100644
index 000000000..6b6eb486e
--- /dev/null
+++ b/tests/new/binaryWarnings/readme.txt
@@ -0,0 +1,43 @@
+
+Warning: brittle test! Change carefully and rebuild binaries!
+
+Bugs: 37020, 37021, 37023
+
+- there are 3+ associated test specifications:
+ - source-only
+ - binary (javac) application, source aspect
+ - binary (ajc) application, source aspect
+ - binary (javac) application, binary aspect (todo)
+ - binary (ajc) application, binary aspect (todo)
+
+- the lines in Main.java correspond with
+ warning line values in the test specifications
+
+- the message text in MainWarnings.java correspond with
+ warning text values in the test specifications
+
+- all the warnings in MainWarnings.java
+ should resolve to unique lines
+ (until we verify based on more than line)
+
+- all test specifications should have exactly the same warnings
+ as each other as as specified in MainWarnings.java
+
+To build the injar sources from the src directory:
+
+Using javac:
+ mkdir classes
+ javac -d classes app/Main.java
+ jar cfM ../injars/app-javac-1.4.jar -C classes .
+ rm -rf classes
+
+Using ajc:
+ ajc -classpath ../../../lib/test/aspectjrt.jar \
+ -outjar ../injars/app-ajc-1.1.jar app/Main.java
+
+Using ajc in eclipse, from a module directory:
+
+ {ajc} -classpath ../lib/test/aspectjrt.jar
+ -outjar ../tests/new/binaryWarnings/injars/app-ajc-1.1.jar
+ ../test/new/binnaryWarnings/src/app/Main.java
+
diff --git a/tests/new/binaryWarnings/src/app/Main.java b/tests/new/binaryWarnings/src/app/Main.java
new file mode 100644
index 000000000..a2daee1d9
--- /dev/null
+++ b/tests/new/binaryWarnings/src/app/Main.java
@@ -0,0 +1,55 @@
+
+package app;
+// WARNING: do not change lineation without changing test specification!!
+public class Main {
+
+ static String staticString = "hello";
+
+ String s = "me";
+
+ public static void main(String[] args) {
+
+ String temp = staticString; // 12
+
+ staticString = temp + " world!"; // 14
+
+ Main main = new Main(); // 16
+
+ for (int i = 0; i < args.length; i++) {
+ main.go(args[i]); // 19
+ }
+ }
+
+ Main() { // 23
+ }
+
+ void go(String s) { // 26
+ try {
+
+ String temp = this.s; // 29
+
+ this.s = temp + ", " + s; // 31
+
+ } catch (RuntimeException e) { // 33
+
+ stop(); // 35
+
+ }
+ }
+
+ void stop() { // 40
+
+ new Main(); // 42
+
+ }
+}
+
+
+class C {
+
+ C() { // 50
+
+ }
+
+}
+
diff --git a/tests/new/binaryWarnings/src/aspects/MainWarnings.java b/tests/new/binaryWarnings/src/aspects/MainWarnings.java
new file mode 100644
index 000000000..4debf1f3b
--- /dev/null
+++ b/tests/new/binaryWarnings/src/aspects/MainWarnings.java
@@ -0,0 +1,56 @@
+
+package aspects;
+
+import app.Main;
+
+// WARNING: do not change message text without changing test specification
+public privileged aspect MainWarnings {
+
+ declare warning : staticinitialization(Main)
+ : "staticinitializtion(Main)";
+
+ declare warning : initialization(Main.new())
+ : "initialization(Main.new())";
+
+ declare warning : execution(Main.new())
+ : "execution(Main.new())";
+
+ declare warning : execution(void Main.go(String))
+ : "execution(void Main.go(String))";
+
+ declare warning : call(Main.new())
+ : "call(Main.new())";
+
+ declare warning : call(void Main.go(String))
+ : "call(void Main.go(String))";
+
+ declare warning : call(Main.new())
+ && withincode(void Main.stop())
+ : "call(Main.new()) && withincode(void Main.stop())";
+
+ declare warning : call(void Main.stop())
+ && withincode(void Main.go(String))
+ : "call(void Main.stop()) && withincode(void Main.go(String))";
+
+ declare warning : get(String Main.s)
+ : "get(String Main.s)";
+
+ declare warning : set(String Main.s)
+ : "set(String Main.s)";
+
+ declare warning : get(String Main.staticString)
+ : "get(String Main.staticString)";
+
+ declare warning : set(String Main.staticString)
+ : "set(String Main.staticString)";
+
+ declare warning : handler(RuntimeException)
+ && within(Main)
+ : "handler(RuntimeException) && within(Main)";
+
+ declare warning : preinitialization(app.C.new())
+ : "preinitialization(app.C.new())";
+
+// declare warning : adviceexecution() && within(app.AdvisingAspect)
+// : "adviceexecution() && within(app.AdvisingAspect)";
+} \ No newline at end of file