Skip to content

Commit

Permalink
chore: add error for incorrect load function (#591)
Browse files Browse the repository at this point in the history
  • Loading branch information
Caele authored Mar 31, 2021
1 parent 87a172b commit bb6f647
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 0 deletions.
10 changes: 10 additions & 0 deletions apis/nucleus/src/sn/__tests__/load.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,16 @@ describe('load', () => {
clearFromCache('pie');
});

it('should throw when load is not a function', async () => {
const loader = { then: {} }; // fake promise
try {
await load('pie', '1.0.0', halo, loader);
expect(0).to.equal(1);
} catch (e) {
expect(e.message).to.equal(`load of visualization 'pie v1.0.0' is not a fuction, wrap load promise in function`);
}
});

it('should throw when resolving to a falsy value', async () => {
const loader = () => false;
try {
Expand Down
3 changes: 3 additions & 0 deletions apis/nucleus/src/sn/load.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,9 @@ export async function load(name, version, { config }, loader) {
const key = `${name}__${version}`;
if (!LOADED[key]) {
const sKey = `${name}${(version && ` v${version}`) || ''}`;
if (loader && typeof loader !== 'function') {
throw new Error(`load of visualization '${sKey}' is not a fuction, wrap load promise in function`);
}
const p = (loader || config.load)({
name,
version,
Expand Down

0 comments on commit bb6f647

Please sign in to comment.