diff --git a/test/jdk/java/nio/file/WatchService/SensitivityModifier.java b/test/jdk/java/nio/file/WatchService/SensitivityModifier.java index f01704a9ba8..b43a4b926ce 100644 --- a/test/jdk/java/nio/file/WatchService/SensitivityModifier.java +++ b/test/jdk/java/nio/file/WatchService/SensitivityModifier.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2021, 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 @@ -25,31 +25,51 @@ * @bug 4313887 * @summary Sanity test for JDK-specific sensitivity level watch event modifier * @modules jdk.unsupported - * @library .. + * @library .. /test/lib + * @build jdk.test.lib.Platform + * @build jdk.test.lib.RandomFactory * @run main/timeout=240 SensitivityModifier * @key randomness */ -import java.nio.file.*; +import java.nio.file.Files; +import java.nio.file.FileSystem; +import java.nio.file.Path; +import java.nio.file.WatchEvent; +import java.nio.file.WatchKey; +import java.nio.file.WatchService; import static java.nio.file.StandardWatchEventKinds.*; import java.io.OutputStream; import java.io.IOException; +import java.util.HashMap; +import java.util.Map; import java.util.Random; import java.util.concurrent.TimeUnit; import com.sun.nio.file.SensitivityWatchEventModifier; +import jdk.test.lib.Platform; +import jdk.test.lib.RandomFactory; public class SensitivityModifier { + // on macOS and other platforms, watch services might be based on polling + // requiring a longer timeout to detect events before returning + static final long POLL_TIMEOUT_SECONDS = + Platform.isLinux() || Platform.isWindows() ? 1 : 2; - static final Random rand = new Random(); + static final Random RAND = RandomFactory.getRandom(); + + static final Map pathToTime = new HashMap<>(); static void register(Path[] dirs, WatchService watcher) throws IOException { - SensitivityWatchEventModifier[] sensitivtives = + pathToTime.clear(); + SensitivityWatchEventModifier[] sensitivities = SensitivityWatchEventModifier.values(); for (int i=0; i[]{ ENTRY_MODIFY }, sensivity); + dir.register(watcher, new WatchEvent.Kind[]{ ENTRY_MODIFY }, + sensitivity); + pathToTime.put(dir, sensitivity.sensitivityValueInSeconds()); } } @@ -59,15 +79,15 @@ public class SensitivityModifier { try (WatchService watcher = fs.newWatchService()) { // create directories and files - int nDirs = 5 + rand.nextInt(20); - int nFiles = 50 + rand.nextInt(50); + int nDirs = 5 + RAND.nextInt(20); + int nFiles = 50 + RAND.nextInt(50); Path[] dirs = new Path[nDirs]; Path[] files = new Path[nFiles]; for (int i=0; i