mirror of https://github.com/nodejs/node.git
test: add setTimeout/setInterval multi-arg tests
It turns out we have little to no test coverage for setTimeout() and setInterval() calls with optional arguments. Now we do. PR-URL: https://github.com/iojs/io.js/pull/1221 Reviewed-By: Trevor Norris <trev.norris@gmail.com>pull/1221/head
parent
33fea6ed5f
commit
2b3b2d392f
|
@ -0,0 +1,30 @@
|
|||
var common = require('../common');
|
||||
var assert = require('assert');
|
||||
|
||||
function range(n) {
|
||||
return 'x'.repeat(n + 1).split('').map(function(_, i) { return i; });
|
||||
}
|
||||
|
||||
function timeout(nargs) {
|
||||
var args = range(nargs);
|
||||
setTimeout.apply(null, [callback, 1].concat(args));
|
||||
|
||||
function callback() {
|
||||
assert.deepEqual([].slice.call(arguments), args);
|
||||
if (nargs < 128) timeout(nargs + 1);
|
||||
}
|
||||
}
|
||||
|
||||
function interval(nargs) {
|
||||
var args = range(nargs);
|
||||
var timer = setTimeout.apply(null, [callback, 1].concat(args));
|
||||
|
||||
function callback() {
|
||||
clearInterval(timer);
|
||||
assert.deepEqual([].slice.call(arguments), args);
|
||||
if (nargs < 128) interval(nargs + 1);
|
||||
}
|
||||
}
|
||||
|
||||
timeout(0);
|
||||
interval(0);
|
Loading…
Reference in New Issue