mirror of
https://github.com/grafana/grafana.git
synced 2024-11-24 09:50:29 -06:00
0dcdfc261b
* chore(monaco): bump monaco-editor to latest version * feat(codeeditor): use esm to load monaco editor * revert(monaco): put back previous version * feat(monaco): setup MonacoEnvironment when bootstrapping app * feat(monaco): load monaco languages from registry as workers * feat(webpack): clean up warnings, remove need to copy monaco into lib * fix(plugins): wip - remove amd loader workaround in systemjs hooks * chore(azure): clean up so QueryField passes typecheck * test(jest): update config to fix failing tests due to missing monaco-editor * test(jest): update config to work with monaco-editor and kusto * test(jest): prevent message eventlistener in nodeGraph/layout.worker tripping up monaco tests * test(plugins): wip - remove amd related tests from systemjs hooks * test(alerting): prefer clearAllMocks to prevent monaco editor failing due to missing matchMedia * test(parca): fix failing test due to undefined backendSrv * chore: move monacoEnv to app/core * test: increase testing-lib timeout to 2secs, fix parca test to assert dom element * feat(plugins): share kusto via systemjs * test(e2e): increase timeout for checking monaco editor in exemplars spec * test(e2e): assert monaco has loaded by checking the spinner is gone and window.monaco exists * test(e2e): check for monaco editor textarea * test(e2e): check monaco editor is loaded before assertions * test(e2e): add waitForMonacoToLoad util to reduce duplication * test(e2e): fix failing mysql spec * chore(jest): add comment to setupTests explaining need to incresae default timeout * chore(nodegraph): improve comment in layout.worker.utils to better explain the need for file
126 lines
4.7 KiB
TypeScript
126 lines
4.7 KiB
TypeScript
import { e2e } from '../utils';
|
|
|
|
import datasetResponse from './fixtures/datasets-response.json';
|
|
import fieldsResponse from './fixtures/fields-response.json';
|
|
import tablesResponse from './fixtures/tables-response.json';
|
|
|
|
const tableNameWithSpecialCharacter = tablesResponse.results.tables.frames[0].data.values[0][1];
|
|
const normalTableName = tablesResponse.results.tables.frames[0].data.values[0][0];
|
|
|
|
describe('MySQL datasource', () => {
|
|
beforeEach(() => {
|
|
cy.intercept('POST', '/api/ds/query', (req) => {
|
|
if (req.body.queries[0].refId === 'datasets') {
|
|
req.alias = 'datasets';
|
|
req.reply({
|
|
body: datasetResponse,
|
|
});
|
|
} else if (req.body.queries[0].refId === 'tables') {
|
|
req.alias = 'tables';
|
|
req.reply({
|
|
body: tablesResponse,
|
|
});
|
|
} else if (req.body.queries[0].refId === 'fields') {
|
|
req.alias = 'fields';
|
|
req.reply({
|
|
body: fieldsResponse,
|
|
});
|
|
}
|
|
});
|
|
e2e.flows.login(Cypress.env('USERNAME'), Cypress.env('PASSWORD'));
|
|
e2e.pages.Explore.visit();
|
|
|
|
e2e.components.DataSourcePicker.container().should('be.visible').type('gdev-mysql{enter}');
|
|
cy.wait('@datasets');
|
|
});
|
|
|
|
it.skip('code editor autocomplete should handle table name escaping/quoting', () => {
|
|
e2e.components.RadioButton.container().filter(':contains("Code")').click();
|
|
|
|
e2e.components.CodeEditor.container().children('[data-testid="Spinner"]').should('not.exist');
|
|
cy.window().its('monaco').should('exist');
|
|
|
|
cy.get('textarea').type('S{downArrow}{enter}');
|
|
cy.wait('@tables');
|
|
cy.get('.suggest-widget').contains(tableNameWithSpecialCharacter).should('be.visible');
|
|
cy.get('textarea').type('{enter}');
|
|
cy.get('textarea').should('have.value', `SELECT FROM grafana.\`${tableNameWithSpecialCharacter}\``);
|
|
|
|
const deleteTimes = new Array(tableNameWithSpecialCharacter.length + 2).fill(
|
|
'{backspace}',
|
|
0,
|
|
tableNameWithSpecialCharacter.length + 2
|
|
);
|
|
cy.get('textarea').type(deleteTimes.join(''));
|
|
|
|
const commandKey = Cypress.platform === 'darwin' ? '{command}' : '{ctrl}';
|
|
|
|
cy.get('textarea').type(`${commandKey}i`);
|
|
cy.get('.suggest-widget').contains(tableNameWithSpecialCharacter).should('be.visible');
|
|
cy.get('textarea').type('S{downArrow}{enter}');
|
|
cy.get('textarea').should('have.value', `SELECT FROM grafana.${normalTableName}`);
|
|
|
|
cy.get('textarea').type('.');
|
|
cy.get('.suggest-widget').contains('No suggestions.').should('be.visible');
|
|
});
|
|
|
|
describe('visual query builder', () => {
|
|
it('should be able to add timeFilter macro', () => {
|
|
cy.get("[aria-label='Table selector']").should('be.visible').click();
|
|
selectOption(normalTableName);
|
|
// Open column selector
|
|
cy.get("[id^='select-column-0']").should('be.visible').click();
|
|
selectOption('createdAt');
|
|
|
|
// Toggle where row
|
|
cy.get("label[for^='sql-filter']").last().should('be.visible').click();
|
|
|
|
// Click add filter button
|
|
cy.get('button[title="Add filter"]').should('be.visible').click();
|
|
cy.get('button[title="Add filter"]').should('be.visible').click(); // For some reason we need to click twice
|
|
|
|
// Open field selector
|
|
cy.get("[aria-label='Field']").should('be.visible').click();
|
|
selectOption('createdAt');
|
|
|
|
// Open operator selector
|
|
cy.get("[aria-label='Operator']").should('be.visible').click();
|
|
selectOption('Macros');
|
|
|
|
// Open macros value selector
|
|
cy.get("[aria-label='Macros value selector']").should('be.visible').click();
|
|
selectOption('timeFilter');
|
|
|
|
e2e.components.CodeEditor.container().children('[data-testid="Spinner"]').should('not.exist');
|
|
cy.window().its('monaco').should('exist');
|
|
|
|
// Validate that the timeFilter macro was added
|
|
e2e.components.CodeEditor.container()
|
|
.get('textarea')
|
|
.should(
|
|
'have.value',
|
|
`SELECT\n createdAt\nFROM\n DataMaker.normalTable\nWHERE\n $__timeFilter(createdAt)\nLIMIT\n 50`
|
|
);
|
|
|
|
// Validate that the timeFilter macro was removed when changed to equals operator
|
|
|
|
// For some reason the input is not visible the second time so we need to force the click
|
|
cy.get("[aria-label='Operator']").click({ force: true });
|
|
selectOption('==');
|
|
|
|
e2e.components.DateTimePicker.input().should('be.visible').click().blur();
|
|
|
|
e2e.components.CodeEditor.container()
|
|
.get('textarea')
|
|
.should(
|
|
'not.have.value',
|
|
`SELECT\n createdAt\nFROM\n DataMaker.normalTable\nWHERE\n $__timeFilter(createdAt)\nLIMIT\n 50`
|
|
);
|
|
});
|
|
});
|
|
});
|
|
|
|
function selectOption(option: string) {
|
|
cy.get("[aria-label='Select option']").contains(option).should('be.visible').click();
|
|
}
|