From 0ac9a94c4ddb5f0edf60ec21d1fd27a2b269f00a Mon Sep 17 00:00:00 2001 From: Sharath Ballal Date: Thu, 30 Nov 2017 19:46:20 +0530 Subject: [PATCH] 8191658: SA: Testcases for attach, detach, reattach and Jhisto commands Reviewed-by: sspitsyn, jgeorge --- .../jtreg/serviceability/sa/ClhsdbAttach.java | 77 +++++++++++++++++++ .../jtreg/serviceability/sa/ClhsdbJhisto.java | 76 ++++++++++++++++++ .../serviceability/sa/ClhsdbLauncher.java | 6 +- 3 files changed, 157 insertions(+), 2 deletions(-) create mode 100644 test/hotspot/jtreg/serviceability/sa/ClhsdbAttach.java create mode 100644 test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbAttach.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbAttach.java new file mode 100644 index 00000000000..32095655640 --- /dev/null +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbAttach.java @@ -0,0 +1,77 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * 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 java.util.HashMap; +import java.util.List; +import java.util.Map; + +import jdk.test.lib.apps.LingeredApp; + +/* + * @test + * @bug 8191658 + * @summary Test clhsdb attach, detach, reattach commands + * @library /test/lib + * @run main/othervm ClhsdbAttach + */ + +public class ClhsdbAttach { + + public static void main(String[] args) throws Exception { + System.out.println("Starting ClhsdbAttach test"); + + LingeredApp theApp = null; + try { + ClhsdbLauncher test = new ClhsdbLauncher(); + theApp = LingeredApp.startApp(); + System.out.println("Started LingeredApp with pid " + theApp.getPid()); + String attach = "attach " + theApp.getPid(); + + List cmds = List.of( + "where", + attach, + "flags MaxJavaStackTraceDepth", + "detach", + "universe", + "reattach", + "longConstant markOopDesc::locked_value"); + + Map> expStrMap = new HashMap<>(); + expStrMap.put("where", List.of( + "Command not valid until attached to a VM")); + expStrMap.put("flags MaxJavaStackTraceDepth", List.of( + "MaxJavaStackTraceDepth = ")); + expStrMap.put("universe", List.of( + "Command not valid until attached to a VM")); + expStrMap.put("longConstant markOopDesc::locked_value", List.of( + "longConstant markOopDesc::locked_value")); + + test.run(-1, cmds, expStrMap, null); + } catch (Exception ex) { + throw new RuntimeException("Test ERROR " + ex, ex); + } finally { + LingeredApp.stopApp(theApp); + } + System.out.println("Test PASSED"); + } +} diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java new file mode 100644 index 00000000000..76e32a62479 --- /dev/null +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * 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 java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +import jdk.test.lib.apps.LingeredApp; +import jdk.test.lib.Utils; + +/* + * @test + * @bug 8191658 + * @summary Test clhsdb jhisto command + * @library /test/lib + * @run main/othervm ClhsdbJhisto + */ + +public class ClhsdbJhisto { + + public static void main(String[] args) throws Exception { + System.out.println("Starting ClhsdbJhisto test"); + + LingeredAppWithInterface theApp = null; + try { + ClhsdbLauncher test = new ClhsdbLauncher(); + List vmArgs = new ArrayList(); + vmArgs.addAll(Utils.getVmOptions()); + + theApp = new LingeredAppWithInterface(); + LingeredApp.startApp(vmArgs, theApp); + System.out.println("Started LingeredApp with pid " + theApp.getPid()); + + List cmds = List.of("jhisto"); + + Map> expStrMap = new HashMap<>(); + expStrMap.put("jhisto", List.of( + "java.lang.String", + "java.util.HashMap", + "java.lang.Class", + "java.nio.HeapByteBuffer", + "java.net.URI", + "LingeredAppWithInterface", + "ParselTongue", + "ImmutableCollections$SetN$1")); + + test.run(theApp.getPid(), cmds, expStrMap, null); + } catch (Exception ex) { + throw new RuntimeException("Test ERROR " + ex, ex); + } finally { + LingeredApp.stopApp(theApp); + } + System.out.println("Test PASSED"); + } +} diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbLauncher.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbLauncher.java index 5366be6f826..2d6ccfd3455 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbLauncher.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbLauncher.java @@ -53,10 +53,12 @@ public class ClhsdbLauncher { private void attach(long lingeredAppPid) throws IOException { - System.out.println("Starting clhsdb against " + lingeredAppPid); JDKToolLauncher launcher = JDKToolLauncher.createUsingTestJDK("jhsdb"); launcher.addToolArg("clhsdb"); - launcher.addToolArg("--pid=" + Long.toString(lingeredAppPid)); + if (lingeredAppPid != -1) { + launcher.addToolArg("--pid=" + Long.toString(lingeredAppPid)); + System.out.println("Starting clhsdb against " + lingeredAppPid); + } ProcessBuilder processBuilder = new ProcessBuilder(launcher.getCommand()); processBuilder.redirectError(ProcessBuilder.Redirect.INHERIT);