// create a sub-path so that the destDir length is almost MAX_PATH // so that the full path (with the class name) will exceed MAX_PATH int subDirLen = MAX_PATH - classDir.toString().length() - 2; if (subDirLen > 0) { char[] chars = newchar[subDirLen];
Arrays.fill(chars, 'x');
String subPath = new String(chars);
destDir = Paths.get(System.getProperty("test.classes"), subPath);
}
OutputAnalyzer output = new OutputAnalyzer(pb.start());
output.shouldContain("Hello World")
.shouldHaveExitValue(0);
// increase the length of destDir to slightly over MAX_PATH
destDir = Paths.get(destDir.toString(), "xxxxx");
CompilerUtils.compile(sourceDir, destDir);
output = new OutputAnalyzer(pb.start());
output.shouldContain("Hello World")
.shouldHaveExitValue(0);
// Test a relative path for a jar file < MAX_PATH, but where the // absolute path is > MAX_PATH.
Path jarDir = Paths.get("."); for (int i = 0; i < 21; ++i) {
jarDir = jarDir.resolve("0123456789");
}
Files.createDirectories(jarDir);
Path jarPath = jarDir.resolve("hello.jar");
Files.copy(Paths.get(helloJar), jarPath);
bootCP = "-Xbootclasspath/a:" + jarPath.toString();
pb = ProcessTools.createJavaProcessBuilder(bootCP, "Hello");
output = new OutputAnalyzer(pb.start());
output.shouldContain("Hello World")
.shouldHaveExitValue(0);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.