src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.test/src/org/graalvm/compiler/test/GraalTest.java
author chegar
Thu, 17 Oct 2019 20:54:25 +0100
branchdatagramsocketimpl-branch
changeset 58679 9c3209ff7550
parent 58678 9cf78a70fa4f
parent 58299 6df94ce3ab2f
permissions -rw-r--r--
datagramsocketimpl-branch: merge with default
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     1
/*
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
     2
 * Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     4
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     8
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    13
 * accompanied this code).
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    14
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    18
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    21
 * questions.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    22
 */
50858
2d3e99a72541 8205824: Update Graal
never
parents: 49873
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 49873
diff changeset
    24
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    25
package org.graalvm.compiler.test;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    27
import static org.graalvm.compiler.debug.DebugContext.DEFAULT_LOG_STREAM;
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    28
import static org.graalvm.compiler.debug.DebugContext.NO_DESCRIPTION;
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    29
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
    30
import java.io.IOException;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
import java.io.PrintStream;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import java.io.PrintWriter;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import java.lang.reflect.Field;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
import java.lang.reflect.Method;
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
    35
import java.nio.file.FileVisitResult;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
    36
import java.nio.file.Files;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
    37
import java.nio.file.Path;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    38
import java.nio.file.Paths;
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
    39
import java.nio.file.SimpleFileVisitor;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
    40
import java.nio.file.attribute.BasicFileAttributes;
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
    41
import java.nio.file.attribute.FileAttribute;
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    42
import java.util.ArrayList;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    43
import java.util.Arrays;
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    44
import java.util.Collection;
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    45
import java.util.Collections;
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
    46
import java.util.List;
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    47
import java.util.concurrent.TimeUnit;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    49
import org.graalvm.compiler.debug.DebugContext;
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    50
import org.graalvm.compiler.debug.DebugDumpHandler;
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
    51
import org.graalvm.compiler.debug.DebugHandlersFactory;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
    52
import org.graalvm.compiler.debug.GlobalMetrics;
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    53
import org.graalvm.compiler.options.OptionValues;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    54
import org.graalvm.compiler.serviceprovider.GraalServices;
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
    55
import org.junit.After;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
import org.junit.Assert;
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
    57
import org.junit.AssumptionViolatedException;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    58
import org.junit.internal.ComparisonCriteria;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    59
import org.junit.internal.ExactComparisonCriteria;
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    60
import org.junit.rules.DisableOnDebug;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    61
import org.junit.rules.TestRule;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    62
import org.junit.rules.Timeout;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    63
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
    64
