Skip to content

Commit

Permalink
[Bug] Fix SQL/PPL crash with incorrect query (#2284)
Browse files Browse the repository at this point in the history
* fix SQL/PPL crash with incorrect query

Signed-off-by: Shenoy Pratik <sgguruda@amazon.com>

* add constants

Signed-off-by: Shenoy Pratik <sgguruda@amazon.com>

---------

Signed-off-by: Shenoy Pratik <sgguruda@amazon.com>
  • Loading branch information
ps48 authored Dec 9, 2024
1 parent 207004a commit d0f0012
Show file tree
Hide file tree
Showing 4 changed files with 62 additions and 16 deletions.
64 changes: 51 additions & 13 deletions .cypress/integration/notebooks_test/notebooks.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ import {
PPL_QUERY_TEXT,
NOTEBOOK_TEXT,
OPENSEARCH_URL,
PPL_INCORRECT_QUERY_TEXT,
SQL_INCORRECT_QUERY_TEXT,
} from '../../utils/constants';

import { v4 as uuid4 } from 'uuid';
Expand Down Expand Up @@ -74,7 +76,9 @@ describe('Testing notebooks table', () => {
cy.get('h3[data-test-subj="notebookTableTitle"]').contains('Notebooks (0)').should('exist');
cy.get('div[data-test-subj="notebookEmptyTableText"]').contains('No notebooks');
cy.get('a[data-test-subj="notebookEmptyTableCreateBtn"]').contains('Create notebook');
cy.get('button[data-test-subj="notebookEmptyTableAddSamplesBtn"]').contains('Add sample notebooks');
cy.get('button[data-test-subj="notebookEmptyTableAddSamplesBtn"]').contains(
'Add sample notebooks'
);
});

it('Displays error toast for invalid notebook name', () => {
Expand All @@ -96,13 +100,9 @@ describe('Testing notebooks table', () => {
cy.get('input.euiFieldSearch').focus().type('this notebook should not exist');
cy.get('.euiTableCellContent__text').contains('No items found').should('exist');
cy.get('.euiFormControlLayoutClearButton').click();
cy.get('input.euiFieldSearch')
.focus()
.type(TEST_NOTEBOOK);
cy.get('input.euiFieldSearch').focus().type(TEST_NOTEBOOK);

cy.get('a.euiLink')
.contains(TEST_NOTEBOOK)
.should('exist');
cy.get('a.euiLink').contains(TEST_NOTEBOOK).should('exist');
});

it('Notebooks table columns headers and pagination', () => {
Expand Down Expand Up @@ -295,6 +295,24 @@ describe('Testing paragraphs', () => {
});
});

it('Adds an incorrect SQL query paragraph', () => {
cy.get('button[data-test-subj="AddParagraphButton"]').click();
cy.get('button[data-test-subj="AddCodeBlockBtn"]').click();

cy.get('textarea[data-test-subj="editorArea-6"]').clear();
cy.get('textarea[data-test-subj="editorArea-6"]').focus();
cy.get('textarea[data-test-subj="editorArea-6"]').type(SQL_INCORRECT_QUERY_TEXT);
cy.get('button[data-test-subj="runRefreshBtn-6"]').click();

cy.get('textarea[data-test-subj="editorArea-6"]').should('exist');
cy.get('div[id$="-error-0"]')
.should('exist')
.and('have.class', 'euiFormErrorText')
.and('contain.text', 'Invalid SQL query');

cy.get('.euiDataGrid__overflow').should('exist');
});

it('Adds an observability visualization paragraph', () => {
cy.get('h3[data-test-subj="notebookTitle"]').contains(TEST_NOTEBOOK).should('exist');
cy.get('button[data-test-subj="notebook-paragraph-actions-button"]').click();
Expand All @@ -309,7 +327,9 @@ describe('Testing paragraphs', () => {
cy.get('input[data-test-subj="comboBoxSearchInput"]')
.focus()
.type('[Logs] Count total requests by t');
cy.get('.euiComboBoxOption__content').contains('[Logs] Count total requests by tags').click({ force: true });
cy.get('.euiComboBoxOption__content')
.contains('[Logs] Count total requests by tags')
.click({ force: true });
cy.get('button[data-test-subj="runRefreshBtn-0"]').click();
cy.get('h5').contains('[Logs] Count total requests by tags').should('exist');
});
Expand All @@ -318,19 +338,37 @@ describe('Testing paragraphs', () => {
cy.get('button[data-test-subj="AddParagraphButton"]').click();
cy.get('button[data-test-subj="AddCodeBlockBtn"]').click();

cy.get('textarea[data-test-subj="editorArea-7"]').clear();
cy.get('textarea[data-test-subj="editorArea-7"]').focus();
cy.get('textarea[data-test-subj="editorArea-7"]').type(PPL_QUERY_TEXT);
cy.get('button[data-test-subj="runRefreshBtn-7"]').click();
cy.get('textarea[data-test-subj="editorArea-8"]').clear();
cy.get('textarea[data-test-subj="editorArea-8"]').focus();
cy.get('textarea[data-test-subj="editorArea-8"]').type(PPL_QUERY_TEXT);
cy.get('button[data-test-subj="runRefreshBtn-8"]').click();

cy.get('textarea[data-test-subj="editorArea-7"]').should('not.exist');
cy.get('textarea[data-test-subj="editorArea-8"]').should('not.exist');
cy.get('div[data-test-subj="queryOutputText"]')
.contains('source=opensearch_dashboards_sample_data_flights')
.should('exist');

cy.get('.euiDataGrid__overflow').should('exist');
});

it('Adds an incorrect PPL query paragraph', () => {
cy.get('button[data-test-subj="AddParagraphButton"]').click();
cy.get('button[data-test-subj="AddCodeBlockBtn"]').click();

cy.get('textarea[data-test-subj="editorArea-9"]').clear();
cy.get('textarea[data-test-subj="editorArea-9"]').focus();
cy.get('textarea[data-test-subj="editorArea-9"]').type(PPL_INCORRECT_QUERY_TEXT);
cy.get('button[data-test-subj="runRefreshBtn-9"]').click();

cy.get('textarea[data-test-subj="editorArea-9"]').should('exist');
cy.get('div[id$="-error-0"]')
.should('exist')
.and('have.class', 'euiFormErrorText')
.and('contain.text', 'Error occurred in OpenSearch engine: no such index');

cy.get('.euiDataGrid__overflow').should('exist');
});

it('Clears outputs', () => {
cy.get('h3[data-test-subj="notebookTitle"]').contains(TEST_NOTEBOOK).should('exist');
cy.get('.euiButton__text').contains('Clear all outputs').click();
Expand Down
1 change: 0 additions & 1 deletion .cypress/support/constants.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,3 @@ export const ADMIN_AUTH = {
username: 'admin',
password: 'admin',
};

11 changes: 10 additions & 1 deletion .cypress/utils/constants.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,9 @@ export const setTimeFilter = (setEndTime = false, refresh = true) => {
.focus()
.type('{selectall}' + startTime, { force: true });
if (setEndTime) {
cy.get('button.euiDatePopoverButton--end[data-test-subj="superDatePickerendDatePopoverButton"]').click();
cy.get(
'button.euiDatePopoverButton--end[data-test-subj="superDatePickerendDatePopoverButton"]'
).click();
cy.get('.euiTab__content').contains('Absolute').click();
cy.get('input[data-test-subj="superDatePickerAbsoluteDateInput"]')
.focus()
Expand Down Expand Up @@ -128,10 +130,17 @@ export const SQL_QUERY_TEXT = `%sql
select * from opensearch_dashboards_sample_data_flights limit 20 {enter}
`;

export const SQL_INCORRECT_QUERY_TEXT = `%sql
selectaaaaa * from opensearch_dashboards_sample_data_flights limit 20 {enter}
`;

export const PPL_QUERY_TEXT = `%ppl
source=opensearch_dashboards_sample_data_flights {enter}
`;

export const PPL_INCORRECT_QUERY_TEXT = `%ppl
source=opensearch_dashboards_sample_data_flights__ {enter}
`;

export const suppressResizeObserverIssue = () => {
// exception is thrown on loading EuiDataGrid in cypress only, ignore for now
Expand Down
2 changes: 1 addition & 1 deletion server/services/queryService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ export class QueryService {
return {
data: {
ok: false,
resp: err.message,
resp: err.response,
body: err.body,
},
};
Expand Down

0 comments on commit d0f0012

Please sign in to comment.