jdk/test/java/lang/instrument/RedefineMethodInBacktraceApp.java
author alanb
Fri, 07 Apr 2017 08:05:54 +0000
changeset 44545 83b611b88ac8
parent 30355 e37c7eba132f
permissions -rw-r--r--
8177530: Module system implementation refresh (4/2017) Reviewed-by: mchung, alanb Contributed-by: alan.bateman@oracle.com, mandy.chung@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     1
/*
30355
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
     2
 * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     4
 *
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     7
 * published by the Free Software Foundation.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     8
 *
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    13
 * accompanied this code).
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    14
 *
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    18
 *
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    21
 * questions.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    22
 */
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    23
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    24
import com.sun.management.DiagnosticCommandMBean;
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    25
import java.io.File;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    26
import java.io.FileInputStream;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    27
import java.io.InputStream;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    28
import java.lang.instrument.ClassDefinition;
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    29
import java.lang.management.ManagementFactory;
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    30
import java.lang.management.ThreadInfo;
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    31
import java.lang.reflect.InvocationTargetException;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    32
import java.lang.reflect.Method;
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    33
import java.util.concurrent.CountDownLatch;
30355
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
    34
import javax.management.JMX;
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
    35
import javax.management.ObjectName;
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    36
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    37
/**
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    38
 * When an exception is thrown, the JVM collects just enough information
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    39
 * about the stack trace to be able to create a full fledged stack trace
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    40
 * (StackTraceElement[]). The backtrace contains this information and the
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    41
 * JVM  must make sure that the data in the backtrace is still usable after
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    42
 * a class redefinition.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    43
 *
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    44
 * After the PermGen removal there was a bug when the last reference to a Method
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    45
 * was in the backtrace. The class of the method was kept alive, because of the
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    46
 * mirror stored in the backtrace, but the old versions of the redefined method
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    47
 * could be freed, since class redefinition didn't know about the backtraces.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    48
 */
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    49
public class RedefineMethodInBacktraceApp {
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    50
    static boolean failed = false;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    51
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    52
    public static void main(String args[]) throws Exception {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    53
        System.out.println("Hello from RedefineMethodInBacktraceApp!");
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    54
        new RedefineMethodInBacktraceApp().doTest();
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    55
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    56
        if (failed) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    57
            throw new Exception("ERROR: RedefineMethodInBacktraceApp failed.");
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    58
        }
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    59
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    60
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    61
    public static CountDownLatch stop = new CountDownLatch(1);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    62
    public static CountDownLatch called = new CountDownLatch(1);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    63
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    64
    private void doTest() throws Exception {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    65
        doMethodInBacktraceTest();
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    66
        doMethodInBacktraceTestB();
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    67
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    68
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    69
    private void doMethodInBacktraceTest() throws Exception {
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    70
        Throwable t1 = getThrowableFromMethodToRedefine();
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    71
        Throwable t2 = getThrowableFromMethodToDelete();
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    72
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    73
        doRedefine(RedefineMethodInBacktraceTarget.class);
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    74
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    75
        doClassUnloading();
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    76
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    77
        System.out.println("checking backtrace for throwable from methodToRedefine");
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    78
        touchRedefinedMethodInBacktrace(t1);
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    79
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    80
        System.out.println("checking backtrace for throwable from methodToDelete");
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
    81
        touchRedefinedMethodInBacktrace(t2);
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    82
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
    83
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    84
    private void doMethodInBacktraceTestB() throws Exception {
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    85
        // Start a thread which blocks in method
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    86
        Thread t = new Thread(RedefineMethodInBacktraceTargetB::methodToRedefine);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    87
        t.setDaemon(true);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    88
        t.start();
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    89
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    90
        // Wait here until the new thread is in the method we want to redefine
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    91
        called.await();
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    92
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    93
        // Now redefine the class while the method is still on the stack of the new thread
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    94
        doRedefine(RedefineMethodInBacktraceTargetB.class);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    95
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    96
        // Do thread dumps in two different ways (to exercise different code paths)
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    97
        // while the old class is still on the stack
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    98
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
    99
        ThreadInfo[] tis = ManagementFactory.getThreadMXBean().dumpAllThreads(false, false);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   100
        for(ThreadInfo ti : tis) {
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   101
            System.out.println(ti);
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   102
        }
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   103
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   104
        String[] threadPrintArgs = {};
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   105
        Object[] dcmdArgs = {threadPrintArgs};
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   106
        String[] signature = {String[].class.getName()};
30355
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
   107
        System.out.println(ManagementFactory.getPlatformMBeanServer().invoke(
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
   108
                ObjectName.getInstance("com.sun.management:type=DiagnosticCommand"),
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
   109
                "threadPrint",
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
   110
                dcmdArgs,
e37c7eba132f 8042901: Allow com.sun.management to be in a different module to java.lang.management
sjiang
parents: 30327
diff changeset
   111
                signature));
21310
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   112
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   113
        // release the thread
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   114
        stop.countDown();
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   115
    }
4595a9405051 8025238: nsk/jvmti/scenarios/bcinstr/BI04/bi04t002 crashed with SIGSEGV
sla
parents: 16021
diff changeset
   116
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   117
    private static Throwable getThrowableFromMethodToRedefine() throws Exception {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   118
        Class<RedefineMethodInBacktraceTarget> c =
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   119
                RedefineMethodInBacktraceTarget.class;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   120
        Method method = c.getMethod("methodToRedefine");
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   121
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   122
        Throwable thrownFromMethodToRedefine = null;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   123
        try {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   124
            method.invoke(null);
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   125
        } catch (InvocationTargetException e) {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   126
            thrownFromMethodToRedefine = e.getCause();
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   127
            if (!(thrownFromMethodToRedefine instanceof RuntimeException)) {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   128
                throw e;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   129
            }
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   130
        } catch (Exception e) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   131
            e.printStackTrace();
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   132
            System.out.println("\nTest failed: unexpected exception: " + e.toString());
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   133
            failed = true;
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   134
        }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   135
        method = null;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   136
        c = null;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   137
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   138
        return thrownFromMethodToRedefine;
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   139
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   140
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   141
    private static Throwable getThrowableFromMethodToDelete() throws Exception {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   142
        Class<RedefineMethodInBacktraceTarget> c =
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   143
                RedefineMethodInBacktraceTarget.class;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   144
        Method method = c.getMethod("callMethodToDelete");
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   145
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   146
        Throwable thrownFromMethodToDelete = null;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   147
        try {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   148
            method.invoke(null);
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   149
        } catch (InvocationTargetException e) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   150
            thrownFromMethodToDelete = e.getCause();
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   151
            if (!(thrownFromMethodToDelete instanceof RuntimeException)) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   152
                throw e;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   153
            }
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   154
        } catch (Exception e) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   155
            e.printStackTrace();
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   156
            System.out.println("\nTest failed: unexpected exception: " + e.toString());
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   157
            failed = true;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   158
        }
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   159
        return thrownFromMethodToDelete;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   160
    }
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   161
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   162
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   163
    private static void doClassUnloading() {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   164
        // This will clean out old, unused redefined methods.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   165
        System.gc();
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   166
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   167
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   168
    private static void touchRedefinedMethodInBacktrace(Throwable throwable) {
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   169
        throwable.printStackTrace();
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   170
        // Make sure that we can convert the backtrace, which is referring to
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   171
        // the redefined method, to a  StrackTraceElement[] without crashing.
30327
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   172
        StackTraceElement[] stackTrace = throwable.getStackTrace();
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   173
        for (int i = 0; i < stackTrace.length; i++) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   174
          StackTraceElement frame = stackTrace[i];
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   175
          if (frame.getClassName() == null) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   176
              System.out.println("\nTest failed: trace[" + i + "].getClassName() returned null");
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   177
              failed = true;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   178
          }
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   179
          if (frame.getMethodName() == null) {
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   180
              System.out.println("\nTest failed: trace[" + i + "].getMethodName() returned null");
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   181
              failed = true;
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   182
          }
14a05668b003 8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents: 21310
diff changeset
   183
        }
16021
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   184
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   185
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   186
    private static void doRedefine(Class<?> clazz) throws Exception {
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   187
        // Load the second version of this class.
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   188
        File f = new File(clazz.getName() + ".class");
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   189
        System.out.println("Reading test class from " + f.getAbsolutePath());
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   190
        InputStream redefineStream = new FileInputStream(f);
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   191
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   192
        byte[] redefineBuffer = NamedBuffer.loadBufferFromStream(redefineStream);
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   193
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   194
        ClassDefinition redefineParamBlock = new ClassDefinition(
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   195
                clazz, redefineBuffer);
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   196
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   197
        RedefineMethodInBacktraceAgent.getInstrumentation().redefineClasses(
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   198
                new ClassDefinition[] {redefineParamBlock});
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   199
    }
471eee27e770 8006506: Add test for redefining methods in backtraces to java/lang/instrument tests
stefank
parents:
diff changeset
   200
}