8229280: Test failures on several linux hosts after JDK-8181493
Reviewed-by: alanb, clanger, dfuchs
This commit is contained in:
parent
a1002d68fc
commit
d2db14b836
@ -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"));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user