FolderWatcher mit WatchService funktioniert nur bedingt

bueseb84

Mitglied
Hallo ich möchte gerne einen Folder Watcher implementieren, um auf Änerungen in einem Verzeichnis zu reagieren. Ich nutze dazu den WatchService. Allerdings funktioniert mein Code in meinem Test nur "zufällig" also mal geht es und mal eben nicht.

Hier mein Code als mein Folder Watcher:
Java:
@Slf4j
public class FolderWatcher implements Runnable {

    @NonNull
    private Path monitorDir;

    @Getter
    private boolean running = true;

    @NonNull
    private List<PropertyChangeListener> listenerList = Lists.newLinkedList();

    /**
     * default constructor
     *
     * @param monitorDir - the dir to monitor
     */
    public FolderWatcher(Path monitorDir) {
        log.info("create a new folder watcher object monitor the dir '{}'", monitorDir.toFile().getAbsolutePath());

        this.monitorDir = monitorDir;
    }

    public void addObserver(PropertyChangeListener listener) {
        log.info("add listener");
        listenerList.add(listener);
    }

    @SneakyThrows
    @Override
    public void run() {

        WatchService watchService = FileSystems.getDefault().newWatchService();
        monitorDir.register(watchService, StandardWatchEventKinds.ENTRY_CREATE, StandardWatchEventKinds.ENTRY_MODIFY);

        while (running) {
            log.debug("start monitoring '{}'", monitorDir.toFile().getAbsolutePath());

            WatchKey key;
            while ((key = watchService.take()) != null) {
                for (WatchEvent<?> event : key.pollEvents()) {
                    Path filePath = (Path) key.watchable();
                    filePath = filePath.resolve(event.context().toString());

                    if (filePath.toFile().getAbsolutePath().endsWith("csv")) {
                        log.debug("is csv file '{}'", filePath.toFile().getAbsolutePath());

                        for (PropertyChangeListener listener : listenerList){
                            listener.propertyChange(new PropertyChangeEvent(this, "file", filePath, filePath));
                        }
                    }
                }
                key.reset();
            }
        }
    }

}

So und hier mein Test :

Java:
@Slf4j
class FolderWatcherTest {

    private static Path INCOMING_DIR = Paths.get("src", "test", "resources", "incoming");
    private static Path SOURCE_CSV_FILE = Paths.get("src", "test", "resources", "testCSVFiles", "TestFile.csv");
    private static Path TARGET_CSV_FILE = Paths.get("src", "test", "resources", "incoming", "TestFile.csv");

    @SneakyThrows
    @BeforeAll
    private static void setup() {
        log.debug("create '{}'", INCOMING_DIR);
        Files.createDirectories(INCOMING_DIR);
        assertTrue(Files.exists(INCOMING_DIR));
    }

    @SneakyThrows
    @AfterAll
    private static void cleanup() {
        log.debug("delete '{}'", TARGET_CSV_FILE);
        Files.delete(TARGET_CSV_FILE);
        assertFalse(Files.exists(TARGET_CSV_FILE));

        log.debug("delete '{}'", INCOMING_DIR);
        Files.delete(INCOMING_DIR);
        assertFalse(Files.exists(INCOMING_DIR));
    }

    private void writeSourceFileContentToTargetFile(File sourceFile, File targetFile) throws Exception {
        Reader reader = new InputStreamReader(new FileInputStream(SOURCE_CSV_FILE.toFile()), StandardCharsets.ISO_8859_1);
        BufferedReader bufferedReader = new BufferedReader(reader);

        Writer writer = new OutputStreamWriter(new FileOutputStream(TARGET_CSV_FILE.toFile()));
        BufferedWriter bufferedWriter = new BufferedWriter(writer);
        bufferedReader.lines().forEach(line -> {
            try {
                bufferedWriter.write(line);
            } catch (IOException e) {
                e.printStackTrace();
            }
        });

        bufferedWriter.flush();
        bufferedWriter.close();
        bufferedReader.close();
    }

    @Test
    @DisplayName("first start folder watcher and then write the file")
    public void testFirstStartTheFolderWatcherAndThenWriteTheFile() throws Exception {
        Listener listener = new Listener();
        FolderWatcher folderWatcher = new FolderWatcher(INCOMING_DIR);
        folderWatcher.addObserver(listener);
        new Thread(folderWatcher).start();

        writeSourceFileContentToTargetFile(SOURCE_CSV_FILE.toFile(), TARGET_CSV_FILE.toFile());

        Awaitility.await().atMost(5, TimeUnit.SECONDS).until(() -> folderWatcher.isRunning() == true);
        Awaitility.await().atMost(5, TimeUnit.SECONDS).until(() -> listener.getNumberOfAffectedFiles() > 0);
    }
}


