hotspot/test/gc/g1/plab/TestPLABResize.java
author mchernov
Fri, 27 May 2016 17:48:56 +0300
changeset 38726 2c99beca1dd8
parent 38152 80e5da81fb2c
child 39294 4be906c4ad95
permissions -rw-r--r--
8157452: [TESTBUG] PLAB tests don't handle unexpected GC Reviewed-by: dfazunen, tschatzl
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     1
/*
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     2
 * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     4
 *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     7
 * published by the Free Software Foundation.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     8
 *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    13
 * accompanied this code).
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    14
 *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    18
 *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    21
 * questions.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    22
 */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    23
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    24
 /*
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    25
 * @test TestPLABResize
36390
a2d991d1d628 8141141: Young and Old gen PLAB stats are similar in output with -XX:+PrintPLAB
tschatzl
parents: 36205
diff changeset
    26
 * @bug 8141278 8141141
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    27
 * @summary Test for PLAB resizing
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    28
 * @requires vm.gc=="G1" | vm.gc=="null"
35947
48c797584ac2 8148745: [testbug] Test gc/g1/plab/TestPLABPromotion.java fails in nightly
mchernov
parents: 35885
diff changeset
    29
 * @requires vm.opt.FlightRecorder != true
36616
chegar
parents: 36390
diff changeset
    30
 * @library /testlibrary /test/lib /
38152
80e5da81fb2c 8154258: [TESTBUG] Various serviceability tests fail compilation
dsamersoff
parents: 37181
diff changeset
    31
 * @modules java.base/jdk.internal.misc
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    32
 * @modules java.management
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    33
 * @build ClassFileInstaller
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    34
 *        sun.hotspot.WhiteBox
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    35
 *        gc.g1.plab.lib.LogParser
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    36
 *        gc.g1.plab.lib.MemoryConsumer
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    37
 *        gc.g1.plab.lib.PLABUtils
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    38
 *        gc.g1.plab.lib.AppPLABResize
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    39
 * @run main ClassFileInstaller sun.hotspot.WhiteBox
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    40
 *                              sun.hotspot.WhiteBox$WhiteBoxPermission
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    41
 * @run main gc.g1.plab.TestPLABResize
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    42
 */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    43
package gc.g1.plab;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    44
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    45
import java.util.Arrays;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    46
import java.util.List;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    47
import java.util.stream.Collectors;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    48
import java.io.PrintStream;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    49
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    50
import gc.g1.plab.lib.LogParser;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    51
import gc.g1.plab.lib.PLABUtils;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    52
import gc.g1.plab.lib.AppPLABResize;
37181
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
    53
import gc.g1.plab.lib.PlabReport;
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    54
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    55
import jdk.test.lib.OutputAnalyzer;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    56
import jdk.test.lib.ProcessTools;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    57
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    58
/**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    59
 * Test for PLAB resizing.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    60
 */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    61
