test/jdk/jdk/jfr/jvm/TestUnsupportedVM.java
author mgronlun
Wed, 30 Oct 2019 19:43:52 +0100
changeset 58863 c16ac7a2eba4
parent 51214 67736b4846a0
permissions -rw-r--r--
8226511: Implement JFR Event Streaming Reviewed-by: egahlin, mseledtsov, mgronlun Contributed-by: erik.gahlin@oracle.com, mikhailo.seledtsov@oracle.com, markus.gronlund@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
     2
 * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved.
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     4
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    10
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    15
 * accompanied this code).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    16
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    20
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    23
 * questions.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    24
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    25
package jdk.jfr.jvm;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    26
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
import java.io.FileReader;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
import java.io.IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
import java.nio.file.Files;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
import java.nio.file.Path;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
import java.nio.file.Paths;
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
    33
import java.time.Duration;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
import java.util.ArrayList;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
import java.util.concurrent.Callable;
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
    36
import java.util.concurrent.atomic.AtomicBoolean;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
import jdk.jfr.AnnotationElement;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
import jdk.jfr.Configuration;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
import jdk.jfr.Description;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
import jdk.jfr.Event;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
import jdk.jfr.EventFactory;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
import jdk.jfr.EventSettings;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
import jdk.jfr.EventType;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
import jdk.jfr.FlightRecorder;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
import jdk.jfr.FlightRecorderListener;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
import jdk.jfr.FlightRecorderPermission;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
import jdk.jfr.Label;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
import jdk.jfr.Recording;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
import jdk.jfr.RecordingState;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
import jdk.jfr.SettingControl;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
import jdk.jfr.ValueDescriptor;
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
    53
import jdk.jfr.consumer.EventStream;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
import jdk.jfr.consumer.RecordedClass;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
import jdk.jfr.consumer.RecordedEvent;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
import jdk.jfr.consumer.RecordedFrame;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
import jdk.jfr.consumer.RecordedMethod;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
import jdk.jfr.consumer.RecordedObject;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
import jdk.jfr.consumer.RecordedStackTrace;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
import jdk.jfr.consumer.RecordedThread;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
import jdk.jfr.consumer.RecordedThreadGroup;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
import jdk.jfr.consumer.RecordingFile;
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
    63
import jdk.jfr.consumer.RecordingStream;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
import jdk.management.jfr.ConfigurationInfo;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    65
import jdk.management.jfr.EventTypeInfo;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
import jdk.management.jfr.FlightRecorderMXBean;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    67
import jdk.management.jfr.RecordingInfo;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    68
import jdk.management.jfr.SettingDescriptorInfo;
50225
2942ae532175 8201331: Better test cleanup for jdk/jfr/api/consumer/TestRecordingFile.java
egahlin
parents: 50113
diff changeset
    69
import jdk.test.lib.Utils;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
51214
67736b4846a0 8207830: [aix] disable jfr in build and tests
goetz
parents: 50251
diff changeset
    71
