Skip to content

Commit

Permalink
Add basic test cases for dev tool console (#1204) (#1205)
Browse files Browse the repository at this point in the history
* Add basic test cases for console plugin

Signed-off-by: Zhongnan Su <[email protected]>

* fix typo

Signed-off-by: Zhongnan Su <[email protected]>

---------

Signed-off-by: Zhongnan Su <[email protected]>
(cherry picked from commit aa41ad4)

Co-authored-by: Zhongnan Su <[email protected]>
  • Loading branch information
opensearch-trigger-bot[bot] and zhongnansu authored Apr 8, 2024
1 parent dd284c3 commit 37544c3
Show file tree
Hide file tree
Showing 4 changed files with 110 additions and 1 deletion.
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
/*
* Copyright OpenSearch Contributors
* SPDX-License-Identifier: Apache-2.0
*/

import { MiscUtils } from '@opensearch-dashboards-test/opensearch-dashboards-test-library';

const miscUtils = new MiscUtils(cy);

describe('console app', () => {
const DEFAULT_REQUEST = `GET _search
{
"query": {
"match_all": {}
}
}`.trim();

beforeEach(() => {
// Navigate to the console page before each test
miscUtils.visitPage('/app/dev_tools#/console');
// Assuming there's a method to collapse the help pane in your page objects or you directly use a command here
cy.getElementByTestId('help-close-button').click({ force: true });
cy.wait(1000);
});

it('should show the default request', () => {
// Get the request text and assert it matches the default request
// Adjust the selector to target the element containing the request
cy.getVisibleTextFromAceEditor('request-editor').should(
'eq',
DEFAULT_REQUEST
);
});

it('default request response should include `"timed_out" : false`', () => {
// Click the "Play" button to submit the request
// Adjust the selector as needed
cy.getElementByTestId('sendRequestButton').click();

// Check the response for the expected text
// Adjust the selector to target the element containing the response
cy.getElementByTestId('response-editor').should(
'contain',
'"timed_out": false,'
);
});

it('settings should allow changing the text size', () => {
// Navigate to settings and change the font size, then verify the change
// This assumes you have a way to navigate to settings and change them, possibly abstracted in commands
cy.changeConsoleFontSize(20);
cy.getElementByTestId('request-editor').should(
'have.css',
'font-size',
'20px'
);

cy.changeConsoleFontSize(24);
cy.getElementByTestId('request-editor').should(
'have.css',
'font-size',
'24px'
);
});

it('should resize the editor', () => {
// Set initial window size
cy.viewport(1300, 1100);

// Capture initial size
let initialWidth;
cy.get('.conApp').then(($editor) => {
initialWidth = $editor.width();
});

// Change window size
cy.viewport(1000, 1100);

// Assert that the editor width has decreased
cy.get('.conApp').should(($editor) => {
expect($editor.width()).to.be.lessThan(initialWidth);
});
});
});
1 change: 1 addition & 0 deletions cypress/support/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ import '../utils/plugins/security-analytics-dashboards-plugin/commands';
import '../utils/plugins/ml-commons-dashboards/commands';
import '../utils/plugins/notifications-dashboards/commands';
import '../utils/plugins/dashboards-assistant/commands';
import '../utils/dashboards/console/commands';

import 'cypress-real-events';

Expand Down
24 changes: 24 additions & 0 deletions cypress/utils/dashboards/console/commands.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
/*
* Copyright OpenSearch Contributors
* SPDX-License-Identifier: Apache-2.0
*/

Cypress.Commands.add('getVisibleTextFromAceEditor', (editorSelector) => {
return cy
.getElementByTestId(editorSelector)
.find('.ace_line_group')
.then((lines) => {
const linesText = [...lines].map((line) => line.innerText);
return linesText.join('\n');
});
});

Cypress.Commands.add('changeConsoleFontSize', (size) => {
cy.getElementByTestId('consoleSettingsButton').click({ force: true });
// Ensure the settings panel is open and ready
cy.getElementByTestId('setting-font-size-input', { timeout: 1000 })
.type('{selectall}')
.type(size)
.should('have.value', size);
cy.get('[data-test-subj="settings-save-button"]').click();
});
2 changes: 1 addition & 1 deletion cypress/utils/dashboards/vis_builder/commands.js
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ Cypress.Commands.add('vbEditAgg', (fields = []) => {
});

fields.forEach(({ testSubj, type, value }) => {
// TODO: Impliment controls for other input types
// TODO: Implement controls for other input types
switch (type) {
case 'input':
cy.getElementByTestId(testSubj)
Expand Down

0 comments on commit 37544c3

Please sign in to comment.