025d8527dd
* remove redux from PromQueryBuilderContainer * remove export * housekeeping * introduce MetricsModalContext to replace redux * handle result pagination * add search related values in context * handle filtering * handle search * handle search and highlighting * cleaning up * better helpers * remove unused types * reorganize the code * update settings * improve search and fetch * remove unused styles * linting * fix tests * update * lint * i18n * import order * try to fix the test * remove start call from variable editor * fix highlighter * fix pagination alignment * make the entire row clickable and remove select button * review updates * remove settings * use ufuzzy search * fix tests * use case-insensitive search * review fixes * fix pagination * improve readability
63 lines
1.4 KiB
TypeScript
63 lines
1.4 KiB
TypeScript
import { e2e } from '../../utils';
|
|
|
|
/**
|
|
* Create a Prom data source
|
|
*/
|
|
export function createPromDS(dataSourceID: string, name: string): void {
|
|
// login
|
|
e2e.flows.login(Cypress.env('USERNAME'), Cypress.env('PASSWORD'), true);
|
|
|
|
// select the prometheus DS
|
|
e2e.pages.AddDataSource.visit();
|
|
e2e.pages.AddDataSource.dataSourcePluginsV2(dataSourceID)
|
|
.scrollIntoView()
|
|
.should('be.visible') // prevents flakiness
|
|
.click();
|
|
|
|
// add url for DS to save without error
|
|
e2e.components.DataSource.Prometheus.configPage.connectionSettings().type('http://prom-url:9090');
|
|
|
|
// name the DS
|
|
e2e.pages.DataSource.name().clear();
|
|
e2e.pages.DataSource.name().type(name);
|
|
e2e.pages.DataSource.saveAndTest().click();
|
|
}
|
|
|
|
export function getResources() {
|
|
cy.intercept(/__name__/g, metricResponse).as('getMetricNames');
|
|
|
|
cy.intercept(/metadata/g, metadataResponse).as('getMetadata');
|
|
|
|
cy.intercept(/labels/g, labelsResponse).as('getLabels');
|
|
}
|
|
|
|
const metricResponse = {
|
|
status: 'success',
|
|
data: ['metric1', 'metric2'],
|
|
};
|
|
|
|
const metadataResponse = {
|
|
status: 'success',
|
|
data: {
|
|
metric1: [
|
|
{
|
|
type: 'counter',
|
|
help: 'metric1 help',
|
|
unit: '',
|
|
},
|
|
],
|
|
metric2: [
|
|
{
|
|
type: 'counter',
|
|
help: 'metric2 help',
|
|
unit: '',
|
|
},
|
|
],
|
|
},
|
|
};
|
|
|
|
const labelsResponse = {
|
|
status: 'success',
|
|
data: ['__name__', 'action', 'active', 'backend'],
|
|
};
|