diff --git a/test/hotspot/jtreg/ProblemList.txt b/test/hotspot/jtreg/ProblemList.txt index 1b118f407b2..ecb170526dc 100644 --- a/test/hotspot/jtreg/ProblemList.txt +++ b/test/hotspot/jtreg/ProblemList.txt @@ -54,6 +54,9 @@ compiler/types/correctness/OffTest.java 8066173 generic-all # aot test intermittently failing in jprt 8175791 compiler/aot/DeoptimizationTest.java 8175791 windows-all +applications/ctw/modules/java_desktop.java 8189604 windows-all +applications/ctw/modules/jdk_jconsole.java 8189604 windows-all + ############################################################################# # :hotspot_gc diff --git a/test/hotspot/jtreg/applications/ctw/modules/generate.bash b/test/hotspot/jtreg/applications/ctw/modules/generate.bash new file mode 100644 index 00000000000..8c7a0c5a316 --- /dev/null +++ b/test/hotspot/jtreg/applications/ctw/modules/generate.bash @@ -0,0 +1,72 @@ +#!/bin/bash +# +# 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. +# + +# generates CTW tests for modules passed as argument + +for module in $@ +do + file=${module//./_}.java + echo creating $file for $module... + cat > $file < { @@ -87,10 +91,10 @@ public class CompileTheWorld { } finally { await(executor); } - CompileTheWorld.OUT.printf("Done (%d classes, %d methods, %d ms)%n", + CompileTheWorld.OUT.println(String.format("Done (%d classes, %d methods, %d ms)", PathHandler.getProcessedClassCount(), Compiler.getMethodCount(), - System.currentTimeMillis() - start); + System.currentTimeMillis() - start)); passed = true; } catch (Throwable t){ t.printStackTrace(ERR); diff --git a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Compiler.java b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Compiler.java index da6ab6aeb31..f5091c7df02 100644 --- a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Compiler.java +++ b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Compiler.java @@ -100,8 +100,8 @@ public class Compiler { } } } catch (Throwable t) { - CompileTheWorld.OUT.printf("[%d]\t%s\tWARNING preloading failed : %s%n", - id, className, t); + CompileTheWorld.OUT.println(String.format("[%d]\t%s\tWARNING preloading failed : %s", + id, className, t)); t.printStackTrace(CompileTheWorld.ERR); } } @@ -113,8 +113,8 @@ public class Compiler { try { WHITE_BOX.enqueueInitializerForCompilation(aClass, i); } catch (Throwable t) { - CompileTheWorld.OUT.printf("[%d]\t%s::\tERROR at level %d : %s%n", - id, aClass.getName(), i, t); + CompileTheWorld.OUT.println(String.format("[%d]\t%s::\tERROR at level %d : %s", + id, aClass.getName(), i, t)); t.printStackTrace(CompileTheWorld.ERR); } } diff --git a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java index 57d626e0ed2..453c3c0c612 100644 --- a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java +++ b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/CtwRunner.java @@ -35,8 +35,6 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.util.ArrayList; import java.util.List; -import java.util.concurrent.Executor; -import java.util.concurrent.ExecutorService; import java.util.concurrent.TimeUnit; import java.util.function.Predicate; import java.util.regex.Pattern; @@ -62,19 +60,27 @@ public class CtwRunner { } private final List errors; + private final String target; private final Path targetPath; private final String targetName; private CtwRunner(String target) { - if (target.equals("modules")) { + if (target.startsWith("modules")) { targetPath = Paths .get(Utils.TEST_JDK) .resolve("lib") - .resolve(target); + .resolve("modules"); + if (target.equals("modules")){ + target = targetPath.toString(); + } + targetName = target.replace(':', '_') + .replace('.', '_') + .replace(',', '_'); } else { targetPath = Paths.get(target).toAbsolutePath(); + targetName = targetPath.getFileName().toString(); } - targetName = targetPath.getFileName().toString(); + this.target = target; errors = new ArrayList<>(); } @@ -104,7 +110,7 @@ public class CtwRunner { long classStart = 0L; long classCount = classCount(); Asserts.assertGreaterThan(classCount, 0L, - targetPath + " does not have any classes"); + target + "(at " + targetPath + ") does not have any classes"); boolean done = false; while (!done) { String[] cmd = cmd(classStart); @@ -138,7 +144,7 @@ public class CtwRunner { + "] != classCount[" + classCount + "]")); } else { System.out.println("Executed CTW for all " + classCount - + " classes in " + targetPath); + + " classes in " + target + "(at " + targetPath + ")"); } done = true; } else { @@ -162,7 +168,7 @@ public class CtwRunner { } private long classCount() { - List phs = PathHandler.create(targetPath.toString()); + List phs = PathHandler.create(target); long result = phs.stream() .mapToLong(PathHandler::classCount) .sum(); @@ -215,7 +221,7 @@ public class CtwRunner { "-XX:CompileCommand=exclude,java/lang/invoke/MethodHandle.*", // CTW entry point CompileTheWorld.class.getName(), - targetPath.toString(), + target, }; } diff --git a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/PathHandler.java b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/PathHandler.java index 4ee3ec4e240..5ab94b0a356 100644 --- a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/PathHandler.java +++ b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/PathHandler.java @@ -24,9 +24,12 @@ package sun.hotspot.tools.ctw; import java.io.Closeable; +import java.net.URI; +import java.nio.file.FileSystems; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; +import java.util.Arrays; import java.util.Collections; import java.util.List; import java.util.Objects; @@ -35,6 +38,7 @@ import java.util.concurrent.atomic.AtomicLong; import java.util.function.Function; import java.util.regex.Matcher; import java.util.regex.Pattern; +import java.util.stream.Collectors; import java.util.stream.Stream; /** @@ -121,6 +125,15 @@ public class PathHandler implements Closeable { path = matcher.group(1); path = path.isEmpty() ? "." : path; return ClassPathJarInDirEntry.create(Paths.get(path)); + } else if (path.startsWith("modules:")) { + Path modules = FileSystems.getFileSystem(URI.create("jrt:/")) + .getPath("modules"); + return Arrays.stream(path.substring("modules:".length()) + .split(",")) + .map(modules::resolve) + .map(ClassPathDirEntry::new) + .map(PathHandler::new) + .collect(Collectors.toList()); } else { path = path.isEmpty() ? "." : path; Path p = Paths.get(path); @@ -180,7 +193,9 @@ public class PathHandler implements Closeable { */ public final void process(Executor executor) { CompileTheWorld.OUT.println(entry.description()); - entry.classes().forEach(s -> processClass(s, executor)); + entry.classes() + .distinct() + .forEach(s -> processClass(s, executor)); } /** @@ -209,12 +224,12 @@ public class PathHandler implements Closeable { Class aClass; Thread.currentThread().setContextClassLoader(entry.loader()); try { - CompileTheWorld.OUT.printf("[%d]\t%s%n", id, name); + CompileTheWorld.OUT.println(String.format("[%d]\t%s", id, name)); aClass = entry.loader().loadClass(name); Compiler.compileClass(aClass, id, executor); } catch (Throwable e) { - CompileTheWorld.OUT.printf("[%d]\t%s\tWARNING skipped: %s%n", - id, name, e); + CompileTheWorld.OUT.println(String.format("[%d]\t%s\tWARNING skipped: %s", + id, name, e)); e.printStackTrace(CompileTheWorld.ERR); } } diff --git a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Utils.java b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Utils.java index f9a6b7e03d5..ff44618647c 100644 --- a/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Utils.java +++ b/test/hotspot/jtreg/testlibrary/ctw/src/sun/hotspot/tools/ctw/Utils.java @@ -193,10 +193,11 @@ public class Utils { * @param filename tested filename */ public static boolean isClassFile(String filename) { - // If the filename has a period after removing '.class', it's not valid class file return endsWithIgnoreCase(filename, CLASSFILE_EXT) - && (filename.indexOf('.') - == (filename.length() - CLASSFILE_EXT.length())); + // skip all module-info.class files + && !(filename.substring(filename.lastIndexOf('/') + 1, + filename.lastIndexOf('.')) + .equals("module-info")); } /**