8157931: jdk/internal/jrtfs/Basic.java fails with exploded builds
Reviewed-by: alanb, sundar, jlaskey
This commit is contained in:
parent
6ffb19d592
commit
3e72d2ce1c
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -65,15 +65,31 @@ public class Basic {
|
|||||||
|
|
||||||
private FileSystem theFileSystem;
|
private FileSystem theFileSystem;
|
||||||
private FileSystem fs;
|
private FileSystem fs;
|
||||||
|
private boolean isExplodedBuild = false;
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public void setup() {
|
public void setup() {
|
||||||
|
theFileSystem = FileSystems.getFileSystem(URI.create("jrt:/"));
|
||||||
|
Path javaHomeDir = Paths.get(System.getProperty("java.home"));
|
||||||
|
Path jrtJarPath = javaHomeDir.resolve("jrt-fs.jar");
|
||||||
|
Path modulesPath = javaHomeDir.resolve("lib/modules");
|
||||||
|
isExplodedBuild = !Files.exists(jrtJarPath)
|
||||||
|
&& !Files.exists(modulesPath);
|
||||||
|
if (Files.notExists(jrtJarPath)
|
||||||
|
&& Files.notExists(modulesPath)) {
|
||||||
|
System.out.printf("Following files not exist: %s, %s",
|
||||||
|
jrtJarPath.toString(), modulesPath.toString());
|
||||||
|
System.out.println();
|
||||||
|
System.out.println("It is most probably an exploded build."
|
||||||
|
+ " Skip non-default FileSystem testing.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, String> env = new HashMap<>();
|
||||||
|
// set java.home property to be underlying java.home
|
||||||
|
// so that jrt-fs.jar loading is exercised.
|
||||||
|
env.put("java.home", System.getProperty("java.home"));
|
||||||
try {
|
try {
|
||||||
theFileSystem = FileSystems.getFileSystem(URI.create("jrt:/"));
|
|
||||||
Map<String, String> env = new HashMap<>();
|
|
||||||
// set java.home property to be underlying java.home
|
|
||||||
// so that jrt-fs.jar loading is exercised.
|
|
||||||
env.put("java.home", System.getProperty("java.home"));
|
|
||||||
fs = FileSystems.newFileSystem(URI.create("jrt:/"), env);
|
fs = FileSystems.newFileSystem(URI.create("jrt:/"), env);
|
||||||
} catch (IOException ioExp) {
|
} catch (IOException ioExp) {
|
||||||
throw new RuntimeException(ioExp);
|
throw new RuntimeException(ioExp);
|
||||||
@ -131,6 +147,12 @@ public class Basic {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNewFileSystemWithJavaHome() throws Exception {
|
public void testNewFileSystemWithJavaHome() throws Exception {
|
||||||
|
if (isExplodedBuild) {
|
||||||
|
System.out.println("Skip testNewFileSystemWithJavaHome"
|
||||||
|
+ " since this is an exploded build");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
Map<String, String> env = new HashMap<>();
|
Map<String, String> env = new HashMap<>();
|
||||||
// set java.home property to be underlying java.home
|
// set java.home property to be underlying java.home
|
||||||
// so that jrt-fs.jar loading is exercised.
|
// so that jrt-fs.jar loading is exercised.
|
||||||
@ -154,6 +176,11 @@ public class Basic {
|
|||||||
|
|
||||||
@Test(dataProvider = "knownClassFiles")
|
@Test(dataProvider = "knownClassFiles")
|
||||||
public void testKnownClassFiles(String path, boolean theDefault) throws Exception {
|
public void testKnownClassFiles(String path, boolean theDefault) throws Exception {
|
||||||
|
if (isExplodedBuild && !theDefault) {
|
||||||
|
System.out.println("Skip testKnownClassFiles with non-default FileSystem");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
FileSystem fs = selectFileSystem(theDefault);
|
FileSystem fs = selectFileSystem(theDefault);
|
||||||
Path classFile = fs.getPath(path);
|
Path classFile = fs.getPath(path);
|
||||||
|
|
||||||
@ -201,6 +228,11 @@ public class Basic {
|
|||||||
|
|
||||||
@Test(dataProvider = "knownDirectories")
|
@Test(dataProvider = "knownDirectories")
|
||||||
public void testKnownDirectories(String path, boolean theDefault) throws Exception {
|
public void testKnownDirectories(String path, boolean theDefault) throws Exception {
|
||||||
|
if (isExplodedBuild && !theDefault) {
|
||||||
|
System.out.println("Skip testKnownDirectories with non-default FileSystem");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
FileSystem fs = selectFileSystem(theDefault);
|
FileSystem fs = selectFileSystem(theDefault);
|
||||||
Path dir = fs.getPath(path);
|
Path dir = fs.getPath(path);
|
||||||
|
|
||||||
@ -684,3 +716,4 @@ public class Basic {
|
|||||||
assertEquals(dirPrefixOkayCount, childCount);
|
assertEquals(dirPrefixOkayCount, childCount);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user