8199081: [Testbug] compiler/linkage/LinkageErrors.java fails if run twice
authoriignatyev
Fri, 03 Aug 2018 15:39:28 -0700
changeset 51351 2bb9b1abadbf
parent 51307 4322ef0c1684
child 51352 f646ca47e561
8199081: [Testbug] compiler/linkage/LinkageErrors.java fails if run twice Reviewed-by: kvn, vlivanov
test/hotspot/jtreg/compiler/linkage/CallSites.jasm
test/hotspot/jtreg/compiler/linkage/LinkageErrors.java
--- a/test/hotspot/jtreg/compiler/linkage/CallSites.jasm	Thu Aug 02 09:26:40 2018 -0700
+++ b/test/hotspot/jtreg/compiler/linkage/CallSites.jasm	Fri Aug 03 15:39:28 2018 -0700
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -21,12 +21,6 @@
  * questions.
  *
  */
-super class compiler/linkage/I
-version 52:0
-{
-
-}
-
 
 super class compiler/linkage/CallSites
 version 52:0
--- a/test/hotspot/jtreg/compiler/linkage/LinkageErrors.java	Thu Aug 02 09:26:40 2018 -0700
+++ b/test/hotspot/jtreg/compiler/linkage/LinkageErrors.java	Fri Aug 03 15:39:28 2018 -0700
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  *
  * This code is free software; you can redistribute it and/or modify it
@@ -54,11 +54,24 @@
 public class LinkageErrors {
     final static MethodHandles.Lookup L = MethodHandles.lookup();
 
-    static void test(MethodHandle mh) {
+    static void testICCE(MethodHandle mh) {
         try {
             mh.invokeExact();
             throw new AssertionError("No exception thrown");
-        } catch (LinkageError e) {
+        } catch (IncompatibleClassChangeError e) {
+            return; // expected
+        } catch (AssertionError e) {
+            throw e; // rethrow
+        } catch (Throwable e) {
+            throw new AssertionError("Unexpected exception", e);
+        }
+    }
+
+    static void testNSME(MethodHandle mh) {
+        try {
+            mh.invokeExact();
+            throw new AssertionError("No exception thrown");
+        } catch (NoSuchMethodError e) {
             return; // expected
         } catch (AssertionError e) {
             throw e; // rethrow
@@ -93,18 +106,18 @@
         MethodHandle testX3_null = testX3.bindTo(null);
 
         for (int i = 0; i < 20_000; i++) {
-            test(testI1_A);
-            test(testI1_null);
-            test(testX1_X);
-            test(testX1_null);
+            testNSME(testI1_A);
+            testNSME(testI1_null);
+            testNSME(testX1_X);
+            testNSME(testX1_null);
 
-            test(testI2);
-            test(testX2);
+            testICCE(testI2);
+            testICCE(testX2);
 
-            test(testI3_A);
-            test(testI3_null);
-            test(testX3_X);
-            test(testX3_null);
+            testICCE(testI3_A);
+            testICCE(testI3_null);
+            testICCE(testX3_X);
+            testICCE(testX3_null);
         }
 
         System.out.println("TEST PASSED");