From c8e7590899ff42899509b9604d5f43d9f504dd48 Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Fri, 24 Jan 2020 10:31:45 +0100 Subject: [PATCH] 8237111: LingeredApp should be started with getTestJavaOpts Reviewed-by: cjplummer, dholmes --- test/hotspot/jtreg/ProblemList-zgc.txt | 11 ++- .../sa/ClhsdbRegionDetailsScanOopsForG1.java | 11 ++- .../sa/TestHeapDumpForLargeArray.java | 11 ++- .../serviceability/sa/CDSJMapClstats.java | 5 +- .../sa/ClhsdbCDSJstackPrintAll.java | 5 +- .../jtreg/serviceability/sa/ClhsdbFindPC.java | 7 +- .../jtreg/serviceability/sa/ClhsdbFlags.java | 35 +++++----- .../serviceability/sa/ClhsdbInspect.java | 4 +- .../jtreg/serviceability/sa/ClhsdbJhisto.java | 6 +- .../jtreg/serviceability/sa/ClhsdbJstack.java | 4 +- .../sa/ClhsdbJstackXcompStress.java | 11 +-- .../serviceability/sa/ClhsdbPrintAll.java | 4 +- .../serviceability/sa/ClhsdbScanOops.java | 6 +- .../sa/DeadlockDetectionTest.java | 8 +-- .../sa/JhsdbThreadInfoTest.java | 4 +- .../sa/TestClhsdbJstackLock.java | 6 +- .../sa/TestCpoolForInvokeDynamic.java | 9 ++- .../serviceability/sa/TestDefaultMethods.java | 8 +-- .../serviceability/sa/TestG1HeapRegion.java | 11 ++- .../sa/TestHeapDumpForInvokeDynamic.java | 11 ++- .../sa/TestInstanceKlassSize.java | 5 +- .../sa/TestInstanceKlassSizeForInterface.java | 3 +- .../serviceability/sa/TestIntConstant.java | 5 +- .../sa/TestJhsdbJstackLock.java | 6 +- .../sa/TestJhsdbJstackMixed.java | 11 ++- .../jtreg/serviceability/sa/TestPrintMdo.java | 7 +- .../sa/TestRevPtrsForInvokeDynamic.java | 8 +-- .../jtreg/serviceability/sa/TestType.java | 5 +- .../jtreg/serviceability/sa/TestUniverse.java | 4 +- .../attach/attach004/TestDriver.java | 6 +- test/jdk/com/sun/jdi/JdwpAllowTest.java | 15 ++-- test/jdk/com/sun/jdi/JdwpAttachTest.java | 6 +- .../MonitoredVm/TestPollingInterval.java | 6 +- .../bootstrap/AbstractFilePermissionTest.java | 5 +- .../bootstrap/LocalManagementTest.java | 5 +- .../bootstrap/RmiRegistrySslTest.java | 4 +- .../sun/tools/jhsdb/BasicLauncherTest.java | 6 +- test/jdk/sun/tools/jhsdb/HeapDumpTest.java | 4 +- .../jhsdb/heapconfig/JMapHeapConfigTest.java | 14 ++-- .../jhsdb/heapconfig/TmtoolTestScenario.java | 13 ++-- test/jdk/sun/tools/jinfo/JInfoTest.java | 15 ++-- test/jdk/sun/tools/jps/JpsHelper.java | 27 ++++---- test/jdk/sun/tools/jps/LingeredApp.java | 63 ++++++----------- test/jdk/sun/tools/jps/LingeredAppForJps.java | 6 +- test/jdk/sun/tools/jps/TestJps.java | 6 +- .../tools/jstack/DeadlockDetectionTest.java | 8 +-- .../jdk/test/lib/apps/LingeredAppTest.java | 4 +- test/lib/jdk/test/lib/Utils.java | 34 +++++++--- test/lib/jdk/test/lib/apps/LingeredApp.java | 68 ++++++++----------- 49 files changed, 248 insertions(+), 298 deletions(-) diff --git a/test/hotspot/jtreg/ProblemList-zgc.txt b/test/hotspot/jtreg/ProblemList-zgc.txt index 475bb1d87a1..8e59429c394 100644 --- a/test/hotspot/jtreg/ProblemList-zgc.txt +++ b/test/hotspot/jtreg/ProblemList-zgc.txt @@ -1,5 +1,5 @@ # -# Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2019, 2020, 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 @@ -27,15 +27,24 @@ # ############################################################################# +resourcehogs/serviceability/sa/TestHeapDumpForLargeArray.java 8220624 generic-all serviceability/sa/ClhsdbInspect.java 8220624 generic-all serviceability/sa/ClhsdbJdis.java 8220624 generic-all serviceability/sa/ClhsdbJhisto.java 8220624 generic-all serviceability/sa/ClhsdbJstack.java 8220624 generic-all serviceability/sa/ClhsdbPrintAs.java 8220624 generic-all +serviceability/sa/ClhsdbPrintStatics.java 8220624 generic-all serviceability/sa/ClhsdbPstack.java 8220624 generic-all serviceability/sa/ClhsdbSource.java 8220624 generic-all +serviceability/sa/ClhsdbThread.java 8220624 generic-all +serviceability/sa/ClhsdbWhere.java 8220624 generic-all +serviceability/sa/DeadlockDetectionTest.java 8220624 generic-all +serviceability/sa/JhsdbThreadInfoTest.java 8220624 generic-all serviceability/sa/TestClhsdbJstackLock.java 8220624 generic-all serviceability/sa/TestHeapDumpForInvokeDynamic.java 8220624 generic-all serviceability/sa/TestHeapDumpForLargeArray.java 8220624 generic-all +serviceability/sa/TestJhsdbJstackLock.java 8220624 generic-all +serviceability/sa/TestJhsdbJstackMixed.java 8220624 generic-all serviceability/sa/TestJmapCore.java 8220624 generic-all serviceability/sa/TestJmapCoreMetaspace.java 8219443 generic-all +serviceability/sa/sadebugd/DebugdConnectTest.java 8220624 generic-all diff --git a/test/hotspot/jtreg/resourcehogs/serviceability/sa/ClhsdbRegionDetailsScanOopsForG1.java b/test/hotspot/jtreg/resourcehogs/serviceability/sa/ClhsdbRegionDetailsScanOopsForG1.java index 68d562ab0c3..cc34c6481db 100644 --- a/test/hotspot/jtreg/resourcehogs/serviceability/sa/ClhsdbRegionDetailsScanOopsForG1.java +++ b/test/hotspot/jtreg/resourcehogs/serviceability/sa/ClhsdbRegionDetailsScanOopsForG1.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -45,13 +45,12 @@ public class ClhsdbRegionDetailsScanOopsForG1 { LingeredAppWithLargeStringArray theApp = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UseG1GC"); - vmArgs.add("-Xmx8g"); - vmArgs.add("-XX:G1HeapRegionSize=2m"); theApp = new LingeredAppWithLargeStringArray(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, + "-XX:+UseG1GC", + "-Xmx8g", + "-XX:G1HeapRegionSize=2m"); System.out.println("Started LingeredAppWithLargeStringArray with pid " + theApp.getPid()); List cmds = List.of("g1regiondetails"); diff --git a/test/hotspot/jtreg/resourcehogs/serviceability/sa/TestHeapDumpForLargeArray.java b/test/hotspot/jtreg/resourcehogs/serviceability/sa/TestHeapDumpForLargeArray.java index 8151d63d7ca..b539968b22d 100644 --- a/test/hotspot/jtreg/resourcehogs/serviceability/sa/TestHeapDumpForLargeArray.java +++ b/test/hotspot/jtreg/resourcehogs/serviceability/sa/TestHeapDumpForLargeArray.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -98,13 +98,12 @@ public class TestHeapDumpForLargeArray { // Need to add the default arguments first to have explicit // -Xmx8g last, otherwise test will fail if default // arguments contain a smaller -Xmx. - List vmArgs = new ArrayList(); - vmArgs.addAll(Utils.getVmOptions()); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.add("-Xmx8g"); + String[] vmArgs = Utils.prependTestJavaOpts( + "-XX:+UsePerfData", + "-Xmx8g"); theApp = new LingeredAppWithLargeArray(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); attachAndDump(heapDumpFileName, theApp.getPid()); } finally { LingeredApp.stopApp(theApp); diff --git a/test/hotspot/jtreg/serviceability/sa/CDSJMapClstats.java b/test/hotspot/jtreg/serviceability/sa/CDSJMapClstats.java index cfa29277bae..2a9b3c27b60 100644 --- a/test/hotspot/jtreg/serviceability/sa/CDSJMapClstats.java +++ b/test/hotspot/jtreg/serviceability/sa/CDSJMapClstats.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -71,11 +71,10 @@ public class CDSJMapClstats { CDSOptions opts = (new CDSOptions()).setArchiveName(sharedArchiveName); CDSTestUtils.createArchiveAndCheck(opts); - List vmArgs = Arrays.asList( + theApp = LingeredApp.startApp( "-XX:+UnlockDiagnosticVMOptions", "-XX:SharedArchiveFile=" + sharedArchiveName, "-Xshare:auto"); - theApp = LingeredApp.startApp(vmArgs); System.out.println("Started LingeredApp with pid " + theApp.getPid()); runClstats(theApp.getPid()); } catch (Exception ex) { diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSJstackPrintAll.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSJstackPrintAll.java index a9f30d69731..d2070d83ba1 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSJstackPrintAll.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSJstackPrintAll.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -51,11 +51,10 @@ public class ClhsdbCDSJstackPrintAll { CDSTestUtils.createArchiveAndCheck(opts); ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = Arrays.asList( + theApp = LingeredApp.startApp( "-XX:+UnlockDiagnosticVMOptions", "-XX:SharedArchiveFile=" + sharedArchiveName, "-Xshare:auto"); - theApp = LingeredApp.startApp(vmArgs); System.out.println("Started LingeredApp with pid " + theApp.getPid()); // Ensure that UseSharedSpaces is turned on. diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbFindPC.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbFindPC.java index b7f6d6829ce..973e563ff33 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbFindPC.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbFindPC.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -48,9 +48,9 @@ public class ClhsdbFindPC { theApp = new LingeredAppWithTrivialMain(); if (withXcomp) { - LingeredApp.startApp(List.of("-Xcomp"), theApp); + LingeredApp.startApp(theApp, "-Xcomp"); } else { - LingeredApp.startApp(List.of("-Xint"), theApp); + LingeredApp.startApp(theApp, "-Xint"); } System.out.print("Started LingeredApp "); if (withXcomp) { @@ -114,4 +114,3 @@ public class ClhsdbFindPC { System.out.println("Test PASSED"); } } - diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbFlags.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbFlags.java index 21c1c6d1922..d22c5212160 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbFlags.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbFlags.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -49,11 +49,10 @@ public class ClhsdbFlags { LingeredApp theApp = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UnlockExperimentalVMOptions"); - vmArgs.add("-XX:+UnlockDiagnosticVMOptions"); - vmArgs.add("-XX:-MaxFDLimit"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts( + "-XX:+UnlockExperimentalVMOptions", + "-XX:+UnlockDiagnosticVMOptions", + "-XX:-MaxFDLimit"); theApp = LingeredApp.startApp(vmArgs); System.out.println("Started LingeredApp with pid " + theApp.getPid()); @@ -100,18 +99,18 @@ public class ClhsdbFlags { LingeredApp theApp = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UnlockDiagnosticVMOptions"); // bool - vmArgs.add("-XX:ActiveProcessorCount=1"); // int - vmArgs.add("-XX:ParallelGCThreads=1"); // uint - vmArgs.add("-XX:MaxJavaStackTraceDepth=1024"); // intx - vmArgs.add("-XX:LogEventsBufferEntries=10"); // uintx - vmArgs.add("-XX:HeapSizePerGCThread=32m"); // size_t - vmArgs.add("-XX:NativeMemoryTracking=off"); // ccstr - vmArgs.add("-XX:OnError='echo error'"); // ccstrlist - vmArgs.add("-XX:CompileThresholdScaling=1.0"); // double - vmArgs.add("-XX:ErrorLogTimeout=120"); // uint64_t - vmArgs.addAll(Utils.getVmOptions()); + // *Prepend* options to prevent interference with flags below + String[] vmArgs = Utils.prependTestJavaOpts( + "-XX:+UnlockDiagnosticVMOptions", // bool + "-XX:ActiveProcessorCount=1", // int + "-XX:ParallelGCThreads=1", // uint + "-XX:MaxJavaStackTraceDepth=1024", // intx + "-XX:LogEventsBufferEntries=10", // uintx + "-XX:HeapSizePerGCThread=32m", // size_t + "-XX:NativeMemoryTracking=off", // ccstr + "-XX:OnError='echo error'", // ccstrlist + "-XX:CompileThresholdScaling=1.0", // double + "-XX:ErrorLogTimeout=120"); // uint64_t theApp = LingeredApp.startApp(vmArgs); System.out.println("Started LingeredApp with pid " + theApp.getPid()); diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbInspect.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbInspect.java index 802683a608c..7d207e5b6a3 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbInspect.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbInspect.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -47,7 +47,7 @@ public class ClhsdbInspect { ClhsdbLauncher test = new ClhsdbLauncher(); theApp = new LingeredAppWithLock(); - LingeredApp.startApp(null, theApp); + LingeredApp.startApp(theApp); System.out.println("Started LingeredApp with pid " + theApp.getPid()); // Run the 'jstack -v' command to get the address of a Method*, diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java index edbfcc481b4..c8943582d0c 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbJhisto.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -47,11 +47,9 @@ public class ClhsdbJhisto { LingeredAppWithInterface theApp = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(); - vmArgs.addAll(Utils.getVmOptions()); theApp = new LingeredAppWithInterface(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp); System.out.println("Started LingeredApp with pid " + theApp.getPid()); List cmds = List.of("jhisto"); diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbJstack.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbJstack.java index a18c2e1442e..60436567cf8 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbJstack.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbJstack.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -43,7 +43,7 @@ public class ClhsdbJstack { LingeredApp theApp = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - theApp = withXcomp ? LingeredApp.startApp(List.of("-Xcomp")) + theApp = withXcomp ? LingeredApp.startApp("-Xcomp") : LingeredApp.startApp(); System.out.print("Started LingeredApp "); if (withXcomp) { diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbJstackXcompStress.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbJstackXcompStress.java index 5208ecdf365..bf2b4af239c 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbJstackXcompStress.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbJstackXcompStress.java @@ -1,4 +1,5 @@ /* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2019, Red Hat Inc. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -89,12 +90,12 @@ public class ClhsdbJstackXcompStress { public static void main(String... args) throws Exception { LingeredApp app = null; try { - List vmArgs = List.of("-Xcomp", - "-XX:CompileCommand=dontinline,LingeredAppWithRecComputation.factorial", - "-XX:CompileCommand=compileonly,LingeredAppWithRecComputation.testLoop", - "-XX:CompileCommand=compileonly,LingeredAppWithRecComputation.factorial"); app = new LingeredAppWithRecComputation(); - LingeredApp.startApp(vmArgs, app); + LingeredApp.startApp(app, + "-Xcomp", + "-XX:CompileCommand=dontinline,LingeredAppWithRecComputation.factorial", + "-XX:CompileCommand=compileonly,LingeredAppWithRecComputation.testLoop", + "-XX:CompileCommand=compileonly,LingeredAppWithRecComputation.factorial"); System.out.println("Started LingeredAppWithRecComputation with pid " + app.getPid()); runJstackInLoop(app); System.out.println("Test Completed"); diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbPrintAll.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbPrintAll.java index 705d0693442..9a07f3dbadc 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbPrintAll.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbPrintAll.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -46,7 +46,7 @@ public class ClhsdbPrintAll { ClhsdbLauncher test = new ClhsdbLauncher(); theApp = new LingeredAppWithEnum(); - LingeredApp.startApp(null, theApp); + LingeredApp.startApp(theApp); System.out.println("Started LingeredAppWithEnum with pid " + theApp.getPid()); List cmds = List.of("printall"); diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbScanOops.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbScanOops.java index 2763a06bd59..c171573e287 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbScanOops.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbScanOops.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -46,9 +46,7 @@ public class ClhsdbScanOops { try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(); - vmArgs.add(gc); - theApp = LingeredApp.startApp(vmArgs); + theApp = LingeredApp.startApp(gc); System.out.println ("Started LingeredApp with the GC option " + gc + " and pid " + theApp.getPid()); diff --git a/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java b/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java index bf2999af048..ba85164a93e 100644 --- a/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java +++ b/test/hotspot/jtreg/serviceability/sa/DeadlockDetectionTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -78,12 +78,10 @@ public class DeadlockDetectionTest { } try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts("-XX:+UsePerfData"); theApp = new LingeredAppWithDeadlock(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); OutputAnalyzer output = jstack("--pid", Long.toString(theApp.getPid())); System.out.println(output.getOutput()); diff --git a/test/hotspot/jtreg/serviceability/sa/JhsdbThreadInfoTest.java b/test/hotspot/jtreg/serviceability/sa/JhsdbThreadInfoTest.java index dd22fb9b2fc..c47df961891 100644 --- a/test/hotspot/jtreg/serviceability/sa/JhsdbThreadInfoTest.java +++ b/test/hotspot/jtreg/serviceability/sa/JhsdbThreadInfoTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -45,7 +45,7 @@ public class JhsdbThreadInfoTest { LingeredApp app = null; try { - app = LingeredApp.startApp(Utils.getVmOptions()); + app = LingeredApp.startApp(); System.out.println("Started LingeredApp with pid " + app.getPid()); JDKToolLauncher jhsdbLauncher = JDKToolLauncher.createUsingTestJDK("jhsdb"); diff --git a/test/hotspot/jtreg/serviceability/sa/TestClhsdbJstackLock.java b/test/hotspot/jtreg/serviceability/sa/TestClhsdbJstackLock.java index 1eb036edd28..decd64ebc24 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestClhsdbJstackLock.java +++ b/test/hotspot/jtreg/serviceability/sa/TestClhsdbJstackLock.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -43,10 +43,9 @@ public class TestClhsdbJstackLock { LingeredAppWithLock app = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(Utils.getVmOptions()); app = new LingeredAppWithLock(); - LingeredApp.startApp(vmArgs, app); + LingeredApp.startApp(app); System.out.println ("Started LingeredAppWithLock with pid " + app.getPid()); @@ -73,4 +72,3 @@ public class TestClhsdbJstackLock { System.out.println("Test PASSED"); } } - diff --git a/test/hotspot/jtreg/serviceability/sa/TestCpoolForInvokeDynamic.java b/test/hotspot/jtreg/serviceability/sa/TestCpoolForInvokeDynamic.java index e583d77110c..5bef3e9bc2a 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestCpoolForInvokeDynamic.java +++ b/test/hotspot/jtreg/serviceability/sa/TestCpoolForInvokeDynamic.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, 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 @@ -122,12 +122,11 @@ public class TestCpoolForInvokeDynamic { if (args == null || args.length == 0) { try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts( + "-XX:+UsePerfData"); theApp = new LingeredAppWithInvokeDynamic(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); createAnotherToAttach(instanceKlassNames, theApp.getPid()); } finally { diff --git a/test/hotspot/jtreg/serviceability/sa/TestDefaultMethods.java b/test/hotspot/jtreg/serviceability/sa/TestDefaultMethods.java index 3eb7d4a20f0..bf2cc2e8801 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestDefaultMethods.java +++ b/test/hotspot/jtreg/serviceability/sa/TestDefaultMethods.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -133,12 +133,10 @@ public class TestDefaultMethods { if (args == null || args.length == 0) { try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts("-XX:+UsePerfData"); theApp = new LingeredAppWithDefaultMethods(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); createAnotherToAttach(instanceKlassNames, theApp.getPid()); } finally { diff --git a/test/hotspot/jtreg/serviceability/sa/TestG1HeapRegion.java b/test/hotspot/jtreg/serviceability/sa/TestG1HeapRegion.java index 140a94a1c89..e01f6eac3fd 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestG1HeapRegion.java +++ b/test/hotspot/jtreg/serviceability/sa/TestG1HeapRegion.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -90,13 +90,12 @@ public class TestG1HeapRegion { public static void main (String... args) throws Exception { if (args == null || args.length == 0) { try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.add("-XX:+UseG1GC"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts( + "-XX:+UsePerfData", + "-XX:+UseG1GC"); theApp = new LingeredApp(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); createAnotherToAttach(theApp.getPid()); } finally { LingeredApp.stopApp(theApp); diff --git a/test/hotspot/jtreg/serviceability/sa/TestHeapDumpForInvokeDynamic.java b/test/hotspot/jtreg/serviceability/sa/TestHeapDumpForInvokeDynamic.java index 134975ead10..dcb84350cec 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestHeapDumpForInvokeDynamic.java +++ b/test/hotspot/jtreg/serviceability/sa/TestHeapDumpForInvokeDynamic.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, 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 @@ -121,13 +121,12 @@ public class TestHeapDumpForInvokeDynamic { } try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.add("-Xmx512m"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts( + "-XX:+UsePerfData", + "-Xmx512m"); theApp = new LingeredAppWithInvokeDynamic(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); attachDumpAndVerify(heapDumpFileName, theApp.getPid()); } finally { LingeredApp.stopApp(theApp); diff --git a/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSize.java b/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSize.java index b7be9b738df..163f3f8864d 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSize.java +++ b/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSize.java @@ -73,9 +73,7 @@ public class TestInstanceKlassSize { LingeredApp app = null; OutputAnalyzer output = null; try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Arrays.asList(Utils.getTestJavaOpts())); + String[] vmArgs = Utils.appendTestJavaOpts("-XX:+UsePerfData"); app = LingeredApp.startApp(vmArgs); System.out.println ("Started LingeredApp with pid " + app.getPid()); } catch (Exception ex) { @@ -159,4 +157,3 @@ public class TestInstanceKlassSize { } } } - diff --git a/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSizeForInterface.java b/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSizeForInterface.java index b167dd1ca3c..275dec9ddbb 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSizeForInterface.java +++ b/test/hotspot/jtreg/serviceability/sa/TestInstanceKlassSizeForInterface.java @@ -150,9 +150,8 @@ public class TestInstanceKlassSizeForInterface { if (args == null || args.length == 0) { try { - List vmArgs = Arrays.asList(Utils.getTestJavaOpts()); theApp = new LingeredAppWithInterface(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp); createAnotherToAttach(instanceKlassNames, (int)theApp.getPid()); } finally { diff --git a/test/hotspot/jtreg/serviceability/sa/TestIntConstant.java b/test/hotspot/jtreg/serviceability/sa/TestIntConstant.java index 9784e3697d1..16f38ee0e67 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestIntConstant.java +++ b/test/hotspot/jtreg/serviceability/sa/TestIntConstant.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -46,9 +46,8 @@ public class TestIntConstant { LingeredApp app = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(Utils.getVmOptions()); - app = LingeredApp.startApp(vmArgs); + app = LingeredApp.startApp(); System.out.println ("Started LingeredApp with pid " + app.getPid()); diff --git a/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackLock.java b/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackLock.java index 6d907e47c37..44cc8af5269 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackLock.java +++ b/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackLock.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -51,10 +51,8 @@ public class TestJhsdbJstackLock { LingeredApp app = null; try { - List vmArgs = new ArrayList(Utils.getVmOptions()); - app = new LingeredAppWithLock(); - LingeredApp.startApp(vmArgs, app); + LingeredApp.startApp(app); System.out.println ("Started LingeredApp with pid " + app.getPid()); JDKToolLauncher launcher = JDKToolLauncher.createUsingTestJDK("jhsdb"); diff --git a/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackMixed.java b/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackMixed.java index d529becb346..59df3c486f6 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackMixed.java +++ b/test/hotspot/jtreg/serviceability/sa/TestJhsdbJstackMixed.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -165,15 +165,14 @@ public class TestJhsdbJstackMixed { LingeredApp app = null; try { - List vmArgs = new ArrayList(Utils.getVmOptions()); // Needed for LingeredApp to be able to resolve native library. String libPath = System.getProperty("java.library.path"); - if (libPath != null) { - vmArgs.add("-Djava.library.path=" + libPath); - } + String[] vmArgs = (libPath != null) + ? Utils.prependTestJavaOpts("-Djava.library.path=" + libPath) + : Utils.getTestJavaOpts(); app = new LingeredAppWithNativeMethod(); - LingeredApp.startApp(vmArgs, app); + LingeredApp.startApp(app, vmArgs); System.out.println("Started LingeredApp with pid " + app.getPid()); runJstackMixedInLoop(app); System.out.println("Test Completed"); diff --git a/test/hotspot/jtreg/serviceability/sa/TestPrintMdo.java b/test/hotspot/jtreg/serviceability/sa/TestPrintMdo.java index 5fae14d739f..ed029dedf7c 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestPrintMdo.java +++ b/test/hotspot/jtreg/serviceability/sa/TestPrintMdo.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -46,9 +46,8 @@ public class TestPrintMdo { LingeredApp app = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+ProfileInterpreter"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts( + "-XX:+ProfileInterpreter"); app = LingeredApp.startApp(vmArgs); System.out.println ("Started LingeredApp with pid " + app.getPid()); diff --git a/test/hotspot/jtreg/serviceability/sa/TestRevPtrsForInvokeDynamic.java b/test/hotspot/jtreg/serviceability/sa/TestRevPtrsForInvokeDynamic.java index 2c405d4a5d7..99cae71dd89 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestRevPtrsForInvokeDynamic.java +++ b/test/hotspot/jtreg/serviceability/sa/TestRevPtrsForInvokeDynamic.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -82,12 +82,10 @@ public class TestRevPtrsForInvokeDynamic { public static void main (String... args) throws Exception { if (args == null || args.length == 0) { try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts("-XX:+UsePerfData"); theApp = new LingeredAppWithInvokeDynamic(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); createAnotherToAttach(theApp.getPid()); } finally { LingeredApp.stopApp(theApp); diff --git a/test/hotspot/jtreg/serviceability/sa/TestType.java b/test/hotspot/jtreg/serviceability/sa/TestType.java index 0ae8ed055f0..cf89bcd8887 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestType.java +++ b/test/hotspot/jtreg/serviceability/sa/TestType.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -47,9 +47,8 @@ public class TestType { LingeredApp app = null; try { ClhsdbLauncher test = new ClhsdbLauncher(); - List vmArgs = new ArrayList(Utils.getVmOptions()); - app = LingeredApp.startApp(vmArgs); + app = LingeredApp.startApp(); System.out.println ("Started LingeredApp with pid " + app.getPid()); List cmds = List.of("type", "type InstanceKlass"); diff --git a/test/hotspot/jtreg/serviceability/sa/TestUniverse.java b/test/hotspot/jtreg/serviceability/sa/TestUniverse.java index 6a233c43f40..1cc6d2a0114 100644 --- a/test/hotspot/jtreg/serviceability/sa/TestUniverse.java +++ b/test/hotspot/jtreg/serviceability/sa/TestUniverse.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -93,7 +93,7 @@ public class TestUniverse { private static void test(GC gc) throws Exception { LingeredApp app = null; try { - app = LingeredApp.startApp(List.of("-XX:+UnlockExperimentalVMOptions", "-XX:+Use" + gc + "GC")); + app = LingeredApp.startApp("-XX:+UnlockExperimentalVMOptions", "-XX:+Use" + gc + "GC"); System.out.println ("Started LingeredApp with " + gc + "GC and pid " + app.getPid()); testClhsdbForUniverse(app.getPid(), gc); } finally { diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jdi/AttachingConnector/attach/attach004/TestDriver.java b/test/hotspot/jtreg/vmTestbase/nsk/jdi/AttachingConnector/attach/attach004/TestDriver.java index b8efbd18403..07d78e47096 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jdi/AttachingConnector/attach/attach004/TestDriver.java +++ b/test/hotspot/jtreg/vmTestbase/nsk/jdi/AttachingConnector/attach/attach004/TestDriver.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, 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 @@ -89,7 +89,7 @@ public class TestDriver { List cmd = new ArrayList<>(); Class debuggeeClass = attach004t.class; cmd.add(JDKToolFinder.getJDKTool("java")); - Collections.addAll(cmd, Utils.addTestJavaOpts( + Collections.addAll(cmd, Utils.prependTestJavaOpts( "-cp", Utils.TEST_CLASS_PATH, "-Xdebug", @@ -119,7 +119,7 @@ public class TestDriver { List cmd = new ArrayList<>(); Class debuggerClass = attach004.class; cmd.add(JDKToolFinder.getJDKTool("java")); - Collections.addAll(cmd, Utils.addTestJavaOpts( + Collections.addAll(cmd, Utils.prependTestJavaOpts( "-cp", Utils.TEST_CLASS_PATH, debuggerClass.getName(), diff --git a/test/jdk/com/sun/jdi/JdwpAllowTest.java b/test/jdk/com/sun/jdi/JdwpAllowTest.java index 561df2d6e6e..6fa29ba14ad 100644 --- a/test/jdk/com/sun/jdi/JdwpAllowTest.java +++ b/test/jdk/com/sun/jdi/JdwpAllowTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, 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 @@ -69,14 +69,11 @@ public class JdwpAllowTest { return res; } - public static ArrayList prepareCmd(String allowOpt) { - ArrayList cmd = new ArrayList<>(); - + public static String[] prepareCmd(String allowOpt) { String jdwpArgs = "-agentlib:jdwp=transport=dt_socket,server=y," + "suspend=n,address=*:0" + (allowOpt == null ? "" : ",allow=" + allowOpt); - cmd.add(jdwpArgs); - return cmd; + return new String[] { jdwpArgs }; } private static Pattern listenRegexp = Pattern.compile("Listening for transport \\b(.+)\\b at address: \\b(\\d+)\\b"); @@ -106,7 +103,7 @@ public class JdwpAllowTest { public static void positiveTest(String testName, String allowOpt) throws InterruptedException, IOException { System.err.println("\nStarting " + testName); - ArrayList cmd = prepareCmd(allowOpt); + String[] cmd = prepareCmd(allowOpt); LingeredApp a = LingeredApp.startApp(cmd); int res; @@ -124,7 +121,7 @@ public class JdwpAllowTest { public static void negativeTest(String testName, String allowOpt) throws InterruptedException, IOException { System.err.println("\nStarting " + testName); - ArrayList cmd = prepareCmd(allowOpt); + String[] cmd = prepareCmd(allowOpt); LingeredApp a = LingeredApp.startApp(cmd); int res; @@ -144,7 +141,7 @@ public class JdwpAllowTest { public static void badAllowOptionTest(String testName, String allowOpt) throws InterruptedException, IOException { System.err.println("\nStarting " + testName); - ArrayList cmd = prepareCmd(allowOpt); + String[] cmd = prepareCmd(allowOpt); LingeredApp a; try { diff --git a/test/jdk/com/sun/jdi/JdwpAttachTest.java b/test/jdk/com/sun/jdi/JdwpAttachTest.java index 76092eaae10..8d134af027c 100644 --- a/test/jdk/com/sun/jdi/JdwpAttachTest.java +++ b/test/jdk/com/sun/jdi/JdwpAttachTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2020, 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 @@ -127,11 +127,11 @@ public class JdwpAttachTest { try { LingeredApp debuggee = LingeredApp.startApp( - Arrays.asList("-agentlib:jdwp=transport=dt_socket" + "-agentlib:jdwp=transport=dt_socket" + ",address=" + connectAddress + ":" + port + ",server=n,suspend=n" // if failure is expected set small timeout (default is 20 sec) - + (!expectedResult ? ",timeout=1000" : ""))); + + (!expectedResult ? ",timeout=1000" : "")); debuggee.stopApp(); if (expectedResult) { log("OK: attached as expected"); diff --git a/test/jdk/sun/jvmstat/monitor/MonitoredVm/TestPollingInterval.java b/test/jdk/sun/jvmstat/monitor/MonitoredVm/TestPollingInterval.java index 75897542dfa..5e409c5b8ac 100644 --- a/test/jdk/sun/jvmstat/monitor/MonitoredVm/TestPollingInterval.java +++ b/test/jdk/sun/jvmstat/monitor/MonitoredVm/TestPollingInterval.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2004, 2020, 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 @@ -54,9 +54,7 @@ public class TestPollingInterval { MonitorException, URISyntaxException { LingeredApp app = null; try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts("-XX:+UsePerfData"); app = LingeredApp.startApp(vmArgs); MonitoredHost localHost = MonitoredHost.getMonitoredHost("localhost"); diff --git a/test/jdk/sun/management/jmxremote/bootstrap/AbstractFilePermissionTest.java b/test/jdk/sun/management/jmxremote/bootstrap/AbstractFilePermissionTest.java index ed1094f1d09..d939a2b1fde 100644 --- a/test/jdk/sun/management/jmxremote/bootstrap/AbstractFilePermissionTest.java +++ b/test/jdk/sun/management/jmxremote/bootstrap/AbstractFilePermissionTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2020, 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 @@ -35,6 +35,7 @@ import java.nio.file.Path; import java.nio.file.attribute.PosixFilePermission; import java.util.ArrayList; import java.util.Arrays; +import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; @@ -164,7 +165,7 @@ public abstract class AbstractFilePermissionTest { final String pp = "-Dcom.sun.management.jmxremote.port=" + jdk.test.lib.Utils.getFreePort(); List command = new ArrayList<>(); - command.addAll(jdk.test.lib.Utils.getVmOptions()); + Collections.addAll(command, jdk.test.lib.Utils.getTestJavaOpts()); command.add(mp); command.add(pp); command.add("-cp"); diff --git a/test/jdk/sun/management/jmxremote/bootstrap/LocalManagementTest.java b/test/jdk/sun/management/jmxremote/bootstrap/LocalManagementTest.java index e24365105d1..571aa93f23b 100644 --- a/test/jdk/sun/management/jmxremote/bootstrap/LocalManagementTest.java +++ b/test/jdk/sun/management/jmxremote/bootstrap/LocalManagementTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2020, 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 @@ -24,6 +24,7 @@ import java.lang.reflect.Method; import java.lang.reflect.Modifier; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import java.util.concurrent.atomic.AtomicReference; @@ -98,7 +99,7 @@ public class LocalManagementTest { private static boolean doTest(String testId, String arg) throws Exception { List args = new ArrayList<>(); args.add("-XX:+UsePerfData"); - args.addAll(Utils.getVmOptions()); + Collections.addAll(args, Utils.getTestJavaOpts()); args.add("-cp"); args.add(TEST_CLASSPATH); diff --git a/test/jdk/sun/management/jmxremote/bootstrap/RmiRegistrySslTest.java b/test/jdk/sun/management/jmxremote/bootstrap/RmiRegistrySslTest.java index 2756d008e77..45ebd6930a3 100644 --- a/test/jdk/sun/management/jmxremote/bootstrap/RmiRegistrySslTest.java +++ b/test/jdk/sun/management/jmxremote/bootstrap/RmiRegistrySslTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2020, 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 @@ -180,7 +180,7 @@ public class RmiRegistrySslTest { initTestEnvironment(); List command = new ArrayList<>(); - command.addAll(Utils.getVmOptions()); + Collections.addAll(command, Utils.getTestJavaOpts()); command.add("-Dtest.src=" + TEST_SRC); command.add("-Dtest.rmi.port=" + port); command.addAll(Arrays.asList(args)); diff --git a/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java b/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java index 64d95514446..4d70b977886 100644 --- a/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java +++ b/test/jdk/sun/tools/jhsdb/BasicLauncherTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -131,7 +131,7 @@ public class BasicLauncherTest { System.out.println("Starting LingeredApp"); try { - theApp = LingeredApp.startApp(Arrays.asList("-Xmx256m")); + theApp = LingeredApp.startApp("-Xmx256m"); System.out.println("Starting jstack against " + theApp.getPid()); JDKToolLauncher launcher = createSALauncher(); @@ -164,7 +164,7 @@ public class BasicLauncherTest { System.out.println("Starting LingeredApp"); try { - theApp = LingeredApp.startApp(Arrays.asList("-Xmx256m")); + theApp = LingeredApp.startApp("-Xmx256m"); System.out.println("Starting " + toolArgs.get(0) + " against " + theApp.getPid()); JDKToolLauncher launcher = createSALauncher(); diff --git a/test/jdk/sun/tools/jhsdb/HeapDumpTest.java b/test/jdk/sun/tools/jhsdb/HeapDumpTest.java index 48903b637f8..44e4b85ad78 100644 --- a/test/jdk/sun/tools/jhsdb/HeapDumpTest.java +++ b/test/jdk/sun/tools/jhsdb/HeapDumpTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, 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 @@ -60,7 +60,7 @@ public class HeapDumpTest { System.out.println("Starting LingeredApp"); try { theApp = new LingeredAppWithExtendedChars(); - LingeredApp.startApp(Arrays.asList("-Xmx256m"), theApp); + LingeredApp.startApp(theApp, "-Xmx256m"); System.out.println(theApp.\u00CB); System.out.println("Starting " + toolArgs.get(0) + " against " + theApp.getPid()); diff --git a/test/jdk/sun/tools/jhsdb/heapconfig/JMapHeapConfigTest.java b/test/jdk/sun/tools/jhsdb/heapconfig/JMapHeapConfigTest.java index aaa0af7f41a..0fedc5962b8 100644 --- a/test/jdk/sun/tools/jhsdb/heapconfig/JMapHeapConfigTest.java +++ b/test/jdk/sun/tools/jhsdb/heapconfig/JMapHeapConfigTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -24,6 +24,7 @@ import java.io.IOException; import java.math.BigDecimal; import java.util.ArrayList; +import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -52,7 +53,6 @@ public class JMapHeapConfigTest { "MaxHeapFreeRatio", "MaxHeapSize", "NewSize", - "MaxNewSize", "OldSize", "NewRatio", "SurvivorRatio", @@ -60,7 +60,9 @@ public class JMapHeapConfigTest { "CompressedClassSpaceSize", "G1HeapRegionSize"}; - // ignoring MaxMetaspaceSize + // Test can't deal with negative jlongs: + // ignoring MaxMetaspaceSize + // ignoring MaxNewSize static final String desiredMaxHeapSize = "-Xmx128m"; @@ -126,7 +128,7 @@ public class JMapHeapConfigTest { } boolean mx_found = false; - List jvmOptions = Utils.getVmOptions(); + String[] jvmOptions = Utils.getTestJavaOpts(); for (String option : jvmOptions) { if (option.startsWith("-Xmx")) { System.out.println("INFO: maximum heap size set by JTREG as " + option); @@ -137,7 +139,7 @@ public class JMapHeapConfigTest { // Forward vm options to LingeredApp ArrayList cmd = new ArrayList(); - cmd.addAll(Utils.getVmOptions()); + Collections.addAll(cmd, Utils.getTestJavaOpts()); if (!mx_found) { cmd.add(desiredMaxHeapSize); System.out.println("INFO: maximum heap size set explicitly as " + desiredMaxHeapSize); @@ -145,7 +147,7 @@ public class JMapHeapConfigTest { cmd.add("-XX:+PrintFlagsFinal"); TmtoolTestScenario tmt = TmtoolTestScenario.create("jmap", "--heap"); - int exitcode = tmt.launch(cmd); + int exitcode = tmt.launch(cmd.toArray(new String[0])); if (exitcode != 0) { throw new RuntimeException("Test FAILED jmap exits with non zero exit code " + exitcode); } diff --git a/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java b/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java index b95d0614c18..67f9b18aca7 100644 --- a/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java +++ b/test/jdk/sun/tools/jhsdb/heapconfig/TmtoolTestScenario.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -26,6 +26,7 @@ import java.io.InputStreamReader; import java.math.BigDecimal; import java.util.ArrayList; import java.util.Arrays; +import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -90,14 +91,14 @@ public class TmtoolTestScenario { * @param vmArgs - vm and java arguments to launch test app * @return exit code of tool */ - public int launch(List vmArgs) { + public int launch(String... vmArgs) { System.out.println("Starting LingeredApp"); try { try { List vmArgsExtended = new ArrayList(); vmArgsExtended.add("-XX:+UsePerfData"); - vmArgsExtended.addAll(vmArgs); - theApp = LingeredApp.startApp(vmArgsExtended); + Collections.addAll(vmArgsExtended, vmArgs); + theApp = LingeredApp.startApp(vmArgsExtended.toArray(new String[0])); System.out.println("Starting " + toolName + " against " + theApp.getPid()); JDKToolLauncher launcher = JDKToolLauncher.createUsingTestJDK("jhsdb"); @@ -132,10 +133,6 @@ public class TmtoolTestScenario { } } - public void launch(String... appArgs) throws IOException { - launch(Arrays.asList(appArgs)); - } - private TmtoolTestScenario(String toolName, String[] toolArgs) { this.toolName = toolName; this.toolArgs = toolArgs; diff --git a/test/jdk/sun/tools/jinfo/JInfoTest.java b/test/jdk/sun/tools/jinfo/JInfoTest.java index a7b6bc3832a..dc498ff9b0c 100644 --- a/test/jdk/sun/tools/jinfo/JInfoTest.java +++ b/test/jdk/sun/tools/jinfo/JInfoTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2020, 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 @@ -59,9 +59,9 @@ public class JInfoTest { LingeredApp app1 = new JInfoTestLingeredApp(); LingeredApp app2 = new JInfoTestLingeredApp(); try { - ArrayList params = new ArrayList(); - LingeredApp.startApp(params, app1); - LingeredApp.startApp(params, app2); + String[] params = new String[0];; + LingeredApp.startApp(app1, params); + LingeredApp.startApp(app2, params); OutputAnalyzer output = jinfo("-flag", "MinHeapFreeRatio=1", "JInfoTestLingeredApp"); output.shouldHaveExitValue(0); output = jinfo("-flag", "MinHeapFreeRatio", "JInfoTestLingeredApp"); @@ -84,9 +84,9 @@ public class JInfoTest { LingeredApp app1 = new JInfoTestLingeredApp(); LingeredApp app2 = new JInfoTestLingeredApp(); try { - ArrayList params = new ArrayList(); - LingeredApp.startApp(params, app1); - LingeredApp.startApp(params, app2); + String[] params = new String[0]; + LingeredApp.startApp(app1, params); + LingeredApp.startApp(app2, params); OutputAnalyzer output = jinfo("JInfoTestLingeredApp"); output.shouldHaveExitValue(0); // "Runtime Environment" written once per proc @@ -122,4 +122,3 @@ public class JInfoTest { // Sometime there is LingeredApp's from other test still around class JInfoTestLingeredApp extends LingeredApp { } - diff --git a/test/jdk/sun/tools/jps/JpsHelper.java b/test/jdk/sun/tools/jps/JpsHelper.java index af7b2cf1141..a186c0d80b2 100644 --- a/test/jdk/sun/tools/jps/JpsHelper.java +++ b/test/jdk/sun/tools/jps/JpsHelper.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, 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 @@ -93,21 +93,20 @@ public final class JpsHelper { } - /** - * VM arguments to start test application with. - * -XX:+UsePerfData is required for running the tests on embedded platforms. - */ - public static final String[] VM_ARGS = { - "-XX:+UsePerfData", "-Xmx512m", "-Xlog:gc", - "-Dmultiline.prop=value1\nvalue2\r\nvalue3" - }; /** * VM flag to start test application with */ public static final String VM_FLAG = "+DisableExplicitGC"; private static File vmFlagsFile = null; - private static List testVmArgs = null; + /** + * VM arguments to start test application with. + * -XX:+UsePerfData is required for running the tests on embedded platforms. + */ + private static String[] testVmArgs = { + "-XX:+UsePerfData", "-Xmx512m", "-Xlog:gc", + "-Dmultiline.prop=value1\nvalue2\r\nvalue3", + null /* lazily initialized -XX:Flags */}; private static File manifestFile = null; /** @@ -127,11 +126,9 @@ public final class JpsHelper { /** * Return a list of VM arguments */ - public static List getVmArgs() throws IOException { - if (testVmArgs == null) { - testVmArgs = new ArrayList<>(); - testVmArgs.addAll(Arrays.asList(VM_ARGS)); - testVmArgs.add("-XX:Flags=" + getVmFlagsFile().getAbsolutePath()); + public static String[] getVmArgs() throws IOException { + if (testVmArgs[testVmArgs.length - 1] == null) { + testVmArgs[testVmArgs.length - 1] = "-XX:Flags=" + getVmFlagsFile().getAbsolutePath(); } return testVmArgs; } diff --git a/test/jdk/sun/tools/jps/LingeredApp.java b/test/jdk/sun/tools/jps/LingeredApp.java index 0de79453aa5..f393941c3c5 100644 --- a/test/jdk/sun/tools/jps/LingeredApp.java +++ b/test/jdk/sun/tools/jps/LingeredApp.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -32,10 +32,12 @@ import java.nio.file.Paths; import java.nio.file.attribute.BasicFileAttributes; import java.nio.file.attribute.FileTime; import java.util.ArrayList; +import java.util.Collections; import java.util.Date; import java.util.List; import java.util.Map; import java.util.UUID; +import jdk.test.lib.Utils; /** * This is a framework to launch an app that could be synchronized with caller @@ -257,7 +259,7 @@ public class LingeredApp { * Analyze an environment and prepare a command line to * run the app, app name should be added explicitly */ - public List runAppPrepare(List vmArguments) { + public List runAppPrepare(String[] vmArguments) { // We should always use testjava or throw an exception, // so we can't use JDKToolFinder.getJDKTool("java"); // that falls back to compile java on error @@ -278,20 +280,13 @@ public class LingeredApp { List cmd = new ArrayList(); cmd.add(javapath); - if (vmArguments == null) { - // Propagate test.vm.options to LingeredApp, filter out possible empty options - String testVmOpts[] = System.getProperty("test.vm.opts","").split("\\s+"); - for (String s : testVmOpts) { - if (!s.equals("")) { - cmd.add(s); - } - } - } - else{ + // Propagate getTestJavaOpts() to LingeredApp + vmArguments = Utils.getTestJavaOpts(); + } else { // Lets user manage LingeredApp options - cmd.addAll(vmArguments); } + Collections.addAll(cmd, vmArguments); // Make sure we set correct classpath to run the app cmd.add("-cp"); @@ -326,7 +321,7 @@ public class LingeredApp { * @param vmArguments * @throws IOException */ - public void runApp(List vmArguments) + public void runApp(String[] vmArguments) throws IOException { List cmd = runAppPrepare(vmArguments); @@ -367,37 +362,14 @@ public class LingeredApp { /** * High level interface for test writers */ - /** - * Factory method that creates LingeredApp object with ready to use application - * lock name is autogenerated - * @param cmd - vm options, could be null to auto add testvm.options - * @return LingeredApp object - * @throws IOException - */ - public static LingeredApp startApp(List cmd) throws IOException { - LingeredApp a = new LingeredApp(); - a.createLock(); - try { - a.runApp(cmd); - a.waitAppReady(appWaitTime); - } catch (Exception ex) { - a.deleteLock(); - throw ex; - } - - return a; - } - /** * Factory method that starts pre-created LingeredApp * lock name is autogenerated - * @param cmd - vm options, could be null to auto add testvm.options + * @param cmd - vm options, could be null to auto add Utils.getTestJavaOpts() * @param theApp - app to start - * @return LingeredApp object * @throws IOException */ - - public static void startApp(List cmd, LingeredApp theApp) throws IOException { + public static void startApp(LingeredApp theApp, String... cmd) throws IOException { theApp.createLock(); try { theApp.runApp(cmd); @@ -408,8 +380,17 @@ public class LingeredApp { } } - public static LingeredApp startApp() throws IOException { - return startApp(null); + /** + * Factory method that creates LingeredApp object with ready to use application + * lock name is autogenerated + * @param cmd - vm options, could be null to auto add Utils.getTestJavaOpts() + * @return LingeredApp object + * @throws IOException + */ + public static LingeredApp startApp(String... cmd) throws IOException { + LingeredApp a = new LingeredApp(); + startApp(a, cmd); + return a; } public static void stopApp(LingeredApp app) throws IOException { diff --git a/test/jdk/sun/tools/jps/LingeredAppForJps.java b/test/jdk/sun/tools/jps/LingeredAppForJps.java index f2407411b77..8973202dcda 100644 --- a/test/jdk/sun/tools/jps/LingeredAppForJps.java +++ b/test/jdk/sun/tools/jps/LingeredAppForJps.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, 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 @@ -32,7 +32,7 @@ import java.net.URL; public class LingeredAppForJps extends LingeredApp { // Copy runApp logic here to be able to run an app from JarFile - public void runAppWithName(List vmArguments, String runName) + public void runAppWithName(String[] vmArguments, String runName) throws IOException { List cmd = runAppPrepare(vmArguments); @@ -52,7 +52,7 @@ public class LingeredAppForJps extends LingeredApp { startGobblerPipe(); } - public static LingeredApp startAppJar(List cmd, LingeredAppForJps app, File jar) throws IOException { + public static LingeredApp startAppJar(LingeredAppForJps app, String[] cmd, File jar) throws IOException { app.createLock(); try { app.runAppWithName(cmd, jar.getAbsolutePath()); diff --git a/test/jdk/sun/tools/jps/TestJps.java b/test/jdk/sun/tools/jps/TestJps.java index e8dd339ffff..36364554555 100644 --- a/test/jdk/sun/tools/jps/TestJps.java +++ b/test/jdk/sun/tools/jps/TestJps.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, 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 @@ -48,7 +48,7 @@ public class TestJps { public static void testJpsClass() throws Throwable { LingeredApp app = new LingeredAppForJps(); try { - LingeredApp.startApp(JpsHelper.getVmArgs(), app); + LingeredApp.startApp(app, JpsHelper.getVmArgs()); JpsHelper.runJpsVariants(app.getPid(), LingeredAppForJps.getProcessName(), LingeredAppForJps.getFullProcessName(), app.getLockFileName()); @@ -64,7 +64,7 @@ public class TestJps { // Jar created go to the main test LingeredAppForJps app = new LingeredAppForJps(); try { - LingeredAppForJps.startAppJar(JpsHelper.getVmArgs(), app, jar); + LingeredAppForJps.startAppJar(app, JpsHelper.getVmArgs(), jar); JpsHelper.runJpsVariants(app.getPid(), LingeredAppForJps.getProcessName(jar), LingeredAppForJps.getFullProcessName(jar), app.getLockFileName()); } finally { diff --git a/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java b/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java index 56ed1fbddf1..ba53dfc7afe 100644 --- a/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java +++ b/test/jdk/sun/tools/jstack/DeadlockDetectionTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -75,12 +75,10 @@ public class DeadlockDetectionTest { } try { - List vmArgs = new ArrayList(); - vmArgs.add("-XX:+UsePerfData"); - vmArgs.addAll(Utils.getVmOptions()); + String[] vmArgs = Utils.appendTestJavaOpts("-XX:+UsePerfData"); theApp = new LingeredAppWithDeadlock(); - LingeredApp.startApp(vmArgs, theApp); + LingeredApp.startApp(theApp, vmArgs); OutputAnalyzer output = jstack(Long.toString(theApp.getPid())); System.out.println(output.getOutput()); diff --git a/test/lib-test/jdk/test/lib/apps/LingeredAppTest.java b/test/lib-test/jdk/test/lib/apps/LingeredAppTest.java index 54a3706fa7c..dfbc8830b63 100644 --- a/test/lib-test/jdk/test/lib/apps/LingeredAppTest.java +++ b/test/lib-test/jdk/test/lib/apps/LingeredAppTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -52,7 +52,7 @@ public class LingeredAppTest { cmd.add("-XX:+PrintFlagsFinal"); - LingeredApp a = LingeredApp.startApp(cmd); + LingeredApp a = LingeredApp.startApp(cmd.toArray(new String[cmd.length]); System.out.printf("App pid: %d\n", a.getPid()); a.stopApp(); diff --git a/test/lib/jdk/test/lib/Utils.java b/test/lib/jdk/test/lib/Utils.java index 2617c08885c..d1654aa5677 100644 --- a/test/lib/jdk/test/lib/Utils.java +++ b/test/lib/jdk/test/lib/Utils.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2020, 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 @@ -144,15 +144,6 @@ public final class Utils { // Private constructor to prevent class instantiation } - /** - * Returns the list of VM options. - * - * @return List of VM options - */ - public static List getVmOptions() { - return Arrays.asList(safeSplitString(VM_OPTIONS)); - } - /** * Returns the list of VM options with -J prefix. * @@ -183,13 +174,34 @@ public final class Utils { * This is the combination of JTReg arguments test.vm.opts and test.java.opts * @return The combination of JTReg test java options and user args. */ - public static String[] addTestJavaOpts(String... userArgs) { + public static String[] prependTestJavaOpts(String... userArgs) { List opts = new ArrayList(); Collections.addAll(opts, getTestJavaOpts()); Collections.addAll(opts, userArgs); return opts.toArray(new String[0]); } + /** + * Combines given arguments with default JTReg arguments for a jvm running a test. + * This is the combination of JTReg arguments test.vm.opts and test.java.opts + * @return The combination of JTReg test java options and user args. + */ + public static String[] appendTestJavaOpts(String... userArgs) { + List opts = new ArrayList(); + Collections.addAll(opts, userArgs); + Collections.addAll(opts, getTestJavaOpts()); + return opts.toArray(new String[0]); + } + + /** + * Combines given arguments with default JTReg arguments for a jvm running a test. + * This is the combination of JTReg arguments test.vm.opts and test.java.opts + * @return The combination of JTReg test java options and user args. + */ + public static String[] addTestJavaOpts(String... userArgs) { + return prependTestJavaOpts(userArgs); + } + /** * Removes any options specifying which GC to use, for example "-XX:+UseG1GC". * Removes any options matching: -XX:(+/-)Use*GC diff --git a/test/lib/jdk/test/lib/apps/LingeredApp.java b/test/lib/jdk/test/lib/apps/LingeredApp.java index e96993032db..0a0e283d387 100644 --- a/test/lib/jdk/test/lib/apps/LingeredApp.java +++ b/test/lib/jdk/test/lib/apps/LingeredApp.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, 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 @@ -34,11 +34,13 @@ import java.nio.file.Paths; import java.nio.file.attribute.BasicFileAttributes; import java.nio.file.attribute.FileTime; import java.util.ArrayList; +import java.util.Collections; import java.util.Date; import java.util.List; import java.util.Map; import java.util.stream.Collectors; import java.util.UUID; +import jdk.test.lib.Utils; import jdk.test.lib.process.OutputBuffer; import jdk.test.lib.process.StreamPumper; @@ -281,7 +283,7 @@ public class LingeredApp { * Analyze an environment and prepare a command line to * run the app, app name should be added explicitly */ - public List runAppPrepare(List vmArguments) { + public List runAppPrepare(String[] vmArguments) { // We should always use testjava or throw an exception, // so we can't use JDKToolFinder.getJDKTool("java"); // that falls back to compile java on error @@ -303,17 +305,12 @@ public class LingeredApp { cmd.add(javapath); if (vmArguments == null) { - // Propagate test.vm.options to LingeredApp, filter out possible empty options - String testVmOpts[] = System.getProperty("test.vm.opts","").split("\\s+"); - for (String s : testVmOpts) { - if (!s.equals("")) { - cmd.add(s); - } - } + // Propagate getTestJavaOpts() to LingeredApp + vmArguments = Utils.getTestJavaOpts(); } else { // Lets user manage LingeredApp options - cmd.addAll(vmArguments); } + Collections.addAll(cmd, vmArguments); // Make sure we set correct classpath to run the app cmd.add("-cp"); @@ -342,7 +339,7 @@ public class LingeredApp { * @param vmArguments * @throws IOException */ - public void runApp(List vmArguments) + public void runApp(String[] vmArguments) throws IOException { List cmd = runAppPrepare(vmArguments); @@ -391,39 +388,14 @@ public class LingeredApp { /** * High level interface for test writers */ - /** - * Factory method that creates LingeredApp object with ready to use application - * lock name is autogenerated - * @param cmd - vm options, could be null to auto add testvm.options - * @return LingeredApp object - * @throws IOException - */ - public static LingeredApp startApp(List cmd) throws IOException { - LingeredApp a = new LingeredApp(); - a.createLock(); - try { - a.runApp(cmd); - a.waitAppReady(appWaitTime); - } catch (Exception ex) { - a.deleteLock(); - System.err.println("LingeredApp failed to start: " + ex); - a.finishApp(); - throw ex; - } - - return a; - } - /** * Factory method that starts pre-created LingeredApp * lock name is autogenerated - * @param cmd - vm options, could be null to auto add testvm.options + * @param cmd - vm options, could be null to auto add Utils.getTestJavaOpts() * @param theApp - app to start - * @return LingeredApp object * @throws IOException */ - - public static void startApp(List cmd, LingeredApp theApp) throws IOException { + public static void startApp(LingeredApp theApp, String... cmd) throws IOException { theApp.createLock(); try { theApp.runApp(cmd); @@ -434,8 +406,24 @@ public class LingeredApp { } } - public static LingeredApp startApp() throws IOException { - return startApp(null); + /** + * Factory method that creates LingeredApp object with ready to use application + * lock name is autogenerated + * @param cmd - vm options, could be null to auto add Utils.getTestJavaOpts() + * @return LingeredApp object + * @throws IOException + */ + public static LingeredApp startApp(String... cmd) throws IOException { + LingeredApp a = new LingeredApp(); + try { + startApp(a, cmd); + } catch (Exception ex) { + System.err.println("LingeredApp failed to start: " + ex); + a.finishApp(); + throw ex; + } + + return a; } public static void stopApp(LingeredApp app) throws IOException {