From 0189b3ca17d904e89819615d138955d3f2ef6d1b Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Mon, 28 Mar 2022 01:02:21 -0700 Subject: [PATCH 1/7] add new test for dependent filter --- .../dashboard/nativeFilters.test.ts | 94 +++++++++++++++++-- superset-frontend/package-lock.json | 2 +- 2 files changed, 85 insertions(+), 11 deletions(-) diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts index 433b4a65e33cb..5063b50f710fc 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts @@ -22,7 +22,11 @@ import { nativeFilters, exploreView, } from 'cypress/support/directories'; -import { testItems } from './dashboard.helper'; +import { + testItems, + WORLD_HEALTH_CHARTS, + waitForChartLoad, +} from './dashboard.helper'; import { DASHBOARD_LIST } from '../dashboard_list/dashboard_list.helper'; import { CHART_LIST } from '../chart_list/chart_list.helper'; import { FORM_DATA_DEFAULTS } from '../explore/visualizations/shared.helper'; @@ -390,15 +394,6 @@ describe('Nativefilters Sanity test', () => { cy.get('.line').within(() => { cy.contains('United States').should('be.visible'); }); - - // clean up the default setting - cy.get(nativeFilters.filterFromDashboardView.expand).click({ force: true }); - cy.get(nativeFilters.filterFromDashboardView.createFilterButton).click(); - cy.contains('Filter has default value').click(); - cy.get(nativeFilters.modal.footer) - .find(nativeFilters.modal.saveButton) - .should('be.visible') - .click({ force: true }); }); it('User can create a time grain filter', () => { @@ -565,6 +560,85 @@ describe('Nativefilters Sanity test', () => { .should('be.visible', { timeout: 40000 }) .contains('country_name'); }); + it('User can create parent filters using "Values are dependent on other filters"', () => { + cy.get(nativeFilters.filterFromDashboardView.expand).click({ force: true }); + cy.get(nativeFilters.filterFromDashboardView.createFilterButton) + .should('be.visible') + .click(); + // Create Parent filter + cy.get(nativeFilters.modal.container) + .find(nativeFilters.filtersPanel.filterName) + .click({ scrollBehavior: false }) + .type('parent', { scrollBehavior: false }); + cy.get(nativeFilters.modal.container) + .find(nativeFilters.filtersPanel.datasetName) + .click({ scrollBehavior: false }) + .type('wb_health_population{enter}', { scrollBehavior: false }); + cy.get(nativeFilters.silentLoading).should('not.exist'); + cy.get(nativeFilters.filtersPanel.filterInfoInput) + .last() + .should('be.visible') + .click({ force: true }); + cy.get(nativeFilters.filtersPanel.filterInfoInput).last().type('region'); + cy.get(nativeFilters.filtersPanel.inputDropdown) + .should('be.visible', { timeout: 20000 }) + .last() + .click(); + cy.get(nativeFilters.addFilterButton.button) + .first() + .click() + .then(() => { + cy.get(nativeFilters.addFilterButton.dropdownItem) + .contains('Filter') + .click(); + }); + // Create dependent filter for parent filter + cy.get(nativeFilters.modal.container) + .find(nativeFilters.filtersPanel.filterName) + .last() + .click({ scrollBehavior: false }) + .type('country_name', { scrollBehavior: false }); + cy.get(nativeFilters.modal.container) + .find(nativeFilters.filtersPanel.datasetName) + .last() + .click({ scrollBehavior: false }) + .type('wb_health_population{enter}', { scrollBehavior: false }); + cy.get(nativeFilters.silentLoading).should('not.exist'); + cy.get(nativeFilters.filtersPanel.filterInfoInput) + .last() + .should('be.visible') + .click({ force: true }); + cy.get(nativeFilters.filtersPanel.filterInfoInput) + .last() + .should('be.visible') + .type('country_name'); + cy.get(nativeFilters.filtersPanel.inputDropdown) + .should('be.visible', { timeout: 20000 }) + .last() + .click(); + // After click dependent option, should also select parent as dependent filter + cy.get(nativeFilters.filterConfigurationSections.displayedSection).within( + () => { + cy.contains('Values are dependent on other filters') + .should('be.visible') + .click(); + cy.wait(1000); + cy.get('[aria-label="Limit type"]').contains('parent'); + }, + ); + cy.get(nativeFilters.modal.footer) + .contains('Save') + .should('be.visible') + .click(); + WORLD_HEALTH_CHARTS.forEach(waitForChartLoad); + // Verify UI have 2 filters. + cy.get(nativeFilters.filterFromDashboardView.filterName) + .contains('country_name') + .should('be.visible'); + cy.get(nativeFilters.filterFromDashboardView.filterName) + .contains('parent') + .should('be.visible'); + }); }); xdescribe('Nativefilters', () => { diff --git a/superset-frontend/package-lock.json b/superset-frontend/package-lock.json index 6fb053083fbfc..791fd867da344 100644 --- a/superset-frontend/package-lock.json +++ b/superset-frontend/package-lock.json @@ -274,7 +274,7 @@ }, "engines": { "node": "^16.9.1", - "npm": "^7.5.4" + "npm": "^7.5.4 || ^8.1.2" } }, "node_modules/@actions/core": { From 6d1ed90c595ff3394512fa99f90c53d653de4e58 Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Mon, 28 Mar 2022 08:30:21 -0700 Subject: [PATCH 2/7] fix failure --- .../integration/dashboard/nativeFilters.test.ts | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts index 5063b50f710fc..7d2d2da0e2289 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts @@ -394,6 +394,14 @@ describe('Nativefilters Sanity test', () => { cy.get('.line').within(() => { cy.contains('United States').should('be.visible'); }); + // clean up the default setting + cy.get(nativeFilters.filterFromDashboardView.expand).click({ force: true }); + cy.get(nativeFilters.filterFromDashboardView.createFilterButton).click(); + cy.contains('Filter has default value').click(); + cy.get(nativeFilters.modal.footer) + .find(nativeFilters.modal.saveButton) + .should('be.visible') + .click({ force: true }); }); it('User can create a time grain filter', () => { @@ -615,7 +623,7 @@ describe('Nativefilters Sanity test', () => { cy.get(nativeFilters.filtersPanel.inputDropdown) .should('be.visible', { timeout: 20000 }) .last() - .click(); + .click({ force: true }); // After click dependent option, should also select parent as dependent filter cy.get(nativeFilters.filterConfigurationSections.displayedSection).within( () => { From 6f11085a67534074b700b9dc1cb6a72b0e4ae29d Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Mon, 28 Mar 2022 09:49:59 -0700 Subject: [PATCH 3/7] add more fix --- .../cypress/integration/dashboard/nativeFilters.test.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts index 7d2d2da0e2289..0bd30bc129100 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts @@ -577,6 +577,7 @@ describe('Nativefilters Sanity test', () => { cy.get(nativeFilters.modal.container) .find(nativeFilters.filtersPanel.filterName) .click({ scrollBehavior: false }) + .clear() .type('parent', { scrollBehavior: false }); cy.get(nativeFilters.modal.container) .find(nativeFilters.filtersPanel.datasetName) @@ -585,7 +586,6 @@ describe('Nativefilters Sanity test', () => { cy.get(nativeFilters.silentLoading).should('not.exist'); cy.get(nativeFilters.filtersPanel.filterInfoInput) .last() - .should('be.visible') .click({ force: true }); cy.get(nativeFilters.filtersPanel.filterInfoInput).last().type('region'); cy.get(nativeFilters.filtersPanel.inputDropdown) @@ -605,6 +605,7 @@ describe('Nativefilters Sanity test', () => { .find(nativeFilters.filtersPanel.filterName) .last() .click({ scrollBehavior: false }) + .clear() .type('country_name', { scrollBehavior: false }); cy.get(nativeFilters.modal.container) .find(nativeFilters.filtersPanel.datasetName) From ccf79a240f64548ef39cef97b98b7effba226a26 Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Tue, 29 Mar 2022 09:30:48 -0700 Subject: [PATCH 4/7] add some function --- .../integration/dashboard/dashboard.helper.ts | 120 +++++++++++++++ .../dashboard/nativeFilters.test.ts | 137 ++++++------------ .../cypress-base/cypress/support/index.d.ts | 14 ++ .../cypress-base/cypress/support/index.ts | 86 +++++++++++ 4 files changed, 268 insertions(+), 89 deletions(-) diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/dashboard.helper.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/dashboard.helper.ts index 1458fc7d5982d..9822f7035952d 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/dashboard.helper.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/dashboard.helper.ts @@ -1,4 +1,9 @@ import { getChartAlias, Slice } from 'cypress/utils/vizPlugins'; +import { + dashboardView, + editDashboardView, + nativeFilters, +} from 'cypress/support/directories'; /** * Licensed to the Apache Software Foundation (ASF) under one @@ -25,7 +30,13 @@ export const testItems = { dashboard: 'Cypress Sales Dashboard', dataset: 'Vehicle Sales', chart: 'Cypress chart', + newChart: 'New Cypress Chart', + createdDashboard: 'New Dashboard', defaultNameDashboard: '[ untitled dashboard ]', + newDashboardTitle: `Test dashboard [NEW TEST]`, + bulkFirstNameDashboard: 'First Dash', + bulkSecondNameDashboard: 'Second Dash', + worldBanksDataCopy: `World Bank's Data [copy]`, }; export const CHECK_DASHBOARD_FAVORITE_ENDPOINT = @@ -133,3 +144,112 @@ export function resize(selector: string) { }, }; } + +export function cleanUp() { + cy.deleteDashboardByName(testItems.dashboard); + cy.deleteDashboardByName(testItems.defaultNameDashboard); + cy.deleteDashboardByName(''); + cy.deleteDashboardByName(testItems.newDashboardTitle); + cy.deleteDashboardByName(testItems.bulkFirstNameDashboard); + cy.deleteDashboardByName(testItems.bulkSecondNameDashboard); + cy.deleteDashboardByName(testItems.createdDashboard); + cy.deleteDashboardByName(testItems.worldBanksDataCopy); + cy.deleteChartByName(testItems.chart); + cy.deleteChartByName(testItems.newChart); +} + +/** ************************************************************************ + * Clicks on new filter button + * @returns {None} + * @summary helper for adding new filter + ************************************************************************* */ +export function clickOnAddFilterInModal() { + return cy + .get(nativeFilters.addFilterButton.button) + .first() + .click() + .then(() => { + cy.get(nativeFilters.addFilterButton.dropdownItem) + .contains('Filter') + .click({ force: true }); + }); +} + +/** ************************************************************************ + * Fills value native filter form with basic information + * @param {string} name name for filter + * @param {string} dataset which dataset should be used + * @param {string} filterColumn which column should be used + * @returns {None} + * @summary helper for filling value native filter form + ************************************************************************* */ +export function fillValueNativeFilterForm( + name: string, + dataset: string, + filterColumn: string, +) { + cy.get(nativeFilters.modal.container) + .find(nativeFilters.filtersPanel.filterName) + .last() + .click({ scrollBehavior: false }) + .type(name, { scrollBehavior: false }); + cy.get(nativeFilters.modal.container) + .find(nativeFilters.filtersPanel.datasetName) + .last() + .click({ scrollBehavior: false }) + .type(`${dataset}{enter}`, { scrollBehavior: false }); + cy.get(nativeFilters.silentLoading).should('not.exist'); + cy.get(nativeFilters.filtersPanel.filterInfoInput) + .last() + .should('be.visible') + .click({ force: true }); + cy.get(nativeFilters.filtersPanel.filterInfoInput).last().type(filterColumn); + cy.get(nativeFilters.filtersPanel.inputDropdown) + .should('be.visible', { timeout: 20000 }) + .last() + .click(); +} +/** ************************************************************************ + * Get native filter placeholder e.g 9 options + * @param {number} index which input it fills + * @returns cy object for assertions + * @summary helper for getting placeholder value + ************************************************************************* */ +export function getNativeFilterPlaceholderWithIndex(index: number) { + return cy.get(nativeFilters.filtersPanel.columnEmptyInput).eq(index); +} + +/** ************************************************************************ + * Apply native filter value from dashboard view + * @param {number} index which input it fills + * @param {string} value what is filter value + * @returns {null} + * @summary put value to nth native filter input in view + ************************************************************************* */ +export function applyNativeFilterValueWithIndex(index: number, value: string) { + cy.get(nativeFilters.filterFromDashboardView.filterValueInput) + .eq(index) + .parent() + .should('be.visible', { timeout: 10000 }) + .type(`${value}{enter}`); + // click the title to dismiss shown options + cy.get(nativeFilters.filterFromDashboardView.filterName).eq(index).click(); +} + +/** ************************************************************************ + * Fills parent filter input + * @param {number} index which input it fills + * @param {string} value on which filter it depends on + * @returns {null} + * @summary takes first or second input and modify the depends on filter value + ************************************************************************* */ +export function addParentFilterWithValue(index: number, value: string) { + return cy + .get(nativeFilters.filterConfigurationSections.displayedSection) + .within(() => { + cy.get('input[aria-label="Limit type"]') + .eq(index) + .click({ force: true }) + .type(`${value}{enter}`, { delay: 30, force: true }); + }); +} diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts index 0bd30bc129100..78e872a62b22a 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts @@ -23,9 +23,15 @@ import { exploreView, } from 'cypress/support/directories'; import { + cleanUp, testItems, WORLD_HEALTH_CHARTS, waitForChartLoad, + clickOnAddFilterInModal, + fillValueNativeFilterForm, + getNativeFilterPlaceholderWithIndex, + addParentFilterWithValue, + applyNativeFilterValueWithIndex, } from './dashboard.helper'; import { DASHBOARD_LIST } from '../dashboard_list/dashboard_list.helper'; import { CHART_LIST } from '../chart_list/chart_list.helper'; @@ -43,21 +49,26 @@ const milliseconds = new Date().getTime(); const dashboard = `Test Dashboard${milliseconds}`; describe('Nativefilters Sanity test', () => { - before(() => { + beforeEach(() => { cy.login(); + cleanUp(); cy.intercept('/api/v1/dashboard/?q=**').as('dashboardsList'); cy.intercept('POST', '**/copy_dash/*').as('copy'); cy.intercept('/api/v1/dashboard/*').as('dashboard'); - cy.request( - 'api/v1/dashboard/?q=(order_column:changed_on_delta_humanized,order_direction:desc,page:0,page_size:100)', - ).then(xhr => { - const dashboards = xhr.body.result; + cy.intercept('GET', '**/api/v1/dataset/**').as('datasetLoad'); + cy.intercept('**/api/v1/dashboard/?q=**').as('dashboardsList'); + cy.visit('dashboard/list/'); + cy.contains('Actions'); + cy.wait('@dashboardsList').then(xhr => { + const dashboards = xhr.response?.body.result; + expect(dashboards).not.to.be.undefined; const worldBankDashboard = dashboards.find( (d: { dashboard_title: string }) => d.dashboard_title === "World Bank's Data", ); cy.visit(worldBankDashboard.url); }); + WORLD_HEALTH_CHARTS.forEach(waitForChartLoad); cy.get(dashboardView.threeDotsMenuIcon).should('be.visible').click(); cy.get(dashboardView.saveAsMenuOption).should('be.visible').click(); cy.get(dashboardView.saveModal.dashboardNameInput) @@ -69,19 +80,10 @@ describe('Nativefilters Sanity test', () => { .its('response.statusCode') .should('eq', 200); }); - beforeEach(() => { - cy.login(); - cy.request( - 'api/v1/dashboard/?q=(order_column:changed_on_delta_humanized,order_direction:desc,page:0,page_size:100)', - ).then(xhr => { - const dashboards = xhr.body.result; - const testDashboard = dashboards.find( - (d: { dashboard_title: string }) => - d.dashboard_title === testItems.dashboard, - ); - cy.visit(testDashboard.url); - }); + afterEach(() => { + cleanUp(); }); + it('User can expand / retract native filter sidebar on a dashboard', () => { cy.get(nativeFilters.createFilterButton).should('not.exist'); cy.get(nativeFilters.filterFromDashboardView.expand) @@ -394,14 +396,6 @@ describe('Nativefilters Sanity test', () => { cy.get('.line').within(() => { cy.contains('United States').should('be.visible'); }); - // clean up the default setting - cy.get(nativeFilters.filterFromDashboardView.expand).click({ force: true }); - cy.get(nativeFilters.filterFromDashboardView.createFilterButton).click(); - cy.contains('Filter has default value').click(); - cy.get(nativeFilters.modal.footer) - .find(nativeFilters.modal.saveButton) - .should('be.visible') - .click({ force: true }); }); it('User can create a time grain filter', () => { @@ -568,85 +562,50 @@ describe('Nativefilters Sanity test', () => { .should('be.visible', { timeout: 40000 }) .contains('country_name'); }); + it('User can create parent filters using "Values are dependent on other filters"', () => { - cy.get(nativeFilters.filterFromDashboardView.expand).click({ force: true }); - cy.get(nativeFilters.filterFromDashboardView.createFilterButton) - .should('be.visible') - .click(); - // Create Parent filter - cy.get(nativeFilters.modal.container) - .find(nativeFilters.filtersPanel.filterName) - .click({ scrollBehavior: false }) - .clear() - .type('parent', { scrollBehavior: false }); - cy.get(nativeFilters.modal.container) - .find(nativeFilters.filtersPanel.datasetName) - .click({ scrollBehavior: false }) - .type('wb_health_population{enter}', { scrollBehavior: false }); - cy.get(nativeFilters.silentLoading).should('not.exist'); - cy.get(nativeFilters.filtersPanel.filterInfoInput) - .last() - .click({ force: true }); - cy.get(nativeFilters.filtersPanel.filterInfoInput).last().type('region'); - cy.get(nativeFilters.filtersPanel.inputDropdown) - .should('be.visible', { timeout: 20000 }) - .last() - .click(); - cy.get(nativeFilters.addFilterButton.button) - .first() - .click() - .then(() => { - cy.get(nativeFilters.addFilterButton.dropdownItem) - .contains('Filter') - .click(); - }); - // Create dependent filter for parent filter - cy.get(nativeFilters.modal.container) - .find(nativeFilters.filtersPanel.filterName) - .last() - .click({ scrollBehavior: false }) - .clear() - .type('country_name', { scrollBehavior: false }); - cy.get(nativeFilters.modal.container) - .find(nativeFilters.filtersPanel.datasetName) - .last() - .click({ scrollBehavior: false }) - .type('wb_health_population{enter}', { scrollBehavior: false }); - cy.get(nativeFilters.silentLoading).should('not.exist'); - cy.get(nativeFilters.filtersPanel.filterInfoInput) - .last() - .should('be.visible') - .click({ force: true }); - cy.get(nativeFilters.filtersPanel.filterInfoInput) - .last() + cy.get(nativeFilters.filterFromDashboardView.expand) .should('be.visible') - .type('country_name'); - cy.get(nativeFilters.filtersPanel.inputDropdown) - .should('be.visible', { timeout: 20000 }) - .last() .click({ force: true }); - // After click dependent option, should also select parent as dependent filter + cy.get(nativeFilters.filterFromDashboardView.createFilterButton).click(); + // Create parent filter 'region'. + fillValueNativeFilterForm('region', 'wb_health_population', 'region'); + // Create filter 'country_name' depend on region filter. + clickOnAddFilterInModal(); + fillValueNativeFilterForm( + 'country_name', + 'wb_health_population', + 'country_name', + ); cy.get(nativeFilters.filterConfigurationSections.displayedSection).within( () => { cy.contains('Values are dependent on other filters') .should('be.visible') .click(); - cy.wait(1000); - cy.get('[aria-label="Limit type"]').contains('parent'); }, ); + addParentFilterWithValue(0, 'region'); + cy.wait(1000); cy.get(nativeFilters.modal.footer) .contains('Save') .should('be.visible') .click(); + // Validate both filter in dashboard view. WORLD_HEALTH_CHARTS.forEach(waitForChartLoad); - // Verify UI have 2 filters. - cy.get(nativeFilters.filterFromDashboardView.filterName) - .contains('country_name') - .should('be.visible'); - cy.get(nativeFilters.filterFromDashboardView.filterName) - .contains('parent') - .should('be.visible'); + ['region', 'country_name'].forEach(it => { + cy.get(nativeFilters.filterFromDashboardView.filterName) + .contains(it) + .should('be.visible'); + }); + getNativeFilterPlaceholderWithIndex(1) + .invoke('text') + .should('equal', '214 options', { timeout: 20000 }); + // apply first filter value and validate 2nd filter is depden on 1st filter. + applyNativeFilterValueWithIndex(0, 'East Asia & Pacific'); + + getNativeFilterPlaceholderWithIndex(1).should('have.text', '36 options', { + timeout: 20000, + }); }); }); diff --git a/superset-frontend/cypress-base/cypress/support/index.d.ts b/superset-frontend/cypress-base/cypress/support/index.d.ts index fdacf3232ba15..eca68a7ced7fe 100644 --- a/superset-frontend/cypress-base/cypress/support/index.d.ts +++ b/superset-frontend/cypress-base/cypress/support/index.d.ts @@ -47,6 +47,20 @@ declare namespace Cypress { querySubstring?: string | RegExp; chartSelector?: JQuery.Selector; }): cy; + + /** + * Get + */ + getDashboards(): cy; + getCharts(): cy; + + /** + * Delete + */ + deleteDashboard(id: number): cy; + deleteDashboardByName(name: string): cy; + deleteChartByName(name: string): cy; + deleteChart(id: number): cy; } } diff --git a/superset-frontend/cypress-base/cypress/support/index.ts b/superset-frontend/cypress-base/cypress/support/index.ts index e22f69975e96f..4e4d062fa555a 100644 --- a/superset-frontend/cypress-base/cypress/support/index.ts +++ b/superset-frontend/cypress-base/cypress/support/index.ts @@ -19,6 +19,7 @@ import '@cypress/code-coverage/support'; const BASE_EXPLORE_URL = '/superset/explore/?form_data='; +const TokenName = Cypress.env('TOKEN_NAME'); /* eslint-disable consistent-return */ Cypress.on('uncaught:exception', err => { @@ -102,3 +103,88 @@ Cypress.Commands.add( return cy; }, ); + +Cypress.Commands.add('deleteDashboardByName', (name: string) => + cy.getDashboards().then(dashboards => { + for (const element of dashboards) { + if (element.dashboard_title == name) { + const elementId = element.id; + cy.deleteDashboard(elementId); + } + } + }), +); + +Cypress.Commands.add('deleteDashboard', (id: number) => + cy + .request({ + method: 'DELETE', + url: `api/v1/dashboard/${id}`, + headers: { + Cookie: `csrf_access_token=${window.localStorage.getItem( + 'access_token', + )}`, + 'Content-Type': 'application/json', + Authorization: `Bearer ${TokenName}`, + 'X-CSRFToken': `${window.localStorage.getItem('access_token')}`, + Referer: `${Cypress.config().baseUrl}/`, + }, + }) + .then(resp => resp), +); + +Cypress.Commands.add('getDashboards', () => + cy + .request({ + method: 'GET', + url: `api/v1/dashboard/`, + headers: { + 'Content-Type': 'application/json', + Authorization: `Bearer ${TokenName}`, + }, + }) + .then(resp => resp.body.result), +); + +Cypress.Commands.add('deleteChart', (id: number) => + cy + .request({ + method: 'DELETE', + url: `api/v1/chart/${id}`, + headers: { + Cookie: `csrf_access_token=${window.localStorage.getItem( + 'access_token', + )}`, + 'Content-Type': 'application/json', + Authorization: `Bearer ${TokenName}`, + 'X-CSRFToken': `${window.localStorage.getItem('access_token')}`, + Referer: `${Cypress.config().baseUrl}/`, + }, + failOnStatusCode: false, + }) + .then(resp => resp), +); + +Cypress.Commands.add('getCharts', () => + cy + .request({ + method: 'GET', + url: `api/v1/chart/`, + headers: { + 'Content-Type': 'application/json', + Authorization: `Bearer ${TokenName}`, + }, + }) + .then(resp => resp.body.result), +); + +Cypress.Commands.add('deleteChartByName', (name: string) => + cy.getCharts().then(slices => { + for (const element of slices) { + if (element.slice_name == name) { + const elementId = element.id; + cy.deleteChart(elementId); + } + } + }), +); From c6694f210739177e3f223bd4974bf88013f25b3a Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Tue, 29 Mar 2022 10:57:33 -0700 Subject: [PATCH 5/7] fix failure and lint --- .../cypress/integration/dashboard/nativeFilters.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts index 78e872a62b22a..97a5663610063 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts @@ -603,7 +603,7 @@ describe('Nativefilters Sanity test', () => { // apply first filter value and validate 2nd filter is depden on 1st filter. applyNativeFilterValueWithIndex(0, 'East Asia & Pacific'); - getNativeFilterPlaceholderWithIndex(1).should('have.text', '36 options', { + getNativeFilterPlaceholderWithIndex(0).should('have.text', '36 options', { timeout: 20000, }); }); From d2607783962068a9853c60d7068973b77d56a1c0 Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Tue, 29 Mar 2022 19:58:00 -0700 Subject: [PATCH 6/7] fix lint --- docker/docker-init.sh | 2 +- superset-frontend/cypress-base/cypress/support/index.ts | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/docker/docker-init.sh b/docker/docker-init.sh index 07830694048a7..c98f49881ada7 100755 --- a/docker/docker-init.sh +++ b/docker/docker-init.sh @@ -41,7 +41,7 @@ ADMIN_PASSWORD="admin" # If Cypress run – overwrite the password for admin and export env variables if [ "$CYPRESS_CONFIG" == "true" ]; then ADMIN_PASSWORD="general" - export SUPERSET_CONFIG=tests.superset_test_config + export SUPERSET_CONFIG=tests.integration_tests.superset_test_config export SUPERSET_TESTENV=true export SUPERSET__SQLALCHEMY_DATABASE_URI=postgresql+psycopg2://superset:superset@db:5432/superset fi diff --git a/superset-frontend/cypress-base/cypress/support/index.ts b/superset-frontend/cypress-base/cypress/support/index.ts index 4e4d062fa555a..bf58231ef09b2 100644 --- a/superset-frontend/cypress-base/cypress/support/index.ts +++ b/superset-frontend/cypress-base/cypress/support/index.ts @@ -107,7 +107,7 @@ Cypress.Commands.add( Cypress.Commands.add('deleteDashboardByName', (name: string) => cy.getDashboards().then(dashboards => { for (const element of dashboards) { - if (element.dashboard_title == name) { + if (element.dashboard_title === name) { const elementId = element.id; cy.deleteDashboard(elementId); } @@ -181,7 +181,7 @@ Cypress.Commands.add('getCharts', () => Cypress.Commands.add('deleteChartByName', (name: string) => cy.getCharts().then(slices => { for (const element of slices) { - if (element.slice_name == name) { + if (element.slice_name === name) { const elementId = element.id; cy.deleteChart(elementId); } From 0d99039b409874fca68c5828e7069367edc66dfc Mon Sep 17 00:00:00 2001 From: Jinghua Yao Date: Wed, 30 Mar 2022 23:49:00 -0700 Subject: [PATCH 7/7] fix lint again --- .../integration/dashboard/nativeFilters.test.ts | 1 + .../cypress-base/cypress/support/index.ts | 12 ++++++------ 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts index 97a5663610063..2177c9c4fe4cd 100644 --- a/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts +++ b/superset-frontend/cypress-base/cypress/integration/dashboard/nativeFilters.test.ts @@ -61,6 +61,7 @@ describe('Nativefilters Sanity test', () => { cy.contains('Actions'); cy.wait('@dashboardsList').then(xhr => { const dashboards = xhr.response?.body.result; + /* eslint-disable no-unused-expressions */ expect(dashboards).not.to.be.undefined; const worldBankDashboard = dashboards.find( (d: { dashboard_title: string }) => diff --git a/superset-frontend/cypress-base/cypress/support/index.ts b/superset-frontend/cypress-base/cypress/support/index.ts index bf58231ef09b2..905d00df9f81c 100644 --- a/superset-frontend/cypress-base/cypress/support/index.ts +++ b/superset-frontend/cypress-base/cypress/support/index.ts @@ -105,13 +105,13 @@ Cypress.Commands.add( ); Cypress.Commands.add('deleteDashboardByName', (name: string) => - cy.getDashboards().then(dashboards => { - for (const element of dashboards) { + cy.getDashboards().then((dashboards: any) => { + dashboards?.forEach((element: any) => { if (element.dashboard_title === name) { const elementId = element.id; cy.deleteDashboard(elementId); } - } + }); }), ); @@ -179,12 +179,12 @@ Cypress.Commands.add('getCharts', () => ); Cypress.Commands.add('deleteChartByName', (name: string) => - cy.getCharts().then(slices => { - for (const element of slices) { + cy.getCharts().then((slices: any) => { + slices?.forEach((element: any) => { if (element.slice_name === name) { const elementId = element.id; cy.deleteChart(elementId); } - } + }); }), );