mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
4f3cf4e89a
PR-URL: https://github.com/nodejs/node/pull/51915 Reviewed-By: Yagiz Nizipli <yagiz.nizipli@sentry.io> Reviewed-By: Gerhard Stöbich <deb2001-github@yahoo.de> Reviewed-By: Chengzhong Wu <legendecas@gmail.com>
42 lines
992 B
JavaScript
42 lines
992 B
JavaScript
'use strict';
|
|
|
|
const common = require('../common');
|
|
const dc = require('diagnostics_channel');
|
|
const assert = require('assert');
|
|
|
|
const channel = dc.tracingChannel('test');
|
|
|
|
const expectedResult = { foo: 'bar' };
|
|
const input = { foo: 'bar' };
|
|
const thisArg = { baz: 'buz' };
|
|
|
|
function check(found) {
|
|
assert.deepStrictEqual(found, input);
|
|
}
|
|
|
|
function checkAsync(found) {
|
|
check(found);
|
|
assert.strictEqual(found.error, undefined);
|
|
assert.deepStrictEqual(found.result, expectedResult);
|
|
}
|
|
|
|
const handlers = {
|
|
start: common.mustCall(check),
|
|
end: common.mustCall(check),
|
|
asyncStart: common.mustCall(checkAsync),
|
|
asyncEnd: common.mustCall(checkAsync),
|
|
error: common.mustNotCall()
|
|
};
|
|
|
|
channel.subscribe(handlers);
|
|
|
|
channel.tracePromise(function(value) {
|
|
assert.deepStrictEqual(this, thisArg);
|
|
return Promise.resolve(value);
|
|
}, input, thisArg, expectedResult).then(
|
|
common.mustCall((value) => {
|
|
assert.deepStrictEqual(value, expectedResult);
|
|
}),
|
|
common.mustNotCall()
|
|
);
|