1// Copyright Joyent, Inc. and other Node contributors. 2// 3// Permission is hereby granted, free of charge, to any person obtaining a 4// copy of this software and associated documentation files (the 5// "Software"), to deal in the Software without restriction, including 6// without limitation the rights to use, copy, modify, merge, publish, 7// distribute, sublicense, and/or sell copies of the Software, and to permit 8// persons to whom the Software is furnished to do so, subject to the 9// following conditions: 10// 11// The above copyright notice and this permission notice shall be included 12// in all copies or substantial portions of the Software. 13// 14// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 15// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 16// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN 17// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, 18// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR 19// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE 20// USE OR OTHER DEALINGS IN THE SOFTWARE. 21 22'use strict'; 23require('../common'); 24const assert = require('assert'); 25let i; 26 27const N = 30; 28const done = []; 29 30function get_printer(timeout) { 31 return function() { 32 console.log(`Running from setTimeout ${timeout}`); 33 done.push(timeout); 34 }; 35} 36 37process.nextTick(function() { 38 console.log('Running from nextTick'); 39 done.push('nextTick'); 40}); 41 42for (i = 0; i < N; i += 1) { 43 setTimeout(get_printer(i), i); 44} 45 46console.log('Running from main.'); 47 48 49process.on('exit', function() { 50 assert.strictEqual(done[0], 'nextTick'); 51 // Disabling this test. I don't think we can ensure the order 52 // for (i = 0; i < N; i += 1) { 53 // assert.strictEqual(i, done[i + 1]); 54 // } 55}); 56