| 'use strict'; |
| |
| const common = require('../common'); |
| const assert = require('assert'); |
| const tick = require('./tick'); |
| const initHooks = require('./init-hooks'); |
| const { checkInvocations } = require('./hook-checks'); |
| |
| const hooks = initHooks(); |
| hooks.enable(); |
| |
| // install first immediate |
| setImmediate(common.mustCall(onimmediate)); |
| |
| const as = hooks.activitiesOfTypes('Immediate'); |
| assert.strictEqual(as.length, 1); |
| const imd1 = as[0]; |
| assert.strictEqual(imd1.type, 'Immediate'); |
| assert.strictEqual(typeof imd1.uid, 'number'); |
| assert.strictEqual(typeof imd1.triggerAsyncId, 'number'); |
| checkInvocations(imd1, { init: 1 }, |
| 'imd1: when first set immediate installed'); |
| |
| let imd2; |
| |
| function onimmediate() { |
| let as = hooks.activitiesOfTypes('Immediate'); |
| assert.strictEqual(as.length, 1); |
| checkInvocations(imd1, { init: 1, before: 1 }, |
| 'imd1: when first set immediate triggered'); |
| |
| // install second immediate |
| setImmediate(common.mustCall(onimmediateTwo)); |
| as = hooks.activitiesOfTypes('Immediate'); |
| assert.strictEqual(as.length, 2); |
| imd2 = as[1]; |
| assert.strictEqual(imd2.type, 'Immediate'); |
| assert.strictEqual(typeof imd2.uid, 'number'); |
| assert.strictEqual(typeof imd2.triggerAsyncId, 'number'); |
| checkInvocations(imd1, { init: 1, before: 1 }, |
| 'imd1: when second set immediate installed'); |
| checkInvocations(imd2, { init: 1 }, |
| 'imd2: when second set immediate installed'); |
| } |
| |
| function onimmediateTwo() { |
| checkInvocations(imd1, { init: 1, before: 1, after: 1, destroy: 1 }, |
| 'imd1: when second set immediate triggered'); |
| checkInvocations(imd2, { init: 1, before: 1 }, |
| 'imd2: when second set immediate triggered'); |
| tick(1); |
| } |
| |
| process.on('exit', onexit); |
| |
| function onexit() { |
| hooks.disable(); |
| hooks.sanityCheck('Immediate'); |
| checkInvocations(imd1, { init: 1, before: 1, after: 1, destroy: 1 }, |
| 'imd1: when process exits'); |
| checkInvocations(imd2, { init: 1, before: 1, after: 1, destroy: 1 }, |
| 'imd2: when process exits'); |
| } |