Hat jemand einen Tipp für mich
 

bueseb84

Mitglied
Danke für deinen hinweis. Also der Folderwatcher soll ja nach Dateien in dem Verzeichnis lauschen (monitorDir;) .
Anschließend sollen alle Listener informiert werden

Der Test legt dieses Verzeichnis an und kopiert eine Datei dorthin. Es soll nun geprüft werden ob der Listener diese Datei als notifcation bekommen hat.

Das lauschen auf die Datei funktioniert leider nicht zuverlässig. Mal finet der FolderWathcer diese Datei und mal eben nicht
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Java "FolderWatcher" mit Java 1.6 Allgemeine Java-Themen 11
V Wie funktioniert das Schlüsselwort "final" von Java? Allgemeine Java-Themen 19
M Apache Proxy Weiterleitung auf Tomcat funktioniert nicht wie gewünscht Allgemeine Java-Themen 1
W While Schleife funktioniert nicht ganz Allgemeine Java-Themen 4
H do-while Schleife funktioniert nicht wie ich es möchte Allgemeine Java-Themen 7
ERlK JDA Code funktioniert nicht? Allgemeine Java-Themen 4
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
stormyark TikTakToe funktioniert nicht Allgemeine Java-Themen 10
T Remove bei ArrayList funktioniert nicht Allgemeine Java-Themen 2
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
boschl2000 Springerproblem-Implementierung funktioniert nicht richtig Allgemeine Java-Themen 1
F Getter Methode aufrufen funktioniert nicht Allgemeine Java-Themen 1
N Regulärer Ausdruck funktioniert nicht Allgemeine Java-Themen 6
Lukas2904 Wie funktioniert ein KeyLogger? Allgemeine Java-Themen 3
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
1Raini Java if-Abfrage funktioniert nicht! Allgemeine Java-Themen 3
Killunox MaxHeap Zuweisung unter Linux funktioniert nicht Allgemeine Java-Themen 1
I Wieso funktioniert das nich? Allgemeine Java-Themen 5
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
A Mp3 Player funktioniert nicht Allgemeine Java-Themen 0
X JNA funktioniert nicht mehr Allgemeine Java-Themen 4
Drachenbauer Division mit Int funktioniert nicht Allgemeine Java-Themen 3
O docx-Datei erzeugung mit DocXStamper funktioniert nicht Allgemeine Java-Themen 2
F Schleife funktioniert nicht richtig Allgemeine Java-Themen 13
T Split() Methode funktioniert nicht?! Allgemeine Java-Themen 11
L Tesseract-OCR 4.0 unter Linux funktioniert nicht Allgemeine Java-Themen 3
J Wie konkret funktioniert das Modulsystem unter Java 11? Allgemeine Java-Themen 4
J Neuronales Netz funktioniert mal und mal nicht. Allgemeine Java-Themen 3
T Umlaute in Eclipse einlesen funktioniert nicht Allgemeine Java-Themen 16
A Methodenaufruf funktioniert nicht richtig Allgemeine Java-Themen 5
C WindowBuilder Design funktioniert nicht Allgemeine Java-Themen 0
J FTPSClient funktioniert nicht Allgemeine Java-Themen 4
H IDEA IntelliJ Java Mail funktioniert nach Export nicht mehr! Allgemeine Java-Themen 1
M Operatoren Warum funktioniert diese überprüfung nicht? Allgemeine Java-Themen 7
R jar-Datei funktioniert nicht Allgemeine Java-Themen 2
E Open Declaration Funktioniert nicht Allgemeine Java-Themen 0
R Verschlüsselung funktioniert nicht Allgemeine Java-Themen 5
RalleYTN requires transitive funktioniert nicht? Allgemeine Java-Themen 7
R Bruteforce hashes mit multithreading. Funktioniert das so? Allgemeine Java-Themen 0
P Best Practice Wieso funktioniert der Modulo - Operator nicht? Allgemeine Java-Themen 2
HarleyDavidson Eigener PropertyChangeListener funktioniert einfach nicht Allgemeine Java-Themen 3
J Exclude funktioniert nicht Allgemeine Java-Themen 2
K .jar funktioniert nicht vollständig Allgemeine Java-Themen 1
P Java https proxy (-Dhttps.proxyHost) Start-Parameter funktioniert nicht? Allgemeine Java-Themen 2
L Auswertung eines Testes funktioniert nicht Allgemeine Java-Themen 37
O Fahrenheit/Celsius Converter funktioniert nicht Allgemeine Java-Themen 2
M Serialisierung funktioniert nicht Allgemeine Java-Themen 9
D Collections.sort funktioniert nicht in exportierten .class Dateien Allgemeine Java-Themen 10
J Arrays auf gleichheit untersuchen funktioniert nicht Allgemeine Java-Themen 11
P GUI: ArrayList anzeigen funktioniert nicht Allgemeine Java-Themen 5
H Timer funktioniert nicht? Allgemeine Java-Themen 3
R javax.comm --> Programm funktioniert nach Export nicht mehr Allgemeine Java-Themen 0
O Mein JButton Array funktioniert nicht Allgemeine Java-Themen 3
R Erste Schritte Object reference funktioniert nicht. Wie mach ichs richtig? Allgemeine Java-Themen 3
J If Abfrage funktioniert nicht Allgemeine Java-Themen 4
R Objekt funktioniert nicht auf iOS Allgemeine Java-Themen 15
U PersistenceManager.createEntityManager funktioniert nicht Allgemeine Java-Themen 3
D Java Datei nach Eclipse Export funktioniert nicht Allgemeine Java-Themen 0
M Eigene forEach()-Methode funktioniert nicht. Allgemeine Java-Themen 2
H File.listFiles() funktioniert nicht... Allgemeine Java-Themen 10
JG12111989 Auswertung von Fragebogen funktioniert nicht! Allgemeine Java-Themen 7
M Primzahlberechnung funktioniert nicht. Allgemeine Java-Themen 4
A JFreeChart funktioniert nicht :( Allgemeine Java-Themen 6
C file.delete() funktioniert bei zweiten aufruf nicht mehr Allgemeine Java-Themen 3
F Datei einlesen funktioniert nicht Allgemeine Java-Themen 3
A Debugger im Java-Editor funktioniert nicht Allgemeine Java-Themen 5
B DB-Zugriff einer Webanwendung funktioniert nicht mit Java 7 Allgemeine Java-Themen 2
B Web-Anwendung funktioniert mit Java 1.8, aber nicht mit Java 1.7 (auf Client) Allgemeine Java-Themen 5
J Swing Cursor.WAIT funktioniert nicht nach JFileChooser Allgemeine Java-Themen 1
P Wie funktioniert das Feedback eines Klicks auf eine Java GUI Allgemeine Java-Themen 10
F JTextField funktioniert nicht Allgemeine Java-Themen 6
Athena Programm funktioniert nur beim Debugging korrekt, sonst nicht. Allgemeine Java-Themen 1
S CSV Eintrag der nächsten Zeile auslesen funktioniert nicht Allgemeine Java-Themen 8
S Command funktioniert in Kommandzeile aber nicht mit ProcessBuilder bzw. Runtime.exec auf MAC Allgemeine Java-Themen 3
G Verschlüsselungsalgorythmus funktioniert nicht Allgemeine Java-Themen 2
buggy84 Ausführen einer Batch mit Parameterübergabe funktioniert nicht richtig Allgemeine Java-Themen 18
G Befehl funktioniert in Eclipse allerdings nicht in einer Jar-Datei Allgemeine Java-Themen 3
N Werte aus Arrays auslesen funktioniert nicht Allgemeine Java-Themen 5
W getResources funktioniert nur in Eclipse, nicht in JAR Allgemeine Java-Themen 2
S Methode funktioniert nicht als ActionListener Allgemeine Java-Themen 4
M exec() funktioniert nicht Allgemeine Java-Themen 1
M RC4-Chiffre (funktioniert eingeschränkt) Allgemeine Java-Themen 6
X Datentypen Dropzone.options funktioniert nicht Allgemeine Java-Themen 1
D Java funktioniert nur mit deaktivierter Grafikkarte Allgemeine Java-Themen 3
L Erste Schritte Eclipse und Lokal funktioniert - in HTML nicht! Allgemeine Java-Themen 2
K MD5 funktioniert nicht korrekt !? Allgemeine Java-Themen 9
M JAR Datei erstellen funktioniert nicht Allgemeine Java-Themen 5
Q JLabel Textausgabe funktioniert nicht Allgemeine Java-Themen 4
E SimpleDateFormat-Konvertierung funktioniert nicht Allgemeine Java-Themen 3
T Dateidownload Funktioniert nicht Allgemeine Java-Themen 4
C Wie funktioniert Projektplanung? Allgemeine Java-Themen 18
K String.replace funktioniert nicht Allgemeine Java-Themen 3
G treeMap.putall funktioniert nicht?! Allgemeine Java-Themen 2
DaniSahne96 Threads Code funktioniert nicht wie er sollte Allgemeine Java-Themen 9
S Warum funktioniert die runable -.jar nicht? Allgemeine Java-Themen 7
P Eclipse Unter Windows erstelle .jar unter Linux (Ubuntu) funktioniert nicht Allgemeine Java-Themen 5
H Mit Ant erstelltes jar funktioniert nicht wie direkt in Eclipse Allgemeine Java-Themen 8
aze Jar ausführen über Runtime.execute funktioniert nicht Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben