diff options
author | wisberg <wisberg> | 2002-12-16 18:51:06 +0000 |
---|---|---|
committer | wisberg <wisberg> | 2002-12-16 18:51:06 +0000 |
commit | 144143c2970a1e874d74cdbd0f8c622d4282a3c3 (patch) | |
tree | b12383d3d9e76c7e1f25f7fbec83051ef17f81fb /tests/pureJava/TryCatchFinally.java | |
parent | fafae443719b26159ab2d7dac1c9b46b5e00b671 (diff) | |
download | aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.tar.gz aspectj-144143c2970a1e874d74cdbd0f8c622d4282a3c3.zip |
initial version
Diffstat (limited to 'tests/pureJava/TryCatchFinally.java')
-rw-r--r-- | tests/pureJava/TryCatchFinally.java | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/tests/pureJava/TryCatchFinally.java b/tests/pureJava/TryCatchFinally.java new file mode 100644 index 000000000..5efd434f5 --- /dev/null +++ b/tests/pureJava/TryCatchFinally.java @@ -0,0 +1,86 @@ +import org.aspectj.testing.Tester; + +public class TryCatchFinally { + public static void main(String[] args) { + Tester.checkEqual(m1(), "good"); + Tester.checkEqual(m2(), "good"); + Tester.checkEqual(m3(), "good"); + + try { + m1v(); + } catch (RuntimeException re) { + Tester.event("main-caught"); + } + Tester.checkAndClearEvents(new String[] { + "caught", "finally", "main-caught"} ); + try { + m2v(); + } catch (RuntimeException re) { + Tester.event("main-caught"); + } + Tester.checkAndClearEvents(new String[] { + "caught", "finally", "main-caught"} ); + + m3v(); + Tester.checkAndClearEvents(new String[] { + "caught", "finally"} ); + } + + public static String m1() { + try { + throw new RuntimeException("hi"); + } catch (RuntimeException er) { + throw er; + } finally { + return "good"; + } + } + public static String m2() { + try { + return m1() + "XXX"; + } catch (RuntimeException er) { + throw er; + } finally { + return "good"; + } + } + public static String m3() { + try { + throw new RuntimeException("hi"); + } catch (RuntimeException er) { + return "bad-c"; + } finally { + return "good"; + } + } + public static void m1v() { + try { + throw new RuntimeException("hi"); + } catch (RuntimeException er) { + Tester.event("caught"); + throw er; + } finally { + Tester.event("finally"); + } + } + public static void m2v() { + try { + throw new RuntimeException("hi"); + } catch (RuntimeException er) { + Tester.event("caught"); + throw er; + } finally { + Tester.event("finally"); + } + } + public static void m3v() { + try { + throw new RuntimeException("hi"); + } catch (RuntimeException er) { + Tester.event("caught"); + return; + } finally { + Tester.event("finally"); + } + } +} |