From bf378d45fb8b61668da54c48066197bd4a2bdee9 Mon Sep 17 00:00:00 2001 From: Benjamin Gruenbaum Date: Tue, 2 Feb 2021 19:30:43 +0200 Subject: [PATCH] fs: add AbortSignal support to watch --- doc/api/fs.md | 7 +++++ lib/fs.js | 10 +++++++ test/parallel/test-fs-watch-abort-signal.js | 32 +++++++++++++++++++++ 3 files changed, 49 insertions(+) create mode 100644 test/parallel/test-fs-watch-abort-signal.js diff --git a/doc/api/fs.md b/doc/api/fs.md index cac35be697c483..b29d2876ad9028 100644 --- a/doc/api/fs.md +++ b/doc/api/fs.md @@ -4133,6 +4133,9 @@ this API: [`fs.utimes()`][]. diff --git a/lib/fs.js b/lib/fs.js index d01e99c21b0178..4480ff5c00c3db 100644 --- a/lib/fs.js +++ b/lib/fs.js @@ -1579,6 +1579,16 @@ function watch(filename, options, listener) { if (listener) { watcher.addListener('change', listener); } + if (options.signal) { + if (options.signal.aborted) { + process.nextTick(() => watcher.close()); + } + const listener = () => watcher.close(); + options.signal.addEventListener('abort', listener); + watcher.once('close', () => { + options.signal.removeEventListener('abort', listener); + }); + } return watcher; } diff --git a/test/parallel/test-fs-watch-abort-signal.js b/test/parallel/test-fs-watch-abort-signal.js new file mode 100644 index 00000000000000..844eea6eedac22 --- /dev/null +++ b/test/parallel/test-fs-watch-abort-signal.js @@ -0,0 +1,32 @@ +// Flags: --expose-internals +'use strict'; + +// Verify that AbortSignal integration works for fs.watch + +const common = require('../common'); + +if (common.isIBMi) + common.skip('IBMi does not support `fs.watch()`'); + +const fs = require('fs'); +const fixtures = require('../common/fixtures'); + + +{ + // Signal aborted after creating the watcher + const file = fixtures.path('empty.js'); + const ac = new AbortController(); + const { signal } = ac; + const wathcer = fs.watch(file, { signal }); + wathcer.once('close', common.mustCall()); + setImmediate(() => ac.abort()); +} +{ + // Signal aborted before creating the watcher + const file = fixtures.path('empty.js'); + const ac = new AbortController(); + const { signal } = ac; + ac.abort(); + const wathcer = fs.watch(file, { signal }); + wathcer.once('close', common.mustCall()); +}