Skip to content

Commit

Permalink
feat(poweredBy): getWidgetRenderState (#4551)
Browse files Browse the repository at this point in the history
* feat(poweredBy): getWidgetRenderState

DX-206

* fix jsdoc
  • Loading branch information
Haroenv authored Oct 30, 2020
1 parent d53f83a commit bfd66e0
Show file tree
Hide file tree
Showing 5 changed files with 328 additions and 194 deletions.
117 changes: 0 additions & 117 deletions src/connectors/powered-by/__tests__/connectPoweredBy-test.js

This file was deleted.

221 changes: 221 additions & 0 deletions src/connectors/powered-by/__tests__/connectPoweredBy-test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,221 @@
import jsHelper from 'algoliasearch-helper';
import { createSearchClient } from '../../../../test/mock/createSearchClient';
import {
createInitOptions,
createRenderOptions,
} from '../../../../test/mock/createWidget';
import connectPoweredBy from '../connectPoweredBy';

describe('connectPoweredBy', () => {
it('throws without rendering function', () => {
expect(() => {
// @ts-expect-error
connectPoweredBy();
}).toThrowErrorMatchingInlineSnapshot(`
"The render function is not valid (received type Undefined).
See documentation: https://www.algolia.com/doc/api-reference/widgets/powered-by/js/#connector"
`);
});

it('is a widget', () => {
const render = jest.fn();
const unmount = jest.fn();

const customPoweredBy = connectPoweredBy(render, unmount);
const widget = customPoweredBy({});

expect(widget).toEqual(
expect.objectContaining({
$$type: 'ais.poweredBy',
init: expect.any(Function),
render: expect.any(Function),
dispose: expect.any(Function),
})
);
});

it('renders during init and render', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({});

widget.init!(createInitOptions());

expect(rendering).toHaveBeenCalledTimes(1);
expect(rendering).toHaveBeenCalledWith(expect.anything(), true);

widget.render!(createRenderOptions());

expect(rendering).toHaveBeenCalledTimes(2);
expect(rendering).toHaveBeenLastCalledWith(expect.anything(), false);
});

it('has a default URL at init', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({});

widget.init!(createInitOptions());

expect(rendering).toHaveBeenCalledWith(
expect.objectContaining({
url:
'https://www.algolia.com/?utm_source=instantsearch.js&utm_medium=website&utm_content=localhost&utm_campaign=poweredby',
}),
true
);
});

it('has a default URL at render', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({});

widget.render!(createRenderOptions());

expect(rendering).toHaveBeenCalledWith(
expect.objectContaining({
url:
'https://www.algolia.com/?utm_source=instantsearch.js&utm_medium=website&utm_content=localhost&utm_campaign=poweredby',
}),
false
);
});

it('can override the URL', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({
url: '#custom-url',
});

widget.init!(createInitOptions());

expect(rendering).toHaveBeenCalledWith(
expect.objectContaining({ url: '#custom-url' }),
true
);
});

it('can override the theme', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy<{ theme: string }>(rendering);
const widget = makeWidget({
theme: 'dark',
});

widget.init!(createInitOptions());

expect(rendering).toHaveBeenCalledWith(
expect.objectContaining({ widgetParams: { theme: 'dark' } }),
true
);
});

it('does not throw without the unmount function', () => {
const rendering = () => {};
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({});
const helper = jsHelper(createSearchClient(), '');
expect(() =>
widget.dispose!({ helper, state: helper.state })
).not.toThrow();
});

describe('getWidgetRenderState', () => {
it('uses a default url', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({});

expect(widget.getWidgetRenderState(createInitOptions())).toEqual({
url:
'https://www.algolia.com/?utm_source=instantsearch.js&utm_medium=website&utm_content=localhost&utm_campaign=poweredby',
widgetParams: {},
});
});

it('uses a custom url', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({
url: 'hello-world',
});

expect(widget.getWidgetRenderState(createInitOptions())).toEqual({
url: 'hello-world',
widgetParams: {
url: 'hello-world',
},
});
});

it('forwards unknown widget parameters', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy<{ theme: string }>(rendering);
const widget = makeWidget({
theme: 'dark',
});

expect(widget.getWidgetRenderState(createInitOptions())).toEqual({
url:
'https://www.algolia.com/?utm_source=instantsearch.js&utm_medium=website&utm_content=localhost&utm_campaign=poweredby',
widgetParams: {
theme: 'dark',
},
});
});
});

describe('getRenderState', () => {
it('uses a default url', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({});

expect(widget.getRenderState({}, createInitOptions())).toEqual({
poweredBy: {
url:
'https://www.algolia.com/?utm_source=instantsearch.js&utm_medium=website&utm_content=localhost&utm_campaign=poweredby',
widgetParams: {},
},
});
});

it('uses a custom url', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy(rendering);
const widget = makeWidget({
url: 'hello-world',
});

expect(widget.getRenderState({}, createInitOptions())).toEqual({
poweredBy: {
url: 'hello-world',
widgetParams: {
url: 'hello-world',
},
},
});
});

it('forwards unknown widget parameters', () => {
const rendering = jest.fn();
const makeWidget = connectPoweredBy<{ theme: string }>(rendering);
const widget = makeWidget({
theme: 'dark',
});

expect(widget.getRenderState({}, createInitOptions())).toEqual({
poweredBy: {
url:
'https://www.algolia.com/?utm_source=instantsearch.js&utm_medium=website&utm_content=localhost&utm_campaign=poweredby',
widgetParams: {
theme: 'dark',
},
},
});
});
});
});
Loading

0 comments on commit bfd66e0

Please sign in to comment.