test/jdk/jdk/jfr/jcmd/TestJcmdDumpLimited.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:
50745
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     1
/*
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     2
 * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved.
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     4
 *
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    10
 *
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    15
 * accompanied this code).
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    16
 *
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    20
 *
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    23
 * questions.
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    24
 */
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    25
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    26
package jdk.jfr.jcmd;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    27
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    28
import java.io.IOException;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    29
import java.nio.file.Files;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    30
import java.nio.file.Path;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    31
import java.nio.file.Paths;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    32
import java.time.Duration;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    33
import java.time.Instant;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    34
import java.time.LocalDateTime;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    35
import java.time.LocalTime;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    36
import java.time.ZoneOffset;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    37
import java.util.ArrayList;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    38
import java.util.Collections;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    39
import java.util.List;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    40
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    41
import jdk.jfr.Event;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    42
import jdk.jfr.Recording;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    43
import jdk.test.lib.Asserts;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    44
import jdk.test.lib.process.OutputAnalyzer;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    45
51214
67736b4846a0 8207830: [aix] disable jfr in build and tests
goetz
parents: 50873
diff changeset
    46
/**
50745
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    47
 * @test
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    48
 * @summary The test verifies JFR.dump command
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    49
 * @key jfr
51214
67736b4846a0 8207830: [aix] disable jfr in build and tests
goetz
parents: 50873
diff changeset
    50
 * @requires vm.hasJFR
50745
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    51
 * @library /test/lib /test/jdk
50873
ce53844224b6 8205906: jdk.jfr.jcmd.TestJcmdDumpLimited fails due to erronous processing of -XX:FlightRecorderOptions
mgronlun
parents: 50745
diff changeset
    52
 * @run main/othervm jdk.jfr.jcmd.TestJcmdDumpLimited
50745
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    53
 */
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    54
public class TestJcmdDumpLimited {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    55
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    56
    static class TestEvent extends Event {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    57
        int id;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    58
        int number;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    59
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    60
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    61
    static class TestRecording {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    62
        Instant time;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    63
        final Recording r;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    64
        Path path;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    65
        int size;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    66
        int total;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    67
        int id;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    68
        Instant now;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    69
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    70
        TestRecording(int id, int events) throws IOException, InterruptedException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    71
            r = new Recording();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    72
            r.start();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    73
            for (int i = 0; i < events; i++) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    74
                TestEvent event = new TestEvent();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    75
                event.id = id;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    76
                event.number = i;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    77
                event.commit();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    78
                if (i == events / 2) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    79
                    time = Instant.now();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    80
                }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    81
            }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    82
            r.stop();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    83
            Thread.sleep(1);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    84
            path = Paths.get("dump-" + id + ".jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    85
            r.dump(path);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    86
            size = (int) Files.size(path);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    87
            this.id = id;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    88
            this.now = Instant.now();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    89
        }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    90
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    91
        public void close() {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    92
            r.close();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    93
        }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    94
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    95
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    96
    private static long totalSize;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    97
    private static long lastFiveSize;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    98
    private static long firstFiveSize;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
    99
    private static long middleSize;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   100
    private static long centerSize;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   101
    private static long lastSize;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   102
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   103
    private static Instant middle;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   104
    private static Instant centerLeft;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   105
    private static Instant centerRight;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   106
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   107
    public static void main(String[] args) throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   108
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   109
        List<TestRecording> recs = new ArrayList<>();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   110
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   111
        for (int i = 0; i < 9; i++) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   112
            recs.add(new TestRecording(i, 100));
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   113
        }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   114
        int last = 0;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   115
        List<TestRecording> reversed = new ArrayList<>(recs);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   116
        Collections.reverse(reversed);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   117
        for (TestRecording r : reversed) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   118
            r.total = r.size + last;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   119
            last += r.size;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   120
        }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   121
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   122
        for (TestRecording r : recs) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   123
            System.out.println("Recording " + r.id + ": size=" + r.size + " (total=" + r.total + ", time=" + r.now + ")");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   124
        }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   125
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   126
        centerLeft = recs.get(3).time;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   127
        middle = recs.get(4).time;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   128
        centerRight = recs.get(5).time;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   129
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   130
        totalSize = size(recs, 0, 9);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   131
        lastFiveSize = size(recs, 4, 5);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   132
        firstFiveSize = size(recs, 0, 5);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   133
        middleSize = size(recs, 4, 1);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   134
        centerSize = size(recs, 3, 3);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   135
        lastSize =  size(recs, 8, 1);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   136
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   137
        testDump();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   138
        testDumpMaxSize();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   139
        testDumpMaxSizeSmall();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   140
        testDumpBegin();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   141
        testDumpEnd();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   142
        testDumpBeginEndInstant();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   143
        testDumpBeginEndLocalDateTime();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   144
        testDumpBeginEndLocalTime();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   145
        testDumpBeginEndSame();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   146
        testDumpMaxAge();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   147
        testDumpBeginEndRelative();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   148
        testDumpTooEarly();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   149
        testDumpTooLate();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   150
        testDumpBeginMaxAge();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   151
        TestDumpEndMaxage();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   152
        testDumpEndBegin();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   153
        testDumpInvalidTime();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   154
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   155
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   156
    private static int size(List<TestRecording> recs, int skip, int limit) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   157
        return recs.stream().skip(skip).limit(limit).mapToInt(r -> r.size).sum();
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   158
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   159
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   160
    private static void testDumpEndBegin() throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   161
        Path testEndBegin = Paths.get("testEndBegin.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   162
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + testEndBegin.toFile().getAbsolutePath(), "begin=" + Instant.now(), "end=" + Instant.now().minusSeconds(200));
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   163
        output.shouldContain("Dump failed, begin must preceed end.");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   164
        assertMissingFile(testEndBegin);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   165
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   166
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   167
    private static void TestDumpEndMaxage() throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   168
        Path testEndMaxAge = Paths.get("testEndMaxAge.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   169
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + testEndMaxAge.toFile().getAbsolutePath(), "end=" + Instant.now(), "maxage=2h");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   170
        output.shouldContain("Dump failed, maxage can't be combined with begin or end.");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   171
        assertMissingFile(testEndMaxAge);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   172
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   173
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   174
    private static Path testDumpBeginMaxAge() throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   175
        Path testBeginMaxAge = Paths.get("testBeginMaxAge.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   176
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + testBeginMaxAge.toFile().getAbsolutePath(), "begin=" + Instant.now().minusSeconds(100), "maxage=2h");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   177
        output.shouldContain("Dump failed, maxage can't be combined with begin or end.");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   178
        assertMissingFile(testBeginMaxAge);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   179
        return testBeginMaxAge;
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   180
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   181
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   182
    private static void testDumpTooLate() throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   183
        Path missing = Paths.get("missing2.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   184
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + missing.toFile().getAbsolutePath(), "begin=" + Instant.now().plus(Duration.ofHours(1)),
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   185
                "end=" + Instant.now().plus(Duration.ofHours(2)));
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   186
        output.shouldContain("Dump failed. No data found in the specified interval.");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   187
        assertMissingFile(missing);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   188
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   189
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   190
    private static void testDumpTooEarly() throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   191
        Path missing = Paths.get("missing.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   192
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + missing.toFile().getAbsolutePath(), "end=" + Instant.now().minus(Duration.ofHours(1)));
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   193
        output.shouldContain("Dump failed. No data found in the specified interval.");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   194
        assertMissingFile(missing);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   195
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   196
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   197
    private static void testDumpBeginEndRelative() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   198
        Path testBeginEndRelative = Paths.get("testBeginEndRelative.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   199
        JcmdHelper.jcmd("JFR.dump", "filename=" + testBeginEndRelative.toFile().getAbsolutePath(), "begin=-3h", "end=-0s");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   200
        Asserts.assertEquals(totalSize, Files.size(testBeginEndRelative), "Expected dump with begin=-3h end=0s to contain data from all recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   201
        Files.delete(testBeginEndRelative);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   202
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   203
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   204
    private static void testDumpMaxAge() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   205
        Path testMaxAge = Paths.get("testMaxAge.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   206
        JcmdHelper.jcmd("JFR.dump", "filename=" + testMaxAge.toFile().getAbsolutePath(), "maxage=2h");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   207
        Asserts.assertEquals(totalSize, Files.size(testMaxAge), "Expected dump with maxage=2h  to contain data from all recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   208
        Files.delete(testMaxAge);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   209
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   210
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   211
    private static void testDumpBeginEndSame() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   212
        Path testBeginEnd = Paths.get("testBeginEndSame.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   213
        JcmdHelper.jcmd("JFR.dump", "filename=" + testBeginEnd.toFile().getAbsolutePath(), "begin=" + middle, "end=" + middle);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   214
        Asserts.assertEquals(middleSize, Files.size(testBeginEnd), "Expected dump with begin=" + middle + "end=" + middle + " contain data from middle recording");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   215
        Files.delete(testBeginEnd);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   216
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   217
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   218
    private static void testDumpBeginEndInstant() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   219
        Path testBeginEnd = Paths.get("testBeginEndInstant.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   220
        JcmdHelper.jcmd("JFR.dump", "filename=" + testBeginEnd.toFile().getAbsolutePath(), "begin=" + centerLeft, "end=" + centerRight);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   221
        Asserts.assertEquals(centerSize, Files.size(testBeginEnd), "Expected dump with begin=" + centerLeft + " end=" + centerRight + " contain data from the 'center'-recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   222
        Files.delete(testBeginEnd);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   223
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   224
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   225
    private static void testDumpBeginEndLocalDateTime() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   226
        LocalDateTime centerLeftLocal = LocalDateTime.ofInstant(centerLeft, ZoneOffset.systemDefault());
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   227
        LocalDateTime centerRightLocal = LocalDateTime.ofInstant(centerRight, ZoneOffset.systemDefault());
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   228
        Path testBeginEnd = Paths.get("testBeginEndLocalDateTime.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   229
        JcmdHelper.jcmd("JFR.dump", "filename=" + testBeginEnd.toFile().getAbsolutePath(), "begin=" + centerLeftLocal, "end=" + centerRightLocal);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   230
        Asserts.assertEquals(centerSize, Files.size(testBeginEnd), "Expected dump with begin=" + centerLeftLocal + " end=" + centerRightLocal + " contain data from the 'center'-recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   231
        Files.delete(testBeginEnd);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   232
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   233
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   234
    private static void testDumpBeginEndLocalTime() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   235
        LocalTime centerLeftLocal = LocalTime.ofInstant(centerLeft, ZoneOffset.systemDefault());
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   236
        LocalTime centerRightLocal = LocalTime.ofInstant(centerRight, ZoneOffset.systemDefault());
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   237
        Path testBeginEnd = Paths.get("testBeginEndLocalTime.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   238
        JcmdHelper.jcmd("JFR.dump", "filename=" + testBeginEnd.toFile().getAbsolutePath(), "begin=" + centerLeftLocal, "end=" + centerRightLocal);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   239
        Asserts.assertEquals(centerSize, Files.size(testBeginEnd), "Expected dump with begin=" + centerLeftLocal + " end=" + centerRightLocal + " contain data from the 'center'-recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   240
        Files.delete(testBeginEnd);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   241
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   242
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   243
    private static void testDumpEnd() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   244
        Path testEnd = Paths.get("testEnd.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   245
        JcmdHelper.jcmd("JFR.dump", "filename=" + testEnd.toFile().getAbsolutePath(), "end=" + middle);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   246
        Asserts.assertEquals(firstFiveSize, Files.size(testEnd), "Expected dump with end=" + middle + " to contain data from the five first recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   247
        Files.delete(testEnd);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   248
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   249
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   250
    private static void testDumpBegin() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   251
        Path testBegin = Paths.get("testBegin.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   252
        JcmdHelper.jcmd("JFR.dump", "filename=" + testBegin.toFile().getAbsolutePath(), "begin=" + middle);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   253
        Asserts.assertEquals(lastFiveSize, Files.size(testBegin), "Expected dump with begin=" + middle + " to contain data from the last five recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   254
        Files.delete(testBegin);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   255
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   256
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   257
    private static void testDumpMaxSize() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   258
        Path testMaxSize = Paths.get("testMaxSize.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   259
        JcmdHelper.jcmd("JFR.dump", "filename=" + testMaxSize.toFile().getAbsolutePath(), "maxsize=" + lastFiveSize);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   260
        Asserts.assertEquals(lastFiveSize, Files.size(testMaxSize), "Expected dump with maxsize=" + lastFiveSize + " to contain data from the last five recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   261
        Files.delete(testMaxSize);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   262
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   263
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   264
    private static void testDumpMaxSizeSmall() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   265
        Path testMaxSizeSmall = Paths.get("testMaxSizeSmall.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   266
        JcmdHelper.jcmd("JFR.dump", "filename=" + testMaxSizeSmall.toFile().getAbsolutePath(), "maxsize=1k");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   267
        Asserts.assertEquals(lastSize, Files.size(testMaxSizeSmall), "Expected dump with maxsize=1k to contain data from the last recording");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   268
        Files.delete(testMaxSizeSmall);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   269
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   270
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   271
    private static void testDump() throws IOException {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   272
        Path all = Paths.get("all.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   273
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + all.toFile().getAbsolutePath());
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   274
        JcmdAsserts.assertRecordingDumpedToFile(output, all.toFile());
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   275
        Asserts.assertEquals(totalSize, Files.size(all), "Expected dump to be sum of all recordings");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   276
        Files.delete(all);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   277
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   278
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   279
    private static void testDumpInvalidTime() throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   280
        Path invalidTime = Paths.get("invalidTime.jfr");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   281
        OutputAnalyzer output = JcmdHelper.jcmd("JFR.dump", "filename=" + invalidTime.toFile().getAbsolutePath(), "begin=4711");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   282
        output.shouldContain("Dump failed, not a valid begin time.");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   283
        assertMissingFile(invalidTime);
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   284
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   285
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   286
    private static void assertMissingFile(Path missing) throws Exception {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   287
        if (Files.exists(missing)) {
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   288
            throw new Exception("Unexpected dumpfile found");
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   289
        }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   290
    }
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   291
a390cbb82d47 8203929: Limit amount of data for JFR.dump
egahlin
parents:
diff changeset
   292
}