8229280: Test failures on several linux hosts after JDK-8181493

Reviewed-by: alanb, clanger, dfuchs
This commit is contained in:
Brian Burkhalter 2019-09-05 14:12:01 -07:00
parent a1002d68fc
commit d2db14b836

View File

@ -25,37 +25,43 @@
* @bug 8181493 * @bug 8181493
* @summary Verify that nanosecond precision is maintained for file timestamps * @summary Verify that nanosecond precision is maintained for file timestamps
* @requires (os.family == "linux") | (os.family == "mac") | (os.family == "solaris") * @requires (os.family == "linux") | (os.family == "mac") | (os.family == "solaris")
* @modules java.base/sun.nio.fs:+open
*/ */
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.Method;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.FileStore; import java.nio.file.FileStore;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.attribute.BasicFileAttributes; import java.nio.file.attribute.BasicFileAttributes;
import java.nio.file.attribute.BasicFileAttributeView; import java.nio.file.attribute.BasicFileAttributeView;
import java.nio.file.attribute.FileTime; import java.nio.file.attribute.FileTime;
import java.time.Instant; import java.util.Set;
import java.time.ZoneId;
import java.time.ZoneOffset;
import java.time.format.DateTimeFormatter;
import java.util.Arrays;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
public class SetTimesNanos { public class SetTimesNanos {
public static void main(String[] args) throws IOException, public static void main(String[] args) throws Exception {
InterruptedException { // Check whether futimens() system call is supported
Class unixNativeDispatcherClass = Class.forName("sun.nio.fs.UnixNativeDispatcher");
Method futimensSupported = unixNativeDispatcherClass.getDeclaredMethod("futimensSupported");
futimensSupported.setAccessible(true);
if (!(boolean)futimensSupported.invoke(null)) {
System.err.println("futimens() system call not supported; skipping test");
return;
}
Path dirPath = Path.of("test"); Path dirPath = Path.of("test");
Path dir = Files.createDirectory(dirPath); Path dir = Files.createDirectory(dirPath);
FileStore store = Files.getFileStore(dir); FileStore store = Files.getFileStore(dir);
System.out.format("FileStore: %s on %s (%s)%n", dir, store.name(), System.out.format("FileStore: \"%s\" on %s (%s)%n",
store.type()); dir, store.name(), store.type());
if (System.getProperty("os.name").toLowerCase().startsWith("mac") &&
store.type().equalsIgnoreCase("hfs")) { Set<String> testedTypes = Set.of("apfs", "ext4", "xfs", "zfs");
System.err.println if (!testedTypes.contains(store.type())) {
("HFS on macOS does not have nsec timestamps: skipping test"); System.err.format("%s not in %s; skipping test", store.type(), testedTypes);
return; return;
} }
testNanos(dir); testNanos(dir);
Path file = Files.createFile(dir.resolve("test.dat")); Path file = Files.createFile(dir.resolve("test.dat"));