mirror of https://github.com/lukechilds/node.git
Browse Source
Timers should work even if the user has monkey-patched `.call()` and `.apply()` to undesirable values. PR-URL: https://github.com/nodejs/node/pull/12960 Ref: https://github.com/nodejs/node/issues/12956 Reviewed-By: Refael Ackermann <refack@gmail.com> Reviewed-By: Jeremiah Senkpiel <fishrock123@rocketmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com>v6.x
Rich Trott
8 years ago
committed by
Myles Borins
2 changed files with 46 additions and 6 deletions
@ -0,0 +1,40 @@ |
|||
// Make sure `setTimeout()` and friends don't throw if the user-supplied
|
|||
// function has .call() and .apply() monkey-patched to undesirable values.
|
|||
|
|||
// Refs: https://github.com/nodejs/node/issues/12956
|
|||
|
|||
'use strict'; |
|||
|
|||
const common = require('../common'); |
|||
|
|||
{ |
|||
const fn = common.mustCall(10); |
|||
fn.call = 'not a function'; |
|||
fn.apply = 'also not a function'; |
|||
setTimeout(fn, 1); |
|||
setTimeout(fn, 1, 'oneArg'); |
|||
setTimeout(fn, 1, 'two', 'args'); |
|||
setTimeout(fn, 1, 'three', '(3)', 'args'); |
|||
setTimeout(fn, 1, 'more', 'than', 'three', 'args'); |
|||
|
|||
setImmediate(fn, 1); |
|||
setImmediate(fn, 1, 'oneArg'); |
|||
setImmediate(fn, 1, 'two', 'args'); |
|||
setImmediate(fn, 1, 'three', '(3)', 'args'); |
|||
setImmediate(fn, 1, 'more', 'than', 'three', 'args'); |
|||
} |
|||
|
|||
{ |
|||
const testInterval = (...args) => { |
|||
const fn = common.mustCall(() => { clearInterval(interval); }); |
|||
fn.call = 'not a function'; |
|||
fn.apply = 'also not a function'; |
|||
const interval = setInterval(fn, 1, ...args); |
|||
}; |
|||
|
|||
testInterval(); |
|||
testInterval('oneArg'); |
|||
testInterval('two', 'args'); |
|||
testInterval('three', '(3)', 'args'); |
|||
testInterval('more', 'than', 'three', 'args'); |
|||
} |
Loading…
Reference in new issue