public class TestPLABResize {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    62
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    63
    private static final int OBJECT_SIZE_SMALL = 10;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    64
    private static final int OBJECT_SIZE_MEDIUM = 70;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    65
    private static final int OBJECT_SIZE_HIGH = 150;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    66
    private static final int GC_NUM_SMALL = 1;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    67
    private static final int GC_NUM_MEDIUM = 3;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    68
    private static final int GC_NUM_HIGH = 7;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    69
    private static final int WASTE_PCT_SMALL = 10;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    70
    private static final int WASTE_PCT_MEDIUM = 20;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    71
    private static final int WASTE_PCT_HIGH = 30;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    72
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    73
    private static final int ITERATIONS_SMALL = 3;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    74
    private static final int ITERATIONS_MEDIUM = 5;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    75
    private static final int ITERATIONS_HIGH = 8;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    76
37181
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
    77
    private static final String PLAB_SIZE_FIELD_NAME = "actual";
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
    78
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    79
    private final static TestCase[] TEST_CASES = {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    80
        new TestCase(WASTE_PCT_SMALL, OBJECT_SIZE_SMALL, GC_NUM_SMALL, ITERATIONS_MEDIUM),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    81
        new TestCase(WASTE_PCT_SMALL, OBJECT_SIZE_MEDIUM, GC_NUM_HIGH, ITERATIONS_SMALL),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    82
        new TestCase(WASTE_PCT_SMALL, OBJECT_SIZE_HIGH, GC_NUM_MEDIUM, ITERATIONS_HIGH),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    83
        new TestCase(WASTE_PCT_MEDIUM, OBJECT_SIZE_SMALL, GC_NUM_HIGH, ITERATIONS_MEDIUM),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    84
        new TestCase(WASTE_PCT_MEDIUM, OBJECT_SIZE_MEDIUM, GC_NUM_SMALL, ITERATIONS_SMALL),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    85
        new TestCase(WASTE_PCT_MEDIUM, OBJECT_SIZE_HIGH, GC_NUM_MEDIUM, ITERATIONS_HIGH),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    86
        new TestCase(WASTE_PCT_HIGH, OBJECT_SIZE_SMALL, GC_NUM_HIGH, ITERATIONS_MEDIUM),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    87
        new TestCase(WASTE_PCT_HIGH, OBJECT_SIZE_MEDIUM, GC_NUM_SMALL, ITERATIONS_SMALL),
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    88
        new TestCase(WASTE_PCT_HIGH, OBJECT_SIZE_HIGH, GC_NUM_MEDIUM, ITERATIONS_HIGH)
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    89
    };
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    90
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    91
    public static void main(String[] args) throws Throwable {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    92
        for (TestCase testCase : TEST_CASES) {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    93
            testCase.print(System.out);
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    94
            List<String> options = PLABUtils.prepareOptions(testCase.toOptions());
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    95
            options.add(AppPLABResize.class.getName());
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    96
            OutputAnalyzer out = ProcessTools.executeTestJvm(options.toArray(new String[options.size()]));
38726
2c99beca1dd8 8157452: [TESTBUG] PLAB tests don't handle unexpected GC
mchernov
parents: 38152
diff changeset
    97
            PLABUtils.commonCheck(out);
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    98
            checkResults(out.getOutput(), testCase);
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
    99
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   100
    }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   101
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   102
    /**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   103
     * Checks testing results.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   104
     * Expected results - desired PLAB size is decreased and increased during promotion to Survivor.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   105
     *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   106
     * @param output - VM output
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   107
     * @param testCase
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   108
     */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   109
    private static void checkResults(String output, TestCase testCase) {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   110
        final LogParser log = new LogParser(output);
37181
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   111
        final PlabReport report = log.getEntries();
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   112
37181
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   113
        final List<Long> plabSizes = report.entryStream()
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   114
                .map(item -> item.getValue()
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   115
                        .get(LogParser.ReportType.SURVIVOR_STATS)
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   116
                        .get(PLAB_SIZE_FIELD_NAME)
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   117
                )
0d5e8ae18924 8149662: Refactor hotspot/test/gc/g1/plab/lib/LogParser.java
mchernov
parents: 37163
diff changeset
   118
                .collect(Collectors.toList());
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   119
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   120
        // Check that desired plab size was changed during iterations.
37061
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   121
        // The test case does 3 rounds of allocations.  The second round of N allocations and GC's
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   122
        // has a decreasing size of allocations so that iterations N to 2*N -1 will be of decreasing size.
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   123
        // The third round with iterations 2*N to 3*N -1 has increasing sizes of allocation.
38726
2c99beca1dd8 8157452: [TESTBUG] PLAB tests don't handle unexpected GC
mchernov
parents: 38152
diff changeset
   124
        if ( plabSizes.size() != testCase.iterations * 3 ) {
2c99beca1dd8 8157452: [TESTBUG] PLAB tests don't handle unexpected GC
mchernov
parents: 38152
diff changeset
   125
            System.out.println(output);
2c99beca1dd8 8157452: [TESTBUG] PLAB tests don't handle unexpected GC
mchernov
parents: 38152
diff changeset
   126
            throw new RuntimeException ("Expects for " + testCase.iterations * 3 + " PLAB entries in log, found " + plabSizes.size());
2c99beca1dd8 8157452: [TESTBUG] PLAB tests don't handle unexpected GC
mchernov
parents: 38152
diff changeset
   127
        }
2c99beca1dd8 8157452: [TESTBUG] PLAB tests don't handle unexpected GC
mchernov
parents: 38152
diff changeset
   128
37061
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   129
        long startDesiredPLABSize = plabSizes.get(testCase.getIterations());
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   130
        long endDesiredPLABSize = plabSizes.get(testCase.getIterations() * 2 - 1);
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   131
37061
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   132
        if (startDesiredPLABSize < endDesiredPLABSize) {
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   133
            System.out.println(output);
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   134
            throw new RuntimeException("Test failed! Expect that initial PLAB size should be greater than checked. Initial size: " + startDesiredPLABSize + " Checked size:" + endDesiredPLABSize);
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   135
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   136
37061
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   137
        startDesiredPLABSize = plabSizes.get(testCase.getIterations() * 2);
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   138
        endDesiredPLABSize = plabSizes.get(testCase.getIterations() * 3 - 1);
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   139
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   140
        if (startDesiredPLABSize > endDesiredPLABSize) {
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   141
            System.out.println(output);
f4f1c40edfd9 8150183: gc/g1/plab/TestPLABResize.java - previous PLAB size should be less than current
mchernov
parents: 36616
diff changeset
   142
            throw new RuntimeException("Test failed! Expect that initial PLAB size should be less than checked. Initial size: " + startDesiredPLABSize + " Checked size:" + endDesiredPLABSize);
35885
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   143
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   144
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   145
        System.out.println("Test passed!");
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   146
    }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   147
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   148
    /**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   149
     * Description of one test case.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   150
     */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   151
    private static class TestCase {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   152
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   153
        private final int wastePct;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   154
        private final int chunkSize;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   155
        private final int parGCThreads;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   156
        private final int iterations;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   157
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   158
        /**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   159
         * @param wastePct
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   160
         * ParallelGCBufferWastePct
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   161
         * @param chunkSize
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   162
         * requested object size for memory consumption
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   163
         * @param parGCThreads
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   164
         * -XX:ParallelGCThreads
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   165
         * @param iterations
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   166
         *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   167
         */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   168
        public TestCase(int wastePct,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   169
                int chunkSize,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   170
                int parGCThreads,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   171
                int iterations
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   172
        ) {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   173
            if (wastePct == 0 || chunkSize == 0 || parGCThreads == 0 || iterations == 0) {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   174
                throw new IllegalArgumentException("Parameters should not be 0");
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   175
            }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   176
            this.wastePct = wastePct;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   177
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   178
            this.chunkSize = chunkSize;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   179
            this.parGCThreads = parGCThreads;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   180
            this.iterations = iterations;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   181
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   182
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   183
        /**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   184
         * Convert current TestCase to List of options.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   185
         *
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   186
         * @return
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   187
         * List of options
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   188
         */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   189
        public List<String> toOptions() {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   190
            return Arrays.asList("-XX:ParallelGCThreads=" + parGCThreads,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   191
                    "-XX:ParallelGCBufferWastePct=" + wastePct,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   192
                    "-XX:+ResizePLAB",
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   193
                    "-Dchunk.size=" + chunkSize,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   194
                    "-Diterations=" + iterations,
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   195
                    "-XX:NewSize=16m",
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   196
                    "-XX:MaxNewSize=16m"
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   197
            );
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   198
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   199
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   200
        /**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   201
         * Print details about test case.
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   202
         */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   203
        public void print(PrintStream out) {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   204
            out.println("Test case details:");
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   205
            out.println("  Parallel GC buffer waste pct : " + wastePct);
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   206
            out.println("  Chunk size : " + chunkSize);
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   207
            out.println("  Parallel GC threads : " + parGCThreads);
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   208
            out.println("  Iterations: " + iterations);
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   209
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   210
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   211
        /**
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   212
         * @return iterations
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   213
         */
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   214
        public int getIterations() {
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   215
            return iterations;
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   216
        }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   217
    }
6e62be7db2c8 8141278: New tests for PLAB testing
mchernov
parents:
diff changeset
   218
}