PATH:
usr
/
local
/
lib
/
node_modules
/
pm2
/
node_modules
/
continuation-local-storage
/
test
'use strict'; // stdlib var tap = require('tap'); var test = tap.test; var EventEmitter = require('events').EventEmitter; // module under test var context = require('../context.js'); // multiple contexts in use var tracer = context.createNamespace('tracer'); function Trace(harvester) { this.harvester = harvester; } Trace.prototype.runHandler = function (handler) { var trace = tracer.run(handler); this.harvester.emit('finished', trace.transaction); }; test("simple tracer built on contexts", function (t) { t.plan(6); var harvester = new EventEmitter(); var trace = new Trace(harvester); harvester.on('finished', function (transaction) { t.ok(transaction, "transaction should have been passed in"); t.equal(transaction.status, 'ok', "transaction should have finished OK"); t.equal(Object.keys(process.namespaces).length, 1, "Should only have one namespace."); }); trace.runHandler(function inScope() { t.ok(tracer.active, "tracer should have an active context"); tracer.set('transaction', {status : 'ok'}); t.ok(tracer.get('transaction'), "can retrieve newly-set value"); t.equal(tracer.get('transaction').status, 'ok', "value should be correct"); }); });
[-] bind.tap.js
[edit]
[-] zlib.tap.js
[edit]
[-] promises.tap.js
[edit]
[-] tracer-scenarios.tap.js
[edit]
[+]
..
[-] nesting.tap.js
[edit]
[-] async-no-run-queue-multiple.tap.js
[edit]
[-] monkeypatching.tap.js
[edit]
[-] crypto.tap.js
[edit]
[-] error-handling.tap.js
[edit]
[-] proper-exit.tap.js
[edit]
[-] namespaces.tap.js
[edit]
[-] bind-emitter.tap.js
[edit]
[-] run-and-return.tap.js
[edit]
[-] timers.tap.js
[edit]
[-] net-events.tap.js
[edit]
[-] interleave-contexts.tap.js
[edit]
[-] dns.tap.js
[edit]
[-] fs.tap.js
[edit]
[-] simple.tap.js
[edit]
[-] async-context.tap.js
[edit]