hotspot/test/gc/arguments/TestParallelGCThreads.java
author lana
Thu, 12 May 2016 15:15:02 +0000
changeset 37915 be4ff50b6cb6
parent 36851 03e2f4d0a421
child 40631 ed82623d7831
permissions -rw-r--r--
Added tag jdk-9+118 for changeset cc643de7cb06
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     1
/*
29678
dd2f3932c21e 8075586: Add @modules as needed to the open hotspot tests
ykantser
parents: 26939
diff changeset
     2
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     4
*
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     5
* This code is free software; you can redistribute it and/or modify it
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     6
* under the terms of the GNU General Public License version 2 only, as
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     7
* published by the Free Software Foundation.
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     8
*
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
     9
* This code is distributed in the hope that it will be useful, but WITHOUT
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    11
* FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    12
* version 2 for more details (a copy is included in the LICENSE file that
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    13
* accompanied this code).
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    14
*
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    15
* You should have received a copy of the GNU General Public License version
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    16
* 2 along with this work; if not, write to the Free Software Foundation,
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    18
*
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    20
* or visit www.oracle.com if you need additional information or have any
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    21
* questions.
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    22
*/
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    23
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    24
/*
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    25
 * @test TestParallelGCThreads
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    26
 * @key gc
31330
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    27
 * @bug 8059527 8081382
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    28
 * @summary Tests argument processing for ParallelGCThreads
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    29
 * @library /testlibrary
36851
03e2f4d0a421 8153737: Unsupported Module
chegar
parents: 31330
diff changeset
    30
 * @modules java.base/jdk.internal.misc
29678
dd2f3932c21e 8075586: Add @modules as needed to the open hotspot tests
ykantser
parents: 26939
diff changeset
    31
 *          java.management
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    32
 * @run driver TestParallelGCThreads
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    33
 */
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    34
30604
b8d532cb6420 8067013: Rename the com.oracle.java.testlibary package
ykantser
parents: 29678
diff changeset
    35
import jdk.test.lib.*;
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    36
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    37
public class TestParallelGCThreads {
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    38
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    39
  public static void main(String args[]) throws Exception {
31330
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    40
    testFlags();
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    41
    testDefaultValue();
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    42
  }
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    43
31330
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    44
  private static final String flagName = "ParallelGCThreads";
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    45
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    46
  // uint ParallelGCThreads = 23 {product}
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    47
  private static final String printFlagsFinalPattern = " *uint *" + flagName + " *:?= *(\\d+) *\\{product\\} *";
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    48
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    49
  public static void testDefaultValue()  throws Exception {
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    50
    ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    51
      "-XX:+UnlockExperimentalVMOptions", "-XX:+PrintFlagsFinal", "-version");
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    52
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    53
    OutputAnalyzer output = new OutputAnalyzer(pb.start());
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    54
    String value = output.firstMatch(printFlagsFinalPattern, 1);
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    55
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    56
    try {
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    57
      Asserts.assertNotNull(value, "Couldn't find uint flag " + flagName);
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    58
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    59
      Long longValue = new Long(value);
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    60
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    61
      // Sanity check that we got a non-zero value.
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    62
      Asserts.assertNotEquals(longValue, "0");
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    63
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    64
      output.shouldHaveExitValue(0);
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    65
    } catch (Exception e) {
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    66
      System.err.println(output.getOutput());
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    67
      throw e;
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    68
    }
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    69
  }
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    70
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    71
  public static void testFlags() throws Exception {
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    72
    // For each parallel collector (G1, Parallel, ParNew/CMS)
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    73
    for (String gc : new String[] {"G1", "Parallel", "ConcMarkSweep"}) {
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    74
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    75
      // Make sure the VM does not allow ParallelGCThreads set to 0
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    76
      String[] flags = new String[] {"-XX:+Use" + gc + "GC", "-XX:ParallelGCThreads=0", "-XX:+PrintFlagsFinal", "-version"};
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    77
      ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(flags);
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    78
      OutputAnalyzer output = new OutputAnalyzer(pb.start());
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    79
      output.shouldHaveExitValue(1);
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    80
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    81
      // Do some basic testing to ensure the flag updates the count
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    82
      for (long i = 1; i <= 3; i++) {
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    83
        flags = new String[] {"-XX:+Use" + gc + "GC", "-XX:ParallelGCThreads=" + i, "-XX:+PrintFlagsFinal", "-version"};
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    84
        long count = getParallelGCThreadCount(flags);
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    85
        Asserts.assertEQ(count, i, "Specifying ParallelGCThreads=" + i + " for " + gc + "GC does not set the thread count properly!");
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    86
      }
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    87
    }
31330
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    88
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    89
    // 4294967295 == (unsigned int) -1
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    90
    // So setting ParallelGCThreads=4294967295 should give back 4294967295
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    91
    // and setting ParallelGCThreads=4294967296 should give back 0. (SerialGC is ok with ParallelGCThreads=0)
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    92
    for (long i = 4294967295L; i <= 4294967296L; i++) {
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    93
      String[] flags = new String[] {"-XX:+UseSerialGC", "-XX:ParallelGCThreads=" + i, "-XX:+PrintFlagsFinal", "-version"};
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    94
      long count = getParallelGCThreadCount(flags);
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    95
      Asserts.assertEQ(count, i % 4294967296L, "Specifying ParallelGCThreads=" + i + " does not set the thread count properly!");
77061bb01b18 8081382: Make flags ParallelGCThreads and ConcGCThreads of type uint
david
parents: 30604
diff changeset
    96
    }
26939
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    97
  }
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    98
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
    99
  public static long getParallelGCThreadCount(String flags[]) throws Exception {
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   100
    ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(flags);
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   101
    OutputAnalyzer output = new OutputAnalyzer(pb.start());
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   102
    output.shouldHaveExitValue(0);
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   103
    String stdout = output.getStdout();
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   104
    return FlagsValue.getFlagLongValue("ParallelGCThreads", stdout);
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   105
  }
93633340028d 8059527: Disallow ParallelGCThreads=0 for G1
mlarsson
parents:
diff changeset
   106
}