diff options
author | jhugunin <jhugunin> | 2003-01-07 23:19:58 +0000 |
---|---|---|
committer | jhugunin <jhugunin> | 2003-01-07 23:19:58 +0000 |
commit | 1e068fe485d7539ad938712b6bed5812fadf7df7 (patch) | |
tree | 619006429e187de543eb94bc8c331f17b9cab2ad | |
parent | 360b569d3a63fcd40828a5ef41fe90b91a16aa72 (diff) | |
download | aspectj-1e068fe485d7539ad938712b6bed5812fadf7df7.tar.gz aspectj-1e068fe485d7539ad938712b6bed5812fadf7df7.zip |
more tests from bugzilla
-rw-r--r-- | tests/ajcTests.xml | 17 | ||||
-rw-r--r-- | tests/bugs/DeclareSoftCf.java | 31 | ||||
-rw-r--r-- | tests/bugs/ExceptionsOnInters.java | 23 | ||||
-rw-r--r-- | tests/bugs/InterFieldArrays.java | 27 | ||||
-rw-r--r-- | tests/jimTests.xml | 6 |
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" |