Blame view
node_modules/continuation-local-storage/test/timers.tap.js
2.07 KB
f7563de62
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
'use strict'; var tap = require('tap') , test = tap.test , createNamespace = require('../context.js').createNamespace ; test("continuation-local state with timers", function (t) { t.plan(4); var namespace = createNamespace('namespace'); namespace.run(function () { namespace.set('test', 0xabad1dea); t.test("process.nextTick", function (t) { namespace.run(function () { namespace.set('test', 31337); t.equal(namespace.get('test'), 31337, "state has been mutated"); process.nextTick(function () { t.equal(namespace.get('test'), 31337, "mutated state has persisted to process.nextTick's callback"); t.end(); }); }); }); t.test("setImmediate", function (t) { // setImmediate only in Node > 0.9.x if (!global.setImmediate) return t.end(); namespace.run(function () { namespace.set('test', 999); t.equal(namespace.get('test'), 999, "state has been mutated"); setImmediate(function () { t.equal(namespace.get('test'), 999, "mutated state has persisted to setImmediate's callback"); t.end(); }); }); }); t.test("setTimeout", function (t) { namespace.run(function () { namespace.set('test', 54321); t.equal(namespace.get('test'), 54321, "state has been mutated"); setTimeout(function () { t.equal(namespace.get('test'), 54321, "mutated state has persisted to setTimeout's callback"); t.end(); }); }); }); t.test("setInterval", function (t) { namespace.run(function () { namespace.set('test', 10101); t.equal(namespace.get('test'), 10101, "continuation-local state has been mutated"); var ref = setInterval(function () { t.equal(namespace.get('test'), 10101, "mutated state has persisted to setInterval's callback"); clearInterval(ref); t.end(); }, 20); }); }); }); }); |