12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- '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);
- });
- });
- });
- });
|