aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhugunin <jhugunin>2003-01-07 23:19:58 +0000
committerjhugunin <jhugunin>2003-01-07 23:19:58 +0000
commit1e068fe485d7539ad938712b6bed5812fadf7df7 (patch)
tree619006429e187de543eb94bc8c331f17b9cab2ad
parent360b569d3a63fcd40828a5ef41fe90b91a16aa72 (diff)
downloadaspectj-1e068fe485d7539ad938712b6bed5812fadf7df7.tar.gz
aspectj-1e068fe485d7539ad938712b6bed5812fadf7df7.zip
more tests from bugzilla
-rw-r--r--tests/ajcTests.xml17
-rw-r--r--tests/bugs/DeclareSoftCf.java31
-rw-r--r--tests/bugs/ExceptionsOnInters.java23
-rw-r--r--tests/bugs/InterFieldArrays.java27
-rw-r--r--tests/jimTests.xml6
5 files changed, 103 insertions, 1 deletions
diff --git a/tests/ajcTests.xml b/tests/ajcTests.xml
index b5d9a0362..46d3e03a6 100644
--- a/tests/ajcTests.xml
+++ b/tests/ajcTests.xml
@@ -5448,4 +5448,21 @@
<run class="ConstructorArgTracing"/>
</ajc-test>
+ <ajc-test dir="bugs" pr="29106" title="declared exceptions in inter-type decls">
+ <compile files="ExceptionsOnInters.java"/>
+ <run class="ExceptionsOnInters"/>
+ </ajc-test>
+
+ <ajc-test dir="bugs" pr="28921"
+ title="Verify error on non-Throwable in declare soft">
+ <compile files="DeclareSoftCf.java" options="-Xlint:warning">
+ <message kind="warning" line="28"/>
+ <message kind="error" line="29"/>
+ </compile>
+ </ajc-test>
+
+ <ajc-test dir="bugs" pr="29113" title="inter-type fields with array types">
+ <compile files="InterFieldArrays.java"/>
+ <run class="InterFieldArrays"/>
+ </ajc-test>
</suite>
diff --git a/tests/bugs/DeclareSoftCf.java b/tests/bugs/DeclareSoftCf.java
new file mode 100644
index 000000000..2c9e5581e
--- /dev/null
+++ b/tests/bugs/DeclareSoftCf.java
@@ -0,0 +1,31 @@
+// from Bug 28921
+import org.aspectj.lang.*;
+
+public class DeclareSoftCf {
+
+ public static void a(){
+ b();
+ }
+ /**
+ * Method b.
+ */
+ private static void b() {
+ throw new RuntimeException("Orig");
+ }
+
+ public static void main(String[] args) {
+ try {
+ a();
+ } catch (SoftException e) {
+ System.out.println(e.getWrappedThrowable());
+ }
+ }
+
+ public static interface Checked{
+ }
+
+ static aspect Softner{
+ declare parents : Exception+ && !RuntimeException implements Checked;
+ declare soft : Checked : within(DeclareSoftCf); // ERR: Checked not a Throwable
+ }
+} \ No newline at end of file
diff --git a/tests/bugs/ExceptionsOnInters.java b/tests/bugs/ExceptionsOnInters.java
new file mode 100644
index 000000000..58bb5ef58
--- /dev/null
+++ b/tests/bugs/ExceptionsOnInters.java
@@ -0,0 +1,23 @@
+// from Bug 29106
+
+public class ExceptionsOnInters {
+ public static void main(String args[]) {
+ try {
+ ExceptionsOnInters.bomb();
+ } catch (BombException e) {
+ System.err.println(e);
+ }
+ }
+}
+
+aspect Bomb {
+ public static void ExceptionsOnInters.bomb() throws BombException {
+ throw new BombException("KABOOM");
+ }
+}
+
+class BombException extends Exception {
+ public BombException(String message) {
+ super(message);
+ }
+}
diff --git a/tests/bugs/InterFieldArrays.java b/tests/bugs/InterFieldArrays.java
new file mode 100644
index 000000000..e44e9f57c
--- /dev/null
+++ b/tests/bugs/InterFieldArrays.java
@@ -0,0 +1,27 @@
+import org.aspectj.testing.Tester;
+
+public class InterFieldArrays {
+ public static void main(String[] args) {
+ Foo foo = new Foo();
+ Tester.checkEqual(foo.bar.length, 3);
+ Tester.checkEqual(foo.bar1.length, 3);
+
+ foo.bar2 = new int[] { 21, 22, 23};
+ Tester.checkEqual(foo.bar2.length, 3);
+
+ Tester.checkEqual(foo.bar[2], 3);
+ Tester.checkEqual(foo.bar1[2], 13);
+ Tester.checkEqual(foo.bar2[2], 23);
+
+ int[] a = foo.getInts();
+ }
+}
+
+class Foo { }
+aspect Bar {
+ int[] Foo.bar = { 1, 2, 3 };
+ int[] Foo.bar1 = new int[] { 11, 12, 13};
+ int[] Foo.bar2 = null;
+
+ int[] Foo.getInts() { return new int[] { 1, 2, 3}; }
+} \ No newline at end of file
diff --git a/tests/jimTests.xml b/tests/jimTests.xml
index 57e827b8c..6c6ed6b7a 100644
--- a/tests/jimTests.xml
+++ b/tests/jimTests.xml
@@ -1,7 +1,11 @@
<!DOCTYPE suite SYSTEM "../tests/ajcTestSuite.dtd">
<suite>
+ <ajc-test dir="new" title="various declared exception permutations"
+ keywords="from-resolved_10x">
+ <compile files="DeclaredExcs.java"/>
+ <run class="DeclaredExcs"/>
+ </ajc-test>
-
<!--
<ajc-test dir="base/test129"
title="DEPRECATED: introduce of abstract methods works"