/**
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    72
 * @test TestUnsupportedVM
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    73
 * @key jfr
51214
67736b4846a0 8207830: [aix] disable jfr in build and tests
goetz
parents: 50251
diff changeset
    74
 * @requires vm.hasJFR
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    75
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
 * @modules jdk.jfr
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
 *          jdk.management.jfr
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
 *
50251
dc01f2104e46 8203774: jdk/jfr/api/recorder/TestStartStopRecording.java failed due to compilation failed
egahlin
parents: 50225
diff changeset
    79
 * @library /test/lib
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    80
 * @run main/othervm -Dprepare-recording=true jdk.jfr.jvm.TestUnsupportedVM
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    81
 * @run main/othervm -Djfr.unsupported.vm=true jdk.jfr.jvm.TestUnsupportedVM
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    82
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    83
public class TestUnsupportedVM {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    84
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    85
    private static Path RECORDING_FILE = Paths.get("recording.jfr");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    86
    private static Class<?> [] APIClasses = {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    87
            AnnotationElement.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
            Configuration.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
            ConfigurationInfo.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    90
            Event.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
            EventFactory.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
            EventSettings.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
            EventType.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
            EventTypeInfo.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
            FlightRecorder.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
            FlightRecorderPermission.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
            FlightRecorderListener.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
            FlightRecorderMXBean.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
            RecordedClass.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
            RecordedEvent.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   101
            RecordedFrame.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
            RecordedMethod.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
            RecordedObject.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
            RecordedStackTrace.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   105
            RecordedThread.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   106
            RecordedThreadGroup.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   107
            Recording.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   108
            RecordingFile.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
            RecordingInfo.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
            RecordingState.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
            SettingControl.class,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
            SettingDescriptorInfo.class,
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   113
            ValueDescriptor.class,
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   114
            EventStream.class,
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   115
            RecordingStream.class
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
       };
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   117
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
    @Label("My Event")
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
    @Description("My fine event")
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
    static class MyEvent extends Event {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
        int myValue;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
    public static void main(String... args) throws Exception {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
        if (Boolean.getBoolean("prepare-recording")) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   126
            Recording r = new Recording(Configuration.getConfiguration("default"));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
            r.start();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
            r.stop();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
            r.dump(RECORDING_FILE);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
            r.close();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
            return;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   134
        System.out.println("jfr.unsupported.vm=" + System.getProperty("jfr.unsupported.vm"));
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
        // Class FlightRecorder
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
        if (FlightRecorder.isAvailable()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
            throw new AssertionError("JFR should not be available on an unsupported VM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
        if (FlightRecorder.isInitialized()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
            throw new AssertionError("JFR should not be initialized on an unsupported VM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
        assertIllegalStateException(() -> FlightRecorder.getFlightRecorder());
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   145
        assertIllegalStateException(() -> new RecordingStream());
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
        assertSwallow(() -> FlightRecorder.addListener(new FlightRecorderListener() {}));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
        assertSwallow(() -> FlightRecorder.removeListener(new FlightRecorderListener() {}));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
        assertSwallow(() -> FlightRecorder.register(MyEvent.class));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
        assertSwallow(() -> FlightRecorder.unregister(MyEvent.class));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
        assertSwallow(() -> FlightRecorder.addPeriodicEvent(MyEvent.class, new Runnable() { public void run() {} }));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
        assertSwallow(() -> FlightRecorder.removePeriodicEvent(new Runnable() { public void run() {} }));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
        // Class Configuration
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
        if (!Configuration.getConfigurations().isEmpty()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
            throw new AssertionError("Configuration files should not exist on an unsupported VM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
        }
50225
2942ae532175 8201331: Better test cleanup for jdk/jfr/api/consumer/TestRecordingFile.java
egahlin
parents: 50113
diff changeset
   157
        Path jfcFile = Utils.createTempFile("empty", ".jfr");
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
        assertIOException(() -> Configuration.getConfiguration("default"));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
        assertIOException(() -> Configuration.create(jfcFile));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
        assertIOException(() -> Configuration.create(new FileReader(jfcFile.toFile())));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   161
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   162
        // Class EventType
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   163
        assertInternalError(() -> EventType.getEventType(MyEvent.class));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   164
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
        // Class EventFactory
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
        assertInternalError(() -> EventFactory.create(new ArrayList<>(), new ArrayList<>()));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
        // Create a static event
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
        MyEvent myEvent = new MyEvent();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
        myEvent.begin();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   171
        myEvent.end();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
        myEvent.shouldCommit();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   173
        myEvent.commit();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   174
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
        // Trigger class initialization failure
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
        for (Class<?> c : APIClasses) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
            assertNoClassInitFailure(c);
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
        // jdk.jfr.consumer.*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
        // Only run this part of tests if we are on VM
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   182
        // that can produce a recording file
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
        if (Files.exists(RECORDING_FILE)) {
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   184
            boolean firstFileEvent = true;
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
            for(RecordedEvent re : RecordingFile.readAllEvents(RECORDING_FILE)) {
58863
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   186
                // Print one event
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   187
                if (firstFileEvent) {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   188
                    System.out.println(re);
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   189
                    firstFileEvent = false;
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   190
                }
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   191
            }
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   192
            AtomicBoolean firstStreamEvent = new AtomicBoolean(true);
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   193
            try (EventStream es = EventStream.openFile(RECORDING_FILE)) {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   194
                es.onEvent(e -> {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   195
                    // Print one event
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   196
                    if (firstStreamEvent.get()) {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   197
                        try {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   198
                            System.out.println(e);
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   199
                            firstStreamEvent.set(false);
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   200
                        } catch (Throwable t) {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   201
                            t.printStackTrace();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   202
                        }
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   203
                    }
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   204
                });
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   205
                es.start();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   206
                if (firstStreamEvent.get()) {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   207
                    throw new AssertionError("Didn't print streaming event");
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   208
                }
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   209
            }
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   210
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   211
            try (EventStream es = EventStream.openRepository()) {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   212
                es.onEvent(e -> {
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   213
                    System.out.println(e);
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   214
                });
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   215
                es.startAsync();
c16ac7a2eba4 8226511: Implement JFR Event Streaming
mgronlun
parents: 51214
diff changeset
   216
                es.awaitTermination(Duration.ofMillis(10));
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   217
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   218
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   219
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   220
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   221
    private static void assertNoClassInitFailure(Class<?> clazz) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   222
        try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   223
            Class.forName(clazz.getName(), true, clazz.getClassLoader());
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   224
        } catch (ClassNotFoundException e) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   225
            throw new AssertionError("Could not find public API class on unsupported VM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   226
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   227
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   228
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   229
    private static void assertInternalError(Runnable r) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   230
        try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   231
            r.run();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   232
        } catch (InternalError e) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   233
           // OK, as expected
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   234
            return;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   235
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   236
        throw new AssertionError("Expected InternalError on an unsupported JVM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   237
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   238
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   239
    private static void assertIOException(Callable<?> c) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   240
        try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   241
            c.call();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   242
        } catch (Exception e) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   243
            if (e.getClass() == IOException.class) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   244
                return;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   245
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   246
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   247
        throw new AssertionError("Expected IOException on an unsupported JVM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   248
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   249
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   250
    private static void assertIllegalStateException(Runnable r) throws Exception {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   251
        try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   252
            r.run();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   253
        } catch (IllegalStateException ise) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   254
            if (!ise.getMessage().equals("Flight Recorder is not supported on this VM")) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   255
                throw new AssertionError("Expected 'Flight Recorder is not supported on this VM'");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   256
            }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   257
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   258
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   259
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   260
    private static void assertSwallow(Runnable r) throws Exception {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   261
        try {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   262
            r.run();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   263
        } catch (Exception e) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   264
            throw new AssertionError("Unexpected exception '" + e.getMessage() + " on an unspported VM");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   265
        }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   266
    }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   267
}