@thoughtspot/visual-embed-sdk
Version:
ThoughtSpot Embed SDK
164 lines • 10.6 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const react_1 = tslib_1.__importDefault(require("react"));
require("@testing-library/jest-dom");
require("@testing-library/jest-dom/extend-expect");
const react_2 = require("@testing-library/react");
const types_1 = require("../types");
const test_utils_1 = require("../test/test-utils");
const index_1 = require("./index");
const allExports = tslib_1.__importStar(require("./index"));
const index_2 = require("../index");
const package_json_1 = require("../../package.json");
const auth = tslib_1.__importStar(require("../auth"));
const sessionService = tslib_1.__importStar(require("../utils/sessionInfoService"));
const thoughtSpotHost = 'localhost';
beforeAll(() => {
(0, index_2.init)({
thoughtSpotHost,
authType: index_2.AuthType.None,
});
jest.spyOn(auth, 'postLoginService').mockReturnValue(true);
jest.spyOn(sessionService, 'getSessionInfo').mockReturnValue({
userGUID: 'abcd',
});
spyOn(window, 'alert');
});
describe('React Components', () => {
describe('SearchEmbed', () => {
it('Should Render the Iframe with props', async () => {
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.SearchEmbed, { hideDataSources: true, className: "embedClass" }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
expect((0, test_utils_1.getIFrameEl)(container).parentElement.classList.contains('embedClass')).toBe(true);
expect((0, test_utils_1.getIFrameSrc)(container)).toBe(`http://${thoughtSpotHost}/?embedApp=true&hostAppUrl=local-host&viewPortHeight=768&viewPortWidth=1024&sdkVersion=${package_json_1.version}&authType=None&blockNonEmbedFullAppAccess=true&hideAction=[%22${types_1.Action.ReportError}%22,%22editACopy%22,%22saveAsView%22,%22updateTSL%22,%22editTSL%22,%22onDeleteAnswer%22]&preAuthCache=true&overrideConsoleLogs=true&clientLogLevel=ERROR&enableDataPanelV2=false&dataSourceMode=hide&useLastSelectedSources=false&isSearchEmbed=true&collapseSearchBarInitially=true&enableCustomColumnGroups=false&dataPanelCustomGroupsAccordionInitialState=EXPAND_ALL#/embed/answer`);
});
it('Should attach event listeners', async (done) => {
const userGUID = 'absfdfgd';
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.SearchEmbed, { onInit: (e) => {
expect(e.data).toHaveProperty('timestamp');
}, onAuthInit: (e) => {
expect(e.data.userGUID).toEqual(userGUID);
done();
} }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
const iframe = (0, test_utils_1.getIFrameEl)(container);
(0, test_utils_1.postMessageToParent)(iframe.contentWindow, {
type: types_1.EmbedEvent.AuthInit,
data: {
userGUID,
},
});
});
});
describe('AppEmbed', () => {
//
});
describe('LiveboardEmbed', () => {
//
it('Should be able to trigger events on the embed using refs', async () => {
(0, test_utils_1.mockMessageChannel)();
const TestComponent = () => {
const embedRef = (0, index_1.useEmbedRef)();
const onLiveboardRendered = () => {
embedRef.current.trigger(types_1.HostEvent.SetVisibleVizs, ['viz1', 'viz2']);
};
return (react_1.default.createElement(index_1.LiveboardEmbed, { ref: embedRef, liveboardId: "abcd", onLiveboardRendered: onLiveboardRendered }));
};
const { container } = (0, react_2.render)(react_1.default.createElement(TestComponent, null));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
const iframe = (0, test_utils_1.getIFrameEl)(container);
jest.spyOn(iframe.contentWindow, 'postMessage');
(0, test_utils_1.postMessageToParent)(iframe.contentWindow, {
type: types_1.EmbedEvent.LiveboardRendered,
data: {
userGUID: 'abcd',
},
});
await (0, test_utils_1.executeAfterWait)(() => {
expect(iframe.contentWindow.postMessage).toHaveBeenCalledWith({
type: types_1.HostEvent.SetVisibleVizs,
data: ['viz1', 'viz2'],
}, `http://${thoughtSpotHost}`, expect.anything());
});
});
it('Should render liveboard with runtime filters', async () => {
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.LiveboardEmbed, { liveboardId: "abcd", runtimeFilters: [
{
columnName: 'revenue',
operator: types_1.RuntimeFilterOp.EQ,
values: [100],
},
], excludeRuntimeFiltersfromURL: false }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
expect((0, test_utils_1.getIFrameSrc)(container)).toContain('col1=revenue&op1=EQ&val1=100');
});
it('Should have the correct container element', async () => {
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.LiveboardEmbed, { liveboardId: "abcd", className: "def" }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
expect(container.querySelector('div')).not.toBe(null);
expect(container.querySelector('div').classList.contains('def')).toBe(true);
const { container: containerSibling } = (0, react_2.render)(react_1.default.createElement(index_1.LiveboardEmbed, { liveboardId: "abcd", className: "def", insertAsSibling: true }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(containerSibling));
expect(containerSibling.querySelector('span')).not.toBe(null);
expect(containerSibling.querySelector('span').style.position).toBe('absolute');
expect((0, test_utils_1.getIFrameEl)(containerSibling).classList.contains('def')).toBe(true);
expect(containerSibling.querySelector('div')).toBe(null);
});
it('Should have the correct container element', async () => {
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.LiveboardEmbed, { liveboardId: "abcd", className: "def" }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
expect(container.querySelector('div')).not.toBe(null);
expect(container.querySelector('div').classList.contains('def')).toBe(true);
const { container: containerSibling } = (0, react_2.render)(react_1.default.createElement(index_1.LiveboardEmbed, { liveboardId: "abcd", className: "def", insertAsSibling: true }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(containerSibling));
expect(containerSibling.querySelector('span')).not.toBe(null);
expect(containerSibling.querySelector('span').style.position).toBe('absolute');
expect((0, test_utils_1.getIFrameEl)(containerSibling).classList.contains('def')).toBe(true);
expect(containerSibling.querySelector('div')).toBe(null);
});
});
describe('SearchBarEmbed', () => {
it('Should Render the Iframe with props', async () => {
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.SearchBarEmbed, { className: "embedClass", dataSource: 'test', searchOptions: {
searchTokenString: '[revenue]',
executeSearch: true,
} }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)(container));
expect((0, test_utils_1.getIFrameEl)(container).parentElement.classList.contains('embedClass')).toBe(true);
expect((0, test_utils_1.getIFrameSrc)(container)).toBe(`http://${thoughtSpotHost}/?embedApp=true&hostAppUrl=local-host&viewPortHeight=768&viewPortWidth=1024&sdkVersion=${package_json_1.version}&authType=None&blockNonEmbedFullAppAccess=true&hideAction=[%22${types_1.Action.ReportError}%22]&preAuthCache=true&overrideConsoleLogs=true&clientLogLevel=ERROR&dataSources=[%22test%22]&searchTokenString=%5Brevenue%5D&executeSearch=true&useLastSelectedSources=false&isSearchEmbed=true#/embed/search-bar-embed`);
});
});
describe('PreRenderedLiveboardEmbed', () => {
it('should preRender the liveboard ', async () => {
const preRenderId = 'tsEmbed-pre-render-wrapper-test';
const { container } = (0, react_2.render)(react_1.default.createElement(index_1.PreRenderedLiveboardEmbed, { className: "embedClass", preRenderId: "test", liveboardId: "libId" }));
await (0, react_2.waitFor)(() => (0, test_utils_1.getIFrameEl)());
const preRenderWrapper = document.body.querySelector(`#${preRenderId}`);
expect(preRenderWrapper).toBeInstanceOf(HTMLDivElement);
expect(preRenderWrapper.childElementCount).toBe(1);
const preRenderChildId = 'tsEmbed-pre-render-child-test';
const preRenderChild = document.body.querySelector(`#${preRenderChildId}`);
expect(preRenderWrapper.children[0]).toBe(preRenderChild);
window.ResizeObserver = jest.fn().mockImplementation(() => ({
disconnect: jest.fn(),
observe: jest.fn(),
unobserve: jest.fn(),
}));
const { container: libContainer } = (0, react_2.render)(react_1.default.createElement(index_1.LiveboardEmbed, { className: "embedClass", preRenderId: "test", liveboardId: "libId" }));
expect(preRenderWrapper.style.opacity).toBe('');
expect(preRenderWrapper.style.pointerEvents).toBe('');
expect(preRenderWrapper.style.zIndex).toBe('');
});
});
});
describe('allExports', () => {
it('should have exports', () => {
expect(typeof allExports).toBe('object');
});
it('should not have undefined exports', () => {
Object.keys(allExports).forEach((exportKey) => expect(Boolean(allExports[exportKey]))
.toBe(true));
});
});
//# sourceMappingURL=index.spec.js.map