diff options
Diffstat (limited to 'tests/bugs170')
-rw-r--r-- | tests/bugs170/language/Diamond.java | 14 | ||||
-rw-r--r-- | tests/bugs170/language/DiamondITD.java | 11 | ||||
-rw-r--r-- | tests/bugs170/language/Literals.java | 13 | ||||
-rw-r--r-- | tests/bugs170/language/LiteralsITD.java | 11 | ||||
-rw-r--r-- | tests/bugs170/language/MultiCatch.java | 31 | ||||
-rw-r--r-- | tests/bugs170/language/MultiCatchWithHandler.java | 37 | ||||
-rw-r--r-- | tests/bugs170/language/MultiCatchWithHandler2.java | 37 | ||||
-rw-r--r-- | tests/bugs170/language/StringSwitch.java | 33 | ||||
-rw-r--r-- | tests/bugs170/language/TryResources.java | 15 |
9 files changed, 202 insertions, 0 deletions
diff --git a/tests/bugs170/language/Diamond.java b/tests/bugs170/language/Diamond.java new file mode 100644 index 000000000..2987ccad3 --- /dev/null +++ b/tests/bugs170/language/Diamond.java @@ -0,0 +1,14 @@ +import java.util.*; + +public class Diamond { + public static void main(String []argv) { + } +} + +aspect Foo { + before(): execution(* *(..)) { + // in advice + List<String> ls = new ArrayList<>(); + } + +} diff --git a/tests/bugs170/language/DiamondITD.java b/tests/bugs170/language/DiamondITD.java new file mode 100644 index 000000000..a6acbe001 --- /dev/null +++ b/tests/bugs170/language/DiamondITD.java @@ -0,0 +1,11 @@ +import java.util.*; + +public class DiamondITD { + public static void main(String []argv) { + } +} + +aspect Foo { + + public List<String> DiamondITD.ls = new ArrayList<>(); +} diff --git a/tests/bugs170/language/Literals.java b/tests/bugs170/language/Literals.java new file mode 100644 index 000000000..60a39a7c5 --- /dev/null +++ b/tests/bugs170/language/Literals.java @@ -0,0 +1,13 @@ +public class Literals { + public static void main(String []argv) { + } +} + +aspect Foo { + before(): execution(* *(..)) { + int onemill = 1_000_000; + int four =0b100; + } + + +} diff --git a/tests/bugs170/language/LiteralsITD.java b/tests/bugs170/language/LiteralsITD.java new file mode 100644 index 000000000..ea25d9d8a --- /dev/null +++ b/tests/bugs170/language/LiteralsITD.java @@ -0,0 +1,11 @@ +public class LiteralsITD { + public static void main(String []argv) { + } +} + +aspect Foo { + before(): execution(* *(..)) { + } + + public int LiteralsITD.id = 0b100_000; +} diff --git a/tests/bugs170/language/MultiCatch.java b/tests/bugs170/language/MultiCatch.java new file mode 100644 index 000000000..8beede752 --- /dev/null +++ b/tests/bugs170/language/MultiCatch.java @@ -0,0 +1,31 @@ +public class MultiCatch { + + public static void main(String[] args) { + try { + foo("abc"); + } catch (ExceptionA | ExceptionB ex) { + bar(ex); + } + } + + public static void bar(Exception ea) { + + } + + public static void foo(String s) throws ExceptionA, ExceptionB { + if (s.equals("ta")) { + throw new ExceptionA(); + } else { + throw new ExceptionB(); + } + } +} + +@SuppressWarnings("serial") +class ExceptionA extends Exception { +} + +@SuppressWarnings("serial") +class ExceptionB extends Exception { +} + diff --git a/tests/bugs170/language/MultiCatchWithHandler.java b/tests/bugs170/language/MultiCatchWithHandler.java new file mode 100644 index 000000000..bb0373f79 --- /dev/null +++ b/tests/bugs170/language/MultiCatchWithHandler.java @@ -0,0 +1,37 @@ +public class MultiCatchWithHandler { + + public static void main(String[] args) { + try { + foo("abc"); + } catch (ExceptionA | ExceptionB ex) { + bar(ex); + } + } + + public static void bar(Exception ea) { + + } + + public static void foo(String s) throws ExceptionA, ExceptionB { + if (s.equals("ta")) { + throw new ExceptionA(); + } else { + throw new ExceptionB(); + } + } +} + +@SuppressWarnings("serial") +class ExceptionA extends Exception { +} + +@SuppressWarnings("serial") +class ExceptionB extends Exception { +} + + +aspect X { + before(ExceptionA ea): handler(ExceptionA) && args(ea) { + System.out.println("in advice"); + } +} diff --git a/tests/bugs170/language/MultiCatchWithHandler2.java b/tests/bugs170/language/MultiCatchWithHandler2.java new file mode 100644 index 000000000..0a8f7a739 --- /dev/null +++ b/tests/bugs170/language/MultiCatchWithHandler2.java @@ -0,0 +1,37 @@ +public class MultiCatchWithHandler2 { + + public static void main(String[] args) { + try { + foo("ta"); + } catch (ExceptionA | ExceptionB ex) { + bar(ex); + } + } + + public static void bar(Exception ea) { + + } + + public static void foo(String s) throws ExceptionA, ExceptionB { + if (s.equals("ta")) { + throw new ExceptionA(); + } else { + throw new ExceptionB(); + } + } +} + +@SuppressWarnings("serial") +class ExceptionA extends Exception { +} + +@SuppressWarnings("serial") +class ExceptionB extends Exception { +} + + +aspect X { + before(ExceptionA ea): handler(ExceptionA) && args(ea) { + System.out.println("advice"); + } +} diff --git a/tests/bugs170/language/StringSwitch.java b/tests/bugs170/language/StringSwitch.java new file mode 100644 index 000000000..140d3b198 --- /dev/null +++ b/tests/bugs170/language/StringSwitch.java @@ -0,0 +1,33 @@ +public class StringSwitch { + public static void main(String []argv) { + } +} + +aspect Foo { + before(): execution(* *(..)) { +String s = "abc"; +switch(s) { + case "quux": + foo(); + // fall-through + + case "foo": + case "bar": + foo(); + break; + + case "baz": + foo(); + // fall-through + + default: + foo(); + break; +} + + } + + + public void foo() {} + +} diff --git a/tests/bugs170/language/TryResources.java b/tests/bugs170/language/TryResources.java new file mode 100644 index 000000000..308000445 --- /dev/null +++ b/tests/bugs170/language/TryResources.java @@ -0,0 +1,15 @@ +public class TryResources { +} + +aspect Foo { + before(): execution(* *(..)) { +try ( + InputStream in = new FileInputStream(src); + OutputStream out = new FileOutputStream(dest)) +{ + // code +} + + + } +} |