feat(singleton-manager): add node/ssr support

This commit is contained in:
Thijs Louisse 2023-11-21 11:01:26 +01:00 committed by GitHub
parent 64a1b65c98
commit ef9b1e4c52
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 63 additions and 37 deletions

View file

@ -0,0 +1,5 @@
---
'singleton-manager': patch
---
add node/ssr support

View file

@ -35,6 +35,7 @@
"start:singleton": "es-dev-server -c demo/singleton/server.js",
"start:singleton-complex": "es-dev-server -c demo/singleton-complex/server.js",
"test": "cd ../../ && npm run test:browser -- --group singleton-manager",
"test:node": "mocha test-node",
"types": "wireit"
},
"keywords": [

View file

@ -1,9 +1,18 @@
const sym = Symbol.for('lion::SingletonManagerClassStorage');
/**
* Allow compatibility with node-js (for ssr).
* In the future, we can just use globalThis directly
* (for now, we're backwards compatible with browsers that still only use window, since we don't know all contexts singleton-manager is used in).
*/
// eslint-disable-next-line no-undef
const globalThisOrWindow = globalThis || window;
export class SingletonManagerClass {
constructor() {
/** @protected */
this._map = window[sym] ? window[sym] : (window[sym] = new Map());
this._map = globalThisOrWindow[sym]
? globalThisOrWindow[sym]
: (globalThisOrWindow[sym] = new Map());
}
/**

View file

@ -0,0 +1,4 @@
import { expect } from 'chai';
import { runSingletonManagerClassSuite } from '../test-suites/runSingletonManagerClassSuite.suite.js';
runSingletonManagerClassSuite({ expect });

View file

@ -0,0 +1,39 @@
import { SingletonManagerClass } from 'singleton-manager';
/**
* @param {{expect: function}} config
*/
export function runSingletonManagerClassSuite({ expect }) {
describe('SingletonManagerClass', () => {
it('returns undefined and has false if not set', async () => {
const mngr = new SingletonManagerClass();
expect(mngr.get('overlays/overlays.js::0.13.x')).to.be.undefined;
expect(mngr.has('overlays/overlays.js::0.13.x')).to.be.false;
});
it('return value and has true if set', () => {
const mngr = new SingletonManagerClass();
mngr.set('overlays/overlays.js::0.13.x', 'is-set');
expect(mngr.get('overlays/overlays.js::0.13.x')).to.equal('is-set');
expect(mngr.has('overlays/overlays.js::0.13.x')).to.be.true;
// make sure non set values are still correct
expect(mngr.get('overlays/overlays.js::0.14.x')).to.be.undefined;
expect(mngr.has('overlays/overlays.js::0.14.x')).to.be.false;
});
it('does not override existing keys (e.g. subsequential calls for the same keys are ignored)', () => {
const mngr = new SingletonManagerClass();
mngr.set('overlays/overlays.js::0.14.x', 'is-set');
mngr.set('overlays/overlays.js::0.14.x', 'new-set');
expect(mngr.get('overlays/overlays.js::0.14.x')).to.equal('is-set');
});
it('should return the same value with two SingletonManager instances', () => {
const mngr1 = new SingletonManagerClass();
const mngr2 = new SingletonManagerClass();
mngr1.set('overlays/overlays.js::0.15.x', 'is-set');
expect(mngr2.get('overlays/overlays.js::0.15.x')).to.equal('is-set');
});
});
}

View file

@ -1,36 +1,4 @@
import { expect } from '@open-wc/testing';
import { runSingletonManagerClassSuite } from '../test-suites/runSingletonManagerClassSuite.suite.js';
import { SingletonManagerClass } from 'singleton-manager';
describe('SingletonManagerClass', () => {
it('returns undefined and has false if not set', async () => {
const mngr = new SingletonManagerClass();
expect(mngr.get('overlays/overlays.js::0.13.x')).to.be.undefined;
expect(mngr.has('overlays/overlays.js::0.13.x')).to.be.false;
});
it('return value and has true if set', () => {
const mngr = new SingletonManagerClass();
mngr.set('overlays/overlays.js::0.13.x', 'is-set');
expect(mngr.get('overlays/overlays.js::0.13.x')).to.equal('is-set');
expect(mngr.has('overlays/overlays.js::0.13.x')).to.be.true;
// make sure non set values are still correct
expect(mngr.get('overlays/overlays.js::0.14.x')).to.be.undefined;
expect(mngr.has('overlays/overlays.js::0.14.x')).to.be.false;
});
it('does not override existing keys (e.g. subsequential calls for the same keys are ignored)', () => {
const mngr = new SingletonManagerClass();
mngr.set('overlays/overlays.js::0.14.x', 'is-set');
mngr.set('overlays/overlays.js::0.14.x', 'new-set');
expect(mngr.get('overlays/overlays.js::0.14.x')).to.equal('is-set');
});
it('should return the same value with two SingletonManager instances', () => {
const mngr1 = new SingletonManagerClass();
const mngr2 = new SingletonManagerClass();
mngr1.set('overlays/overlays.js::0.15.x', 'is-set');
expect(mngr2.get('overlays/overlays.js::0.15.x')).to.equal('is-set');
});
});
runSingletonManagerClassSuite({ expect });

View file

@ -2,8 +2,8 @@
"extends": "../../tsconfig.json",
"compilerOptions": {
"outDir": "./dist-types",
"rootDir": ".",
"rootDir": "."
},
"include": ["src", "test", "types"],
"include": ["src", "test", "test-node", "test-suites", "types"],
"exclude": ["dist-types"]
}