mirror of
https://github.com/nodejs/node.git
synced 2025-05-01 17:03:34 +00:00

Emits 'stop' event for fs.watchFile on process.nextTick to fix 'maximum call stack size exceeded' error when `stop` is called synchronously after listener is attached. PR-URL: https://github.com/nodejs/node/pull/8524 Fixes: https://github.com/nodejs/node/issues/8421 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Ilkka Myller <ilkka.myller@nodefield.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Yorkie Liu <yorkiefixer@gmail.com>
20 lines
458 B
JavaScript
20 lines
458 B
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const fs = require('fs');
|
|
|
|
const watch = fs.watchFile(__filename, () => {});
|
|
let triggered;
|
|
const listener = common.mustCall(() => {
|
|
triggered = true;
|
|
});
|
|
|
|
triggered = false;
|
|
watch.once('stop', listener); // Should trigger.
|
|
watch.stop();
|
|
assert.equal(triggered, false);
|
|
setImmediate(() => {
|
|
assert.equal(triggered, true);
|
|
watch.removeListener('stop', listener);
|
|
});
|