import { e2e } from '../utils'; const PANEL_UNDER_TEST = 'Value reducers 1'; describe('Inspect drawer tests', () => { beforeEach(() => { e2e.flows.login(Cypress.env('USERNAME'), Cypress.env('PASSWORD')); }); it('Tests various Inspect Drawer scenarios', () => { // @ts-ignore some typing issue cy.on('uncaught:exception', (err) => { if (err.stack?.indexOf("TypeError: Cannot read property 'getText' of null") !== -1) { // On occasion monaco editor will not have the time to be properly unloaded when we change the tab // and then the e2e test fails with the uncaught:exception: // TypeError: Cannot read property 'getText' of null // at Object.ai [as getFoldingRanges] (http://localhost:3001/public/build/monaco-json.worker.js:2:215257) // at e.getFoldingRanges (http://localhost:3001/public/build/monaco-json.worker.js:2:221188) // at e.fmr (http://localhost:3001/public/build/monaco-json.worker.js:2:116605) // at e._handleMessage (http://localhost:3001/public/build/monaco-json.worker.js:2:7414) // at Object.handleMessage (http://localhost:3001/public/build/monaco-json.worker.js:2:7018) // at e._handleMessage (http://localhost:3001/public/build/monaco-json.worker.js:2:5038) // at e.handleMessage (http://localhost:3001/public/build/monaco-json.worker.js:2:4606) // at e.onmessage (http://localhost:3001/public/build/monaco-json.worker.js:2:7097) // at Tt.self.onmessage (http://localhost:3001/public/build/monaco-json.worker.js:2:117109) // return false to prevent the error from // failing this test return false; } return true; }); e2e.flows.openDashboard({ uid: 'wfTJJL5Wz' }); // testing opening inspect drawer directly by clicking on Inspect in header menu e2e.flows.openPanelMenuItem(e2e.flows.PanelMenuItems.Inspect, PANEL_UNDER_TEST); expectDrawerTabsAndContent(); expectDrawerClose(); expectSubMenuScenario('Data'); expectSubMenuScenario('Query'); expectSubMenuScenario('Panel JSON', 'JSON'); e2e.flows.openPanelMenuItem(e2e.flows.PanelMenuItems.Edit, PANEL_UNDER_TEST); e2e.components.QueryTab.queryInspectorButton().should('be.visible').click(); e2e.components.Drawer.General.title(`Inspect: ${PANEL_UNDER_TEST}`) .should('be.visible') .within(() => { e2e.components.Tab.title('Query').should('be.visible'); // query should be the active tab e2e.components.Tab.active().should('have.text', 'Query'); }); e2e.components.PanelInspector.Query.content().should('be.visible'); }); }); const expectDrawerTabsAndContent = () => { e2e.components.Drawer.General.title(`Inspect: ${PANEL_UNDER_TEST}`) .should('be.visible') .within(() => { e2e.components.Tab.title('Data').should('be.visible'); // data should be the active tab e2e.components.Tab.active().within((li: JQuery) => { expect(li.text()).equals('Data'); }); e2e.components.PanelInspector.Data.content().should('be.visible'); e2e.components.PanelInspector.Stats.content().should('not.exist'); e2e.components.PanelInspector.Json.content().should('not.exist'); e2e.components.PanelInspector.Query.content().should('not.exist'); // other tabs should also be visible, click on each to see if we get any console errors e2e.components.Tab.title('Stats').should('be.visible').click(); e2e.components.PanelInspector.Stats.content().should('be.visible'); e2e.components.PanelInspector.Data.content().should('not.exist'); e2e.components.PanelInspector.Json.content().should('not.exist'); e2e.components.PanelInspector.Query.content().should('not.exist'); e2e.components.Tab.title('JSON').should('be.visible').click(); e2e.components.PanelInspector.Json.content().should('be.visible'); e2e.components.PanelInspector.Data.content().should('not.exist'); e2e.components.PanelInspector.Stats.content().should('not.exist'); e2e.components.PanelInspector.Query.content().should('not.exist'); e2e.components.Tab.title('Query').should('be.visible').click(); e2e.components.PanelInspector.Query.content().should('be.visible'); e2e.components.PanelInspector.Data.content().should('not.exist'); e2e.components.PanelInspector.Stats.content().should('not.exist'); e2e.components.PanelInspector.Json.content().should('not.exist'); }); }; const expectDrawerClose = () => { // close using close button e2e.components.Drawer.General.close().click(); e2e.components.Drawer.General.title(`Inspect: ${PANEL_UNDER_TEST}`).should('not.exist'); }; const expectSubMenuScenario = (subMenu: string, tabTitle?: string) => { tabTitle = tabTitle ?? subMenu; // testing opening inspect drawer from sub menus under Inspect in header menu e2e.components.Panels.Panel.title(PANEL_UNDER_TEST).scrollIntoView().should('be.visible'); e2e.components.Panels.Panel.menu(PANEL_UNDER_TEST).click({ force: true }); // force click because menu is hidden and show on hover // sub menus are in the DOM but not visible and because there is no hover support in Cypress force click // https://github.com/cypress-io/cypress-example-recipes/blob/master/examples/testing-dom__hover-hidden-elements/cypress/integration/hover-hidden-elements-spec.js // simulate hover on Inspector menu item to display sub menus e2e.components.Panels.Panel.menuItems('Inspect').trigger('mouseover', { force: true }); e2e.components.Panels.Panel.menuItems(subMenu).click({ force: true }); // data should be the default tab e2e.components.Tab.title(tabTitle).should('be.visible'); e2e.components.Tab.active().should('have.text', tabTitle); expectDrawerClose(); };