mirror of
https://github.com/nodejs/node.git
synced 2025-05-04 20:05:02 +00:00

Testing this wasn't really useful, besides Object.observe is going to be deprecated. Also this test fails with Chakra (#4765) for obvious reason. PR-URL: https://github.com/nodejs/node/pull/4769 Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Brian White <mscdex@mscdex.net> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Roman Reiss <me@silverwind.io>
50 lines
1.0 KiB
JavaScript
50 lines
1.0 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
var assert = require('assert');
|
|
|
|
// Requiring the domain module here changes the function that is used by node to
|
|
// call process.nextTick's callbacks to a variant that specifically handles
|
|
// domains. We want to test this specific variant in this test, and so even if
|
|
// the domain module is not used, this require call is needed and must not be
|
|
// removed.
|
|
require('domain');
|
|
|
|
var implementations = [
|
|
function(fn) {
|
|
Promise.resolve().then(fn);
|
|
}
|
|
];
|
|
|
|
var expected = 0;
|
|
var done = 0;
|
|
|
|
process.on('exit', function() {
|
|
assert.equal(done, expected);
|
|
});
|
|
|
|
function test(scheduleMicrotask) {
|
|
var nextTickCalled = false;
|
|
expected++;
|
|
|
|
scheduleMicrotask(function() {
|
|
process.nextTick(function() {
|
|
nextTickCalled = true;
|
|
});
|
|
|
|
setTimeout(function() {
|
|
assert(nextTickCalled);
|
|
done++;
|
|
}, 0);
|
|
});
|
|
}
|
|
|
|
// first tick case
|
|
implementations.forEach(test);
|
|
|
|
// tick callback case
|
|
setTimeout(function() {
|
|
implementations.forEach(function(impl) {
|
|
process.nextTick(test.bind(null, impl));
|
|
});
|
|
}, 0);
|