2014-04-25 17:19:49 +02:00
|
|
|
/*
|
2018-08-27 21:50:52 -07:00
|
|
|
* Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved.
|
2014-04-25 17:19:49 +02:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import com.sun.tools.attach.*;
|
|
|
|
|
|
|
|
import java.nio.file.Files;
|
|
|
|
import java.nio.file.Path;
|
|
|
|
import java.util.Properties;
|
|
|
|
import java.util.List;
|
|
|
|
import java.io.File;
|
|
|
|
|
2018-08-27 21:50:52 -07:00
|
|
|
import jdk.test.lib.thread.ProcessThread;
|
2018-09-07 14:01:52 -07:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
|
|
|
import jdk.test.lib.process.ProcessTools;
|
2014-04-25 17:19:49 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @test
|
|
|
|
* @bug 8033104
|
|
|
|
* @summary Test to make sure attach and jvmstat works correctly when java.io.tmpdir is set
|
2017-03-15 22:48:59 -07:00
|
|
|
*
|
2018-08-27 21:50:52 -07:00
|
|
|
* @library /test/lib
|
2017-03-15 22:48:59 -07:00
|
|
|
* @modules jdk.attach
|
2015-05-07 09:11:49 +02:00
|
|
|
* jdk.jartool/sun.tools.jar
|
2017-03-15 22:48:59 -07:00
|
|
|
*
|
2018-11-29 07:40:45 +08:00
|
|
|
* @run build Application RunnerUtil
|
2014-06-23 15:51:41 +02:00
|
|
|
* @run main/timeout=200 TempDirTest
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This test runs with an extra long timeout since it takes a really long time with -Xcomp
|
|
|
|
* when starting many processes.
|
2014-04-25 17:19:49 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
public class TempDirTest {
|
|
|
|
|
2014-06-23 15:51:41 +02:00
|
|
|
private static long startTime;
|
|
|
|
|
2014-04-25 17:19:49 +02:00
|
|
|
public static void main(String args[]) throws Throwable {
|
|
|
|
|
2014-06-23 15:51:41 +02:00
|
|
|
startTime = System.currentTimeMillis();
|
|
|
|
|
2014-04-25 17:19:49 +02:00
|
|
|
Path clientTmpDir = Files.createTempDirectory("TempDirTest-client");
|
|
|
|
clientTmpDir.toFile().deleteOnExit();
|
|
|
|
Path targetTmpDir = Files.createTempDirectory("TempDirTest-target");
|
|
|
|
targetTmpDir.toFile().deleteOnExit();
|
|
|
|
|
|
|
|
// run the test with all possible combinations of setting java.io.tmpdir
|
|
|
|
runExperiment(null, null);
|
|
|
|
runExperiment(clientTmpDir, null);
|
|
|
|
runExperiment(clientTmpDir, targetTmpDir);
|
|
|
|
runExperiment(null, targetTmpDir);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
private static int counter = 0;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The actual test is in the nested class TestMain.
|
|
|
|
* The responsibility of this class is to:
|
|
|
|
* 1. Start the Application class in a separate process.
|
|
|
|
* 2. Find the pid and shutdown port of the running Application.
|
|
|
|
* 3. Launches the tests in nested class TestMain that will attach to the Application.
|
|
|
|
* 4. Shut down the Application.
|
|
|
|
*/
|
|
|
|
public static void runExperiment(Path clientTmpDir, Path targetTmpDir) throws Throwable {
|
|
|
|
|
|
|
|
System.out.print("### Running tests with overridden tmpdir for");
|
|
|
|
System.out.print(" client: " + (clientTmpDir == null ? "no" : "yes"));
|
|
|
|
System.out.print(" target: " + (targetTmpDir == null ? "no" : "yes"));
|
|
|
|
System.out.println(" ###");
|
|
|
|
|
2014-06-23 15:51:41 +02:00
|
|
|
long elapsedTime = (System.currentTimeMillis() - startTime) / 1000;
|
|
|
|
System.out.println("Started after " + elapsedTime + "s");
|
|
|
|
|
2014-04-25 17:19:49 +02:00
|
|
|
final String pidFile = "TempDirTest.Application.pid-" + counter++;
|
|
|
|
ProcessThread processThread = null;
|
|
|
|
try {
|
|
|
|
String[] tmpDirArg = null;
|
|
|
|
if (targetTmpDir != null) {
|
|
|
|
tmpDirArg = new String[] {"-Djava.io.tmpdir=" + targetTmpDir};
|
|
|
|
}
|
2014-07-01 15:00:33 +02:00
|
|
|
processThread = RunnerUtil.startApplication(tmpDirArg);
|
|
|
|
launchTests(processThread.getPid(), clientTmpDir);
|
2014-04-25 17:19:49 +02:00
|
|
|
} catch (Throwable t) {
|
|
|
|
System.out.println("TempDirTest got unexpected exception: " + t);
|
|
|
|
t.printStackTrace();
|
|
|
|
throw t;
|
|
|
|
} finally {
|
|
|
|
// Make sure the Application process is stopped.
|
2014-07-01 15:00:33 +02:00
|
|
|
RunnerUtil.stopApplication(processThread);
|
2014-04-25 17:19:49 +02:00
|
|
|
}
|
2014-06-23 15:51:41 +02:00
|
|
|
|
|
|
|
elapsedTime = (System.currentTimeMillis() - startTime) / 1000;
|
|
|
|
System.out.println("Completed after " + elapsedTime + "s");
|
|
|
|
|
2014-04-25 17:19:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs the actual tests in nested class TestMain.
|
|
|
|
* The reason for running the tests in a separate process
|
|
|
|
* is that we need to modify the class path and
|
|
|
|
* the -Djava.io.tmpdir property.
|
|
|
|
*/
|
2014-07-01 15:00:33 +02:00
|
|
|
private static void launchTests(long pid, Path clientTmpDir) throws Throwable {
|
2014-04-25 17:19:49 +02:00
|
|
|
final String sep = File.separator;
|
|
|
|
|
|
|
|
String classpath =
|
2015-01-23 14:20:52 +01:00
|
|
|
System.getProperty("test.class.path", "");
|
2014-04-25 17:19:49 +02:00
|
|
|
|
|
|
|
String[] tmpDirArg = null;
|
|
|
|
if (clientTmpDir != null) {
|
|
|
|
tmpDirArg = new String [] {"-Djava.io.tmpdir=" + clientTmpDir};
|
|
|
|
}
|
|
|
|
|
|
|
|
// Arguments : [-Djava.io.tmpdir=] -classpath cp TempDirTest$TestMain pid
|
|
|
|
String[] args = RunnerUtil.concat(
|
|
|
|
tmpDirArg,
|
|
|
|
new String[] {
|
|
|
|
"-classpath",
|
|
|
|
classpath,
|
|
|
|
"TempDirTest$TestMain",
|
2014-07-01 15:00:33 +02:00
|
|
|
Long.toString(pid) });
|
2014-04-25 17:19:49 +02:00
|
|
|
OutputAnalyzer output = ProcessTools.executeTestJvm(args);
|
|
|
|
output.shouldHaveExitValue(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This is the actual test. It will attach to the running Application
|
|
|
|
* and perform a number of basic attach tests.
|
|
|
|
*/
|
|
|
|
public static class TestMain {
|
|
|
|
public static void main(String args[]) throws Exception {
|
|
|
|
String pid = args[0];
|
|
|
|
|
|
|
|
// Test 1 - list method should list the target VM
|
|
|
|
System.out.println(" - Test: VirtualMachine.list");
|
|
|
|
List<VirtualMachineDescriptor> l = VirtualMachine.list();
|
|
|
|
boolean found = false;
|
|
|
|
for (VirtualMachineDescriptor vmd: l) {
|
|
|
|
if (vmd.id().equals(pid)) {
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (found) {
|
|
|
|
System.out.println(" - " + pid + " found.");
|
|
|
|
} else {
|
|
|
|
throw new RuntimeException(pid + " not found in VM list");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test 2 - try to attach and verify connection
|
|
|
|
|
|
|
|
System.out.println(" - Attaching to application ...");
|
|
|
|
VirtualMachine vm = VirtualMachine.attach(pid);
|
|
|
|
|
|
|
|
System.out.println(" - Test: system properties in target VM");
|
|
|
|
Properties props = vm.getSystemProperties();
|
|
|
|
String value = props.getProperty("attach.test");
|
|
|
|
if (value == null || !value.equals("true")) {
|
|
|
|
throw new RuntimeException("attach.test property not set");
|
|
|
|
}
|
|
|
|
System.out.println(" - attach.test property set as expected");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|