2019-03-01 21:31:36 +01:00
|
|
|
'use strict';
|
|
|
|
require('../common');
|
|
|
|
const assert = require('assert');
|
|
|
|
const { AsyncLocalStorage } = require('async_hooks');
|
|
|
|
|
|
|
|
const asyncLocalStorage = new AsyncLocalStorage();
|
|
|
|
|
2020-02-24 13:00:59 +03:00
|
|
|
asyncLocalStorage.runSyncAndReturn(new Map(), () => {
|
2019-03-01 21:31:36 +01:00
|
|
|
asyncLocalStorage.getStore().set('foo', 'bar');
|
|
|
|
process.nextTick(() => {
|
|
|
|
assert.strictEqual(asyncLocalStorage.getStore().get('foo'), 'bar');
|
2020-02-28 10:07:47 +03:00
|
|
|
process.nextTick(() => {
|
|
|
|
assert.strictEqual(asyncLocalStorage.getStore(), undefined);
|
|
|
|
});
|
2020-03-04 14:57:56 +03:00
|
|
|
|
2019-03-01 21:31:36 +01:00
|
|
|
asyncLocalStorage.disable();
|
|
|
|
assert.strictEqual(asyncLocalStorage.getStore(), undefined);
|
2020-03-04 14:57:56 +03:00
|
|
|
|
|
|
|
// Calls to exit() should not mess with enabled status
|
|
|
|
asyncLocalStorage.exit(() => {
|
|
|
|
assert.strictEqual(asyncLocalStorage.getStore(), undefined);
|
|
|
|
});
|
|
|
|
assert.strictEqual(asyncLocalStorage.getStore(), undefined);
|
|
|
|
|
2019-03-01 21:31:36 +01:00
|
|
|
process.nextTick(() => {
|
|
|
|
assert.strictEqual(asyncLocalStorage.getStore(), undefined);
|
2020-02-24 13:00:59 +03:00
|
|
|
asyncLocalStorage.runSyncAndReturn(new Map(), () => {
|
2019-03-01 21:31:36 +01:00
|
|
|
assert.notStrictEqual(asyncLocalStorage.getStore(), undefined);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|