mirror of https://github.com/lukechilds/node.git
Browse Source
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>v7.x
Claudio Rodriguez
8 years ago
committed by
James M Snell
3 changed files with 33 additions and 1 deletions
@ -0,0 +1,19 @@ |
|||||
|
'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); |
||||
|
}); |
@ -0,0 +1,9 @@ |
|||||
|
'use strict'; |
||||
|
require('../common'); |
||||
|
const assert = require('assert'); |
||||
|
const fs = require('fs'); |
||||
|
|
||||
|
const watch = fs.watchFile(__filename, () => {}); |
||||
|
watch.once('stop', assert.fail); // Should not trigger.
|
||||
|
watch.stop(); |
||||
|
watch.removeListener('stop', assert.fail); |
Loading…
Reference in new issue