import jdk.vm.ci.meta.ResolvedJavaMethod;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    65
import sun.misc.Unsafe;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    66
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    67
/**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    68
 * Base class that contains common utility methods and classes useful in unit tests.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    69
 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    70
public class GraalTest {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    71
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    72
    public static final Unsafe UNSAFE;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    73
    static {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    74
        try {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
            Field theUnsafe = Unsafe.class.getDeclaredField("theUnsafe");
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
            theUnsafe.setAccessible(true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    77
            UNSAFE = (Unsafe) theUnsafe.get(Unsafe.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    78
        } catch (Exception e) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    79
            throw new RuntimeException("exception while trying to get Unsafe", e);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    80
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    81
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    83
    protected Method getMethod(String methodName) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    84
        return getMethod(getClass(), methodName);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    85
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    86
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    87
    protected Method getMethod(Class<?> clazz, String methodName) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    88
        Method found = null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    89
        for (Method m : clazz.getMethods()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    90
            if (m.getName().equals(methodName)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    91
                Assert.assertNull(found);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    92
                found = m;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    93
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    94
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    95
        if (found == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    96
            /* Now look for non-public methods (but this does not look in superclasses). */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    97
            for (Method m : clazz.getDeclaredMethods()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    98
                if (m.getName().equals(methodName)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    99
                    Assert.assertNull(found);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   100
                    found = m;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   102
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   103
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   104
        if (found != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   105
            return found;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   107
            throw new RuntimeException("method not found: " + methodName);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   108
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   109
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   110
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46371
diff changeset
   111
    protected Method getMethod(Class<?> clazz, String methodName, Class<?>... parameterTypes) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   112
        try {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   113
            return clazz.getMethod(methodName, parameterTypes);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   114
        } catch (NoSuchMethodException | SecurityException e) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   115
            throw new RuntimeException("method not found: " + methodName + "" + Arrays.toString(parameterTypes));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   116
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   117
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   118
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   119
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   120
     * Compares two given objects for {@linkplain Assert#assertEquals(Object, Object) equality}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   121
     * Does a deep copy equality comparison if {@code expected} is an array.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   122
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   123
    protected void assertDeepEquals(Object expected, Object actual) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   124
        assertDeepEquals(null, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   125
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   126
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   127
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   128
     * Compares two given objects for {@linkplain Assert#assertEquals(Object, Object) equality}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   129
     * Does a deep copy equality comparison if {@code expected} is an array.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   130
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   131
     * @param message the identifying message for the {@link AssertionError}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   132
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   133
    protected void assertDeepEquals(String message, Object expected, Object actual) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   134
        if (ulpsDelta() > 0) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   135
            assertDeepEquals(message, expected, actual, ulpsDelta());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   136
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   137
            assertDeepEquals(message, expected, actual, equalFloatsOrDoublesDelta());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   138
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   139
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   140
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   141
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   142
     * Compares two given values for equality, doing a recursive test if both values are arrays of
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   143
     * the same type.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   144
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   145
     * @param message the identifying message for the {@link AssertionError}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   146
     * @param delta the maximum delta between two doubles or floats for which both numbers are still
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   147
     *            considered equal.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   148
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   149
    protected void assertDeepEquals(String message, Object expected, Object actual, double delta) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   150
        if (expected != null && actual != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   151
            Class<?> expectedClass = expected.getClass();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   152
            Class<?> actualClass = actual.getClass();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   153
            if (expectedClass.isArray()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   154
                Assert.assertEquals(message, expectedClass, actual.getClass());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
                if (expected instanceof int[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
                    Assert.assertArrayEquals(message, (int[]) expected, (int[]) actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   157
                } else if (expected instanceof byte[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   158
                    Assert.assertArrayEquals(message, (byte[]) expected, (byte[]) actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   159
                } else if (expected instanceof char[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   160
                    Assert.assertArrayEquals(message, (char[]) expected, (char[]) actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   161
                } else if (expected instanceof short[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   162
                    Assert.assertArrayEquals(message, (short[]) expected, (short[]) actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   163
                } else if (expected instanceof float[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   164
                    Assert.assertArrayEquals(message, (float[]) expected, (float[]) actual, (float) delta);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   165
                } else if (expected instanceof long[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   166
                    Assert.assertArrayEquals(message, (long[]) expected, (long[]) actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   167
                } else if (expected instanceof double[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   168
                    Assert.assertArrayEquals(message, (double[]) expected, (double[]) actual, delta);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   169
                } else if (expected instanceof boolean[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   170
                    new ExactComparisonCriteria().arrayEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   171
                } else if (expected instanceof Object[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   172
                    new ComparisonCriteria() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   173
                        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   174
                        protected void assertElementsEqual(Object e, Object a) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   175
                            assertDeepEquals(message, e, a, delta);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   176
                        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   177
                    }.arrayEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   178
                } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   179
                    Assert.fail((message == null ? "" : message) + "non-array value encountered: " + expected);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   180
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   181
            } else if (expectedClass.equals(double.class) && actualClass.equals(double.class)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   182
                Assert.assertEquals((double) expected, (double) actual, delta);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   183
            } else if (expectedClass.equals(float.class) && actualClass.equals(float.class)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   184
                Assert.assertEquals((float) expected, (float) actual, delta);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   185
            } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   186
                Assert.assertEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   187
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   188
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   189
            Assert.assertEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   190
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   191
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   192
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   193
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
     * Compares two given values for equality, doing a recursive test if both values are arrays of
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   195
     * the same type. Uses {@linkplain StrictMath#ulp(float) ULP}s for comparison of floats.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   196
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   197
     * @param message the identifying message for the {@link AssertionError}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   198
     * @param ulpsDelta the maximum allowed ulps difference between two doubles or floats for which
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   199
     *            both numbers are still considered equal.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   200
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   201
    protected void assertDeepEquals(String message, Object expected, Object actual, int ulpsDelta) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
        ComparisonCriteria doubleUlpsDeltaCriteria = new ComparisonCriteria() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   203
            @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   204
            protected void assertElementsEqual(Object e, Object a) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   205
                assertTrue(message, e instanceof Double && a instanceof Double);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   206
                // determine acceptable error based on whether it is a normal number or a NaN/Inf
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   207
                double de = (Double) e;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   208
                double epsilon = (!Double.isNaN(de) && Double.isFinite(de) ? ulpsDelta * Math.ulp(de) : 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   209
                Assert.assertEquals(message, (Double) e, (Double) a, epsilon);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   210
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   211
        };
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   212
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   213
        ComparisonCriteria floatUlpsDeltaCriteria = new ComparisonCriteria() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   214
            @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   215
            protected void assertElementsEqual(Object e, Object a) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   216
                assertTrue(message, e instanceof Float && a instanceof Float);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   217
                // determine acceptable error based on whether it is a normal number or a NaN/Inf
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   218
                float fe = (Float) e;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   219
                float epsilon = (!Float.isNaN(fe) && Float.isFinite(fe) ? ulpsDelta * Math.ulp(fe) : 0);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   220
                Assert.assertEquals(message, (Float) e, (Float) a, epsilon);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   221
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   222
        };
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   223
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   224
        if (expected != null && actual != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   225
            Class<?> expectedClass = expected.getClass();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   226
            Class<?> actualClass = actual.getClass();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   227
            if (expectedClass.isArray()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   228
                Assert.assertEquals(message, expectedClass, actualClass);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   229
                if (expected instanceof double[] || expected instanceof Object[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   230
                    doubleUlpsDeltaCriteria.arrayEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   231
                    return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   232
                } else if (expected instanceof float[] || expected instanceof Object[]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   233
                    floatUlpsDeltaCriteria.arrayEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   234
                    return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   235
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   236
            } else if (expectedClass.equals(double.class) && actualClass.equals(double.class)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   237
                doubleUlpsDeltaCriteria.arrayEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   238
                return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   239
            } else if (expectedClass.equals(float.class) && actualClass.equals(float.class)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   240
                floatUlpsDeltaCriteria.arrayEquals(message, expected, actual);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   241
                return;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   242
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   243
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   244
        // anything else just use the non-ulps version
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   245
        assertDeepEquals(message, expected, actual, equalFloatsOrDoublesDelta());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   246
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   247
52910
583fd71c47d6 8214023: Update Graal
dlong
parents: 52578
diff changeset
   248
    /**
583fd71c47d6 8214023: Update Graal
dlong
parents: 52578
diff changeset
   249
     * @see "https://bugs.openjdk.java.net/browse/JDK-8076557"
583fd71c47d6 8214023: Update Graal
dlong
parents: 52578
diff changeset
   250
     */
583fd71c47d6 8214023: Update Graal
dlong
parents: 52578
diff changeset
   251
    public static void assumeManagementLibraryIsLoadable() {
52578
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   252
        try {
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   253
            /* Trigger loading of the management library using the bootstrap class loader. */
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   254
            GraalServices.getCurrentThreadAllocatedBytes();
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   255
        } catch (UnsatisfiedLinkError | NoClassDefFoundError | UnsupportedOperationException e) {
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   256
            throw new AssumptionViolatedException("Management interface is unavailable: " + e);
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   257
        }
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   258
    }
7dd81e82d083 8210777: Update Graal
dlong
parents: 52427
diff changeset
   259
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   260
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   261
     * Gets the value used by {@link #assertDeepEquals(Object, Object)} and
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   262
     * {@link #assertDeepEquals(String, Object, Object)} for the maximum delta between two doubles
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   263
     * or floats for which both numbers are still considered equal.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   264
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   265
    protected double equalFloatsOrDoublesDelta() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   266
        return 0.0D;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   267
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   268
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   269
    // unless overridden ulpsDelta is not used
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   270
    protected int ulpsDelta() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   271
        return 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   272
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   273
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   274
    @SuppressWarnings("serial")
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   275
    public static class MultiCauseAssertionError extends AssertionError {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   276
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   277
        private Throwable[] causes;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   278
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   279
        public MultiCauseAssertionError(String message, Throwable... causes) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   280
            super(message);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   281
            this.causes = causes;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   282
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   283
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   284
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   285
        public void printStackTrace(PrintStream out) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   286
            super.printStackTrace(out);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   287
            int num = 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   288
            for (Throwable cause : causes) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   289
                if (cause != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   290
                    out.print("cause " + (num++));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   291
                    cause.printStackTrace(out);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   292
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   293
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   294
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   295
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   296
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   297
        public void printStackTrace(PrintWriter out) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   298
            super.printStackTrace(out);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   299
            int num = 0;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   300
            for (Throwable cause : causes) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   301
                if (cause != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   302
                    out.print("cause " + (num++) + ": ");
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   303
                    cause.printStackTrace(out);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   304
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   305
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   306
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   307
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   308
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   309
    /*
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   310
     * Overrides to the normal JUnit {@link Assert} routines that provide varargs style formatting
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   311
     * and produce an exception stack trace with the assertion frames trimmed out.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   312
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   313
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   314
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   315
     * Fails a test with the given message.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   316
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   317
     * @param message the identifying message for the {@link AssertionError} (<code>null</code>
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   318
     *            okay)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   319
     * @see AssertionError
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   320
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   321
    public static void fail(String message, Object... objects) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   322
        AssertionError e;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   323
        if (message == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   324
            e = new AssertionError();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   325
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   326
            e = new AssertionError(String.format(message, objects));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   327
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   328
        // Trim the assert frames from the stack trace
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   329
        StackTraceElement[] trace = e.getStackTrace();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   330
        int start = 1; // Skip this frame
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   331
        String thisClassName = GraalTest.class.getName();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   332
        while (start < trace.length && trace[start].getClassName().equals(thisClassName) && (trace[start].getMethodName().equals("assertTrue") || trace[start].getMethodName().equals("assertFalse"))) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   333
            start++;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   334
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   335
        e.setStackTrace(Arrays.copyOfRange(trace, start, trace.length));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   336
        throw e;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   337
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   338
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   339
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   340
     * Asserts that a condition is true. If it isn't it throws an {@link AssertionError} with the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   341
     * given message.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   342
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   343
     * @param message the identifying message for the {@link AssertionError} (<code>null</code>
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   344
     *            okay)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   345
     * @param condition condition to be checked
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   346
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   347
    public static void assertTrue(String message, boolean condition) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   348
        assertTrue(condition, message);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   349
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   350
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   351
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   352
     * Asserts that a condition is true. If it isn't it throws an {@link AssertionError} without a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   353
     * message.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   354
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   355
     * @param condition condition to be checked
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   356
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   357
    public static void assertTrue(boolean condition) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   358
        assertTrue(condition, null);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   359
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   360
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   361
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   362
     * Asserts that a condition is false. If it isn't it throws an {@link AssertionError} with the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   363
     * given message.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   364
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   365
     * @param message the identifying message for the {@link AssertionError} (<code>null</code>
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   366
     *            okay)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   367
     * @param condition condition to be checked
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   368
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   369
    public static void assertFalse(String message, boolean condition) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   370
        assertTrue(!condition, message);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   371
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   372
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   373
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   374
     * Asserts that a condition is false. If it isn't it throws an {@link AssertionError} without a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   375
     * message.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   376
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   377
     * @param condition condition to be checked
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   378
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   379
    public static void assertFalse(boolean condition) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   380
        assertTrue(!condition, null);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   381
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   382
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   383
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   384
     * Asserts that a condition is true. If it isn't it throws an {@link AssertionError} with the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   385
     * given message.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   386
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   387
     * @param condition condition to be checked
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   388
     * @param message the identifying message for the {@link AssertionError}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   389
     * @param objects arguments to the format string
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   390
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   391
    public static void assertTrue(boolean condition, String message, Object... objects) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   392
        if (!condition) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   393
            fail(message, objects);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   394
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   395
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   396
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   397
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   398
     * Asserts that a condition is false. If it isn't it throws an {@link AssertionError} with the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   399
     * given message produced by {@link String#format}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   400
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   401
     * @param condition condition to be checked
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   402
     * @param message the identifying message for the {@link AssertionError}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   403
     * @param objects arguments to the format string
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   404
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   405
    public static void assertFalse(boolean condition, String message, Object... objects) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   406
        assertTrue(!condition, message, objects);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   407
    }
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   408
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   409
    /**
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   410
     * Gets the {@link DebugHandlersFactory}s available for a {@link DebugContext}.
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   411
     */
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   412
    protected Collection<DebugHandlersFactory> getDebugHandlersFactories() {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   413
        return Collections.emptyList();
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   414
    }
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   415
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   416
    /**
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   417
     * Gets a {@link DebugContext} object corresponding to {@code options}, creating a new one if
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   418
     * none currently exists. Debug contexts created by this method will have their
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   419
     * {@link DebugDumpHandler}s closed in {@link #afterTest()}.
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   420
     */
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   421
    protected DebugContext getDebugContext(OptionValues options) {
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   422
        return getDebugContext(options, null, null);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   423
    }
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   424
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   425
    /**
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   426
     * Gets a {@link DebugContext} object corresponding to {@code options}, creating a new one if
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   427
     * none currently exists. Debug contexts created by this method will have their
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   428
     * {@link DebugDumpHandler}s closed in {@link #afterTest()}.
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   429
     *
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   430
     * @param options currently active options
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   431
     * @param id identification of the compilation or {@code null}
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   432
     * @param method method to use for a proper description of the context or {@code null}
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   433
     * @return configured context for compilation
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   434
     */
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   435
    protected DebugContext getDebugContext(OptionValues options, String id, ResolvedJavaMethod method) {
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   436
        List<DebugContext> cached = cachedDebugs.get();
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   437
        if (cached == null) {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   438
            cached = new ArrayList<>();
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   439
            cachedDebugs.set(cached);
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   440
        }
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   441
        for (DebugContext debug : cached) {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   442
            if (debug.getOptions() == options) {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   443
                return debug;
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   444
            }
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   445
        }
47798
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   446
        final DebugContext.Description descr;
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   447
        if (method == null) {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   448
            descr = NO_DESCRIPTION;
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   449
        } else {
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   450
            descr = new DebugContext.Description(method, id == null ? method.getName() : id);
9fe9292f5931 8190710: Update Graal
dlong
parents: 47216
diff changeset
   451
        }
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   452
        DebugContext debug = DebugContext.create(options, descr, globalMetrics, DEFAULT_LOG_STREAM, getDebugHandlersFactories());
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   453
        cached.add(debug);
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   454
        return debug;
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   455
    }
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   456
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   457
    private static final GlobalMetrics globalMetrics = new GlobalMetrics();
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   458
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   459
    static {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   460
        Runtime.getRuntime().addShutdownHook(new Thread("GlobalMetricsPrinter") {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   461
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   462
            public void run() {
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   463
                // globalMetrics.print(new OptionValues(OptionValues.newOptionMap()));
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   464
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   465
        });
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   466
    }
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   467
    private final ThreadLocal<List<DebugContext>> cachedDebugs = new ThreadLocal<>();
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   468
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   469
    @After
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   470
    public void afterTest() {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   471
        List<DebugContext> cached = cachedDebugs.get();
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   472
        if (cached != null) {
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   473
            for (DebugContext debug : cached) {
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47798
diff changeset
   474
                debug.close();
46640
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   475
                debug.closeDumpHandlers(true);
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   476
            }
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   477
        }
70bdce04c59b 8183991: Update Graal
iveresov
parents: 46459
diff changeset
   478
    }
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   479
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   480
    private static final double TIMEOUT_SCALING_FACTOR = Double.parseDouble(System.getProperty("graaltest.timeout.factor", "1.0"));
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   481
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   482
    /**
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   483
     * Creates a {@link TestRule} that applies a given timeout.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   484
     *
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   485
     * A test harness can scale {@code length} with a factor specified by the
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   486
     * {@code graaltest.timeout.factor} system property.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   487
     */
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   488
    public static TestRule createTimeout(long length, TimeUnit timeUnit) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   489
        Timeout timeout = new Timeout((long) (length * TIMEOUT_SCALING_FACTOR), timeUnit);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   490
        try {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   491
            return new DisableOnDebug(timeout);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   492
        } catch (LinkageError ex) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   493
            return timeout;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   494
        }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   495
    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   496
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   497
    /**
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   498
     * @see #createTimeout
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   499
     */
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   500
    public static TestRule createTimeoutSeconds(int seconds) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   501
        return createTimeout(seconds, TimeUnit.SECONDS);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   502
    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   503
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   504
    /**
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   505
     * @see #createTimeout
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   506
     */
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   507
    public static TestRule createTimeoutMillis(long milliseconds) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   508
        return createTimeout(milliseconds, TimeUnit.MILLISECONDS);
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   509
    }
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   510
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   511
    public static class TemporaryDirectory implements AutoCloseable {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   512
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   513
        public final Path path;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   514
        private IOException closeException;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   515
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   516
        public TemporaryDirectory(Path dir, String prefix, FileAttribute<?>... attrs) throws IOException {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   517
            path = Files.createTempDirectory(dir == null ? Paths.get(".") : dir, prefix, attrs);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   518
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   519
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   520
        @Override
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   521
        public void close() {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   522
            closeException = removeDirectory(path);
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   523
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   524
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   525
        public IOException getCloseException() {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   526
            return closeException;
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   527
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   528
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   529
        @Override
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   530
        public String toString() {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   531
            return path.toString();
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   532
        }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   533
    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 57537
diff changeset
   534
57537
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   535
    /**
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   536
     * Tries to recursively remove {@code directory}. If it fails with an {@link IOException}, the
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   537
     * exception's {@code toString()} is printed to {@link System#err} and the exception is
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   538
     * returned.
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   539
     */
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   540
    public static IOException removeDirectory(Path directory) {
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   541
        try {
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   542
            Files.walkFileTree(directory, new SimpleFileVisitor<Path>() {
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   543
                @Override
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   544
                public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   545
                    Files.delete(file);
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   546
                    return FileVisitResult.CONTINUE;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   547
                }
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   548
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   549
                @Override
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   550
                public FileVisitResult postVisitDirectory(Path dir, IOException exc) throws IOException {
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   551
                    Files.delete(dir);
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   552
                    return FileVisitResult.CONTINUE;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   553
                }
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   554
            });
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   555
        } catch (IOException e) {
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   556
            System.err.println(e);
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   557
            return e;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   558
        }
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   559
        return null;
ecc6e394475f 8226771: Update Graal
dlong
parents: 55509
diff changeset
   560
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   561
}