hotspot/test/serviceability/attach/AttachSetGetFlag.java
author stefank
Mon, 11 Aug 2014 14:03:06 +0200
changeset 25959 6c11a6272b60
child 29678 dd2f3932c21e
permissions -rw-r--r--
8054823: Add size_t as a valid VM flag type Reviewed-by: kvn, vlivanov, sla
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
25959
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     1
/*
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     2
 * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     4
 *
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     7
 * published by the Free Software Foundation.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     8
 *
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    13
 * accompanied this code).
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    14
 *
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    18
 *
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    21
 * questions.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    22
 */
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    23
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    24
/*
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    25
 * @test
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    26
 * @bug 8054823
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    27
 * @summary Tests the setFlag and printFlag attach command
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    28
 * @library /testlibrary
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    29
 * @build com.oracle.java.testlibrary.* AttachSetGetFlag
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    30
 * @run driver AttachSetGetFlag
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    31
 */
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    32
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    33
import java.io.BufferedReader;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    34
import java.io.InputStreamReader;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    35
import java.io.InputStream;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    36
import java.lang.reflect.Field;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    37
import java.nio.file.Files;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    38
import java.nio.file.Path;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    39
import java.nio.file.Paths;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    40
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    41
import sun.tools.attach.HotSpotVirtualMachine;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    42
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    43
import com.oracle.java.testlibrary.Asserts;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    44
import com.oracle.java.testlibrary.Platform;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    45
import com.oracle.java.testlibrary.ProcessTools;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    46
import com.sun.tools.attach.VirtualMachine;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    47
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    48
public class AttachSetGetFlag {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    49
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    50
  public static void main(String... args) throws Exception {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    51
    // Test a manageable uintx flag.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    52
    testGetFlag("MaxHeapFreeRatio", "60");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    53
    testSetFlag("MaxHeapFreeRatio", "50", "60");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    54
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    55
    // Test a non-manageable size_t flag.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    56
    // Since it is not manageable, we can't test the setFlag functionality.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    57
    testGetFlag("ArrayAllocatorMallocLimit", "128");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    58
    // testSetFlag("ArrayAllocatorMallocLimit", "64", "128");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    59
  }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    60
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    61
  public static ProcessBuilder runTarget(String flagName, String flagValue) throws Exception {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    62
    return ProcessTools.createJavaProcessBuilder(
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    63
        "-XX:+UnlockExperimentalVMOptions",
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    64
        "-XX:" + flagName + "=" + flagValue,
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    65
        "AttachSetGetFlag$Target");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    66
  }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    67
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    68
  public static void testGetFlag(String flagName, String flagValue) throws Exception {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    69
    ProcessBuilder pb = runTarget(flagName, flagValue);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    70
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    71
    Process target = pb.start();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    72
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    73
    try {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    74
      waitForReady(target);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    75
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    76
      int pid = (int)target.getPid();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    77
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    78
      HotSpotVirtualMachine vm = (HotSpotVirtualMachine)VirtualMachine.attach(((Integer)pid).toString());
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    79
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    80
      // Test Get
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    81
      BufferedReader remoteDataReader = new BufferedReader(new InputStreamReader(
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    82
          vm.printFlag(flagName)));
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    83
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    84
      boolean foundExpectedLine = false;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    85
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    86
      String line = null;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    87
      while((line = remoteDataReader.readLine()) != null) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    88
        System.out.println("printFlag: " + line);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    89
        if (line.equals("-XX:" + flagName + "=" + flagValue)) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    90
          foundExpectedLine = true;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    91
        }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    92
      }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    93
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    94
      Asserts.assertTrue(foundExpectedLine, "Didn't get the expected output: '-XX:" + flagName + "=" + flagValue + "'");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    95
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    96
      vm.detach();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    97
    }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    98
    finally {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
    99
      target.destroy();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   100
      target.waitFor();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   101
    }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   102
  }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   103
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   104
  public static void testSetFlag(String flagName, String initialFlagValue, String flagValue) throws Exception {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   105
    ProcessBuilder pb = runTarget(flagName, initialFlagValue);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   106
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   107
    Process target = pb.start();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   108
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   109
    try {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   110
      waitForReady(target);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   111
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   112
      int pid = (int)target.getPid();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   113
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   114
      HotSpotVirtualMachine vm = (HotSpotVirtualMachine)VirtualMachine.attach(((Integer)pid).toString());
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   115
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   116
      // First set the value.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   117
      BufferedReader remoteDataReader = new BufferedReader(new InputStreamReader(
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   118
          vm.setFlag(flagName, flagValue)));
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   119
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   120
      String line;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   121
      while((line = remoteDataReader.readLine()) != null) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   122
        System.out.println("setFlag: " + line);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   123
        // Just empty the stream.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   124
      }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   125
      remoteDataReader.close();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   126
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   127
      // Then read and make sure we get back the set value.
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   128
      remoteDataReader = new BufferedReader(new InputStreamReader(vm.printFlag(flagName)));
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   129
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   130
      boolean foundExpectedLine = false;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   131
      line = null;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   132
      while((line = remoteDataReader.readLine()) != null) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   133
        System.out.println("getFlag: " + line);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   134
        if (line.equals("-XX:" + flagName + "=" + flagValue)) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   135
          foundExpectedLine = true;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   136
        }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   137
      }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   138
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   139
      Asserts.assertTrue(foundExpectedLine, "Didn't get the expected output: '-XX:" + flagName + "=" + flagValue + "'");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   140
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   141
      vm.detach();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   142
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   143
    } finally {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   144
      target.destroy();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   145
      target.waitFor();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   146
    }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   147
  }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   148
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   149
  private static void waitForReady(Process target) throws Exception {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   150
    InputStream os = target.getInputStream();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   151
    try (BufferedReader reader = new BufferedReader(new InputStreamReader(os))) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   152
      String line;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   153
      while ((line = reader.readLine()) != null) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   154
        if ("Ready".equals(line)) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   155
          return;
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   156
        }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   157
      }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   158
    }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   159
  }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   160
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   161
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   162
  public static class Target {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   163
    public static void main(String [] args) throws Exception {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   164
      System.out.println("Ready");
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   165
      System.out.flush();
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   166
      while (true) {
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   167
        Thread.sleep(1000);
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   168
      }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   169
    }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   170
  }
6c11a6272b60 8054823: Add size_t as a valid VM flag type
stefank
parents:
diff changeset
   171
}