From f032cc254c7c42e3a1faa88504cfb40116193407 Mon Sep 17 00:00:00 2001 From: Elizabeth Thompson Date: Tue, 21 Sep 2021 09:38:23 -0700 Subject: [PATCH] fix shared query (#16753) --- .../javascripts/sqllab/actions/sqlLab_spec.js | 46 +++++++++---------- .../src/SqlLab/actions/sqlLab.js | 4 +- 2 files changed, 26 insertions(+), 24 deletions(-) diff --git a/superset-frontend/spec/javascripts/sqllab/actions/sqlLab_spec.js b/superset-frontend/spec/javascripts/sqllab/actions/sqlLab_spec.js index 0c424db35fb1b..3c391aaf85063 100644 --- a/superset-frontend/spec/javascripts/sqllab/actions/sqlLab_spec.js +++ b/superset-frontend/spec/javascripts/sqllab/actions/sqlLab_spec.js @@ -612,44 +612,44 @@ describe('async actions', () => { }); describe('queryEditorSetSql', () => { + const sql = 'SELECT * '; + const expectedActions = [ + { + type: actions.QUERY_EDITOR_SET_SQL, + queryEditor, + sql, + }, + ]; describe('with backend persistence flag on', () => { it('updates the tab state in the backend', () => { expect.assertions(2); - const sql = 'SELECT * '; const store = mockStore({}); return store .dispatch(actions.queryEditorSetSql(queryEditor, sql)) .then(() => { - expect(store.getActions()).toHaveLength(0); + expect(store.getActions()).toEqual(expectedActions); expect(fetchMock.calls(updateTabStateEndpoint)).toHaveLength(1); }); }); }); - }); - describe('with backend persistence flag off', () => { - it('does not update the tab state in the backend', () => { - const backendPersistenceOffMock = jest - .spyOn(featureFlags, 'isFeatureEnabled') - .mockImplementation( - feature => !(feature === 'SQLLAB_BACKEND_PERSISTENCE'), - ); - const sql = 'SELECT * '; - const store = mockStore({}); - const expectedActions = [ - { - type: actions.QUERY_EDITOR_SET_SQL, - queryEditor, - sql, - }, - ]; + describe('with backend persistence flag off', () => { + it('does not update the tab state in the backend', () => { + const backendPersistenceOffMock = jest + .spyOn(featureFlags, 'isFeatureEnabled') + .mockImplementation( + feature => !(feature === 'SQLLAB_BACKEND_PERSISTENCE'), + ); - store.dispatch(actions.queryEditorSetSql(queryEditor, sql)); + const store = mockStore({}); + + store.dispatch(actions.queryEditorSetSql(queryEditor, sql)); - expect(store.getActions()).toEqual(expectedActions); - expect(fetchMock.calls(updateTabStateEndpoint)).toHaveLength(0); - backendPersistenceOffMock.mockRestore(); + expect(store.getActions()).toEqual(expectedActions); + expect(fetchMock.calls(updateTabStateEndpoint)).toHaveLength(0); + backendPersistenceOffMock.mockRestore(); + }); }); }); diff --git a/superset-frontend/src/SqlLab/actions/sqlLab.js b/superset-frontend/src/SqlLab/actions/sqlLab.js index 2cccb2e899247..1b46749aeb9dd 100644 --- a/superset-frontend/src/SqlLab/actions/sqlLab.js +++ b/superset-frontend/src/SqlLab/actions/sqlLab.js @@ -898,6 +898,8 @@ export function updateSavedQuery(query) { export function queryEditorSetSql(queryEditor, sql) { return function (dispatch) { + // saved query and set tab state use this action + dispatch({ type: QUERY_EDITOR_SET_SQL, queryEditor, sql }); if (isFeatureEnabled(FeatureFlag.SQLLAB_BACKEND_PERSISTENCE)) { return SupersetClient.put({ endpoint: encodeURI(`/tabstateview/${queryEditor.id}`), @@ -914,7 +916,7 @@ export function queryEditorSetSql(queryEditor, sql) { ), ); } - return dispatch({ type: QUERY_EDITOR_SET_SQL, queryEditor, sql }); + return Promise.resolve(); }; }