mirror of
https://github.com/grafana/grafana.git
synced 2025-08-02 11:34:06 +08:00

* chore(angularsupport): delete feature toggle to disable angular * feat(angular-support): remove config.angularSupportEnabled * chore(jest): remove angular from setup file * chore(angular): delete angular deprecation ui components * refactor(angular): move migration featureflags into migration notice * chore(dashboard): remove angular deprecation notices * chore(annotations): remove angular editor loader * feat(appwrapper): no more angular app loading * feat(pluginscatalog): clean up angular plugin warnings and logic * chore(angular): delete angular app and associated files * feat(plugins): delete old angular graph plugin * feat(plugins): delete old angular table panel * feat(frontend): remove unused appEvent type * feat(dashboards): clean up angular from panel options and menu * feat(plugins): remove graph and table-old from built in plugins and delete sdk * feat(frontend): remove angular related imports in routes and explore graph * feat(theme): remove angular panel styles from global styles * chore(i18n): run make i18n-extract * test(api_plugins_test): refresh snapshot due to deleting old graph and table plugins * chore(angulardeprecation): delete angular migration notice components and usage * test(frontend): clean up tests that assert rendering angular deprecation notices * chore(backend): remove autoMigrateOldPanels feature flag * chore(config): remove angularSupportEnabled from config preventing loading angular plugins * chore(graphpanel): remove autoMigrateGraphPanel from feature toggles * chore(tablepanel): delete autoMigrateTablePanel feature flag * chore(piechart): delete autoMigratePiechartPanel feature flag * chore(worldmappanel): remove autoMigrateWorldmapPanel feature toggle * chore(statpanel): remove autoMigrateStatPanel feature flag * feat(dashboards): remove automigrate feature flags and always auto migrate angular panels * test(pluginsintegration): fix failing loader test * test(frontend): wip: fix failures and skip erroring migration tests * chore(codeowners): remove deleted angular related files and directories * test(graphite): remove angular mock from test file * test(dashboards): skip failing exporter test, remove angularSupportEnabled flags * test(dashbaord): skip another failing panel menu test * Tests: fixes pkg/services/pluginsintegration/loader/loader_test.go (#100505) * Tests: fixes pkg/services/pluginsintegration/plugins_integration_test.go * Trigger Build * chore(dashboards): remove angularComponent from getPanelMenu, update test * feat(dashboards): remove all usage of AngularComponent and getAngularLoader * chore(betterer): refresh results file * feat(plugins): remove PluginAngularBadge component and usage * feat(datasource_srv): remove usage of getLegacyAngularInjector * feat(queryeditor): delete AngularQueryComponentScope type * Chore: removes Angular from plugin_loader * Chore: remove angular from getPlugin * Chore: fix i18n * Trigger Build * Chore: remove more Angular from importPanelPlugin * Chore: remove search options warning * Chore: remove and deprecate Angular related * chore(angular): remove angular dependencies from core and runtime * chore(runtime): delete angular injector * chore(data): delete angular scope from event bus * chore(plugin-catalog): remove code pushing app plugins angular config page * chore(yarn): refresh lock file * chore(frontend): remove ng-loader from webpack configs, remove systemjs cjs plugin * chore(navigation): remove tether-drop cleanup from GrafanaRouter, delete dependency * chore(runtime): delete AngularLoader * chore(betterer): refresh results file * chore(betterer): fix out of sync results file * feat(query): fix type and import errors in QueryEditorRow * test(dashboards): delete skipped angular related tests * Tests: add back tests and fix betterer * Tests: fix broken test * Trigger build * chore(i18n): remove angular deprecation related strings * test: clean up connections and plugins catalog tests * chore(betterer): update results file --------- Co-authored-by: Hugo Häggmark <hugo.haggmark@gmail.com>
115 lines
3.4 KiB
TypeScript
115 lines
3.4 KiB
TypeScript
import { render, screen } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
|
|
import { DataSourceInstanceSettings } from '@grafana/data';
|
|
import { selectors } from '@grafana/e2e-selectors';
|
|
import { mockDataSource } from 'app/features/alerting/unified/mocks';
|
|
import { DataSourceType } from 'app/features/alerting/unified/utils/datasource';
|
|
|
|
import { Props, QueryEditorRowHeader } from './QueryEditorRowHeader';
|
|
|
|
const mockDS = mockDataSource({
|
|
name: 'CloudManager',
|
|
type: DataSourceType.Alertmanager,
|
|
});
|
|
|
|
const mockVariable = mockDataSource({
|
|
name: '${dsVariable}',
|
|
type: 'datasource',
|
|
});
|
|
|
|
jest.mock('@grafana/runtime', () => ({
|
|
...jest.requireActual('@grafana/runtime'),
|
|
getDataSourceSrv: () => ({
|
|
get: () => Promise.resolve(mockDS),
|
|
getList: ({ variables }: { variables: boolean }) => (variables ? [mockDS, mockVariable] : [mockDS]),
|
|
getInstanceSettings: () => mockDS,
|
|
}),
|
|
}));
|
|
|
|
describe('QueryEditorRowHeader', () => {
|
|
it('Can edit title', async () => {
|
|
const scenario = renderScenario({});
|
|
await userEvent.click(screen.getByTestId('query-name-div'));
|
|
|
|
const input = screen.getByTestId('query-name-input');
|
|
await userEvent.clear(input);
|
|
await userEvent.type(input, 'new name');
|
|
|
|
// blur the field
|
|
await userEvent.click(document.body);
|
|
|
|
expect(jest.mocked(scenario.props.onChange).mock.calls[0][0].refId).toBe('new name');
|
|
});
|
|
|
|
it('Show error when other query with same name exists', async () => {
|
|
renderScenario({});
|
|
|
|
await userEvent.click(screen.getByTestId('query-name-div'));
|
|
const input = screen.getByTestId('query-name-input');
|
|
await userEvent.clear(input);
|
|
await userEvent.type(input, 'B');
|
|
const alert = await screen.findByRole('alert');
|
|
|
|
expect(alert.textContent).toBe('Query name already exists');
|
|
});
|
|
|
|
it('Show error when empty name is specified', async () => {
|
|
renderScenario({});
|
|
|
|
await userEvent.click(screen.getByTestId('query-name-div'));
|
|
const input = screen.getByTestId('query-name-input');
|
|
await userEvent.clear(input);
|
|
const alert = await screen.findByRole('alert');
|
|
|
|
expect(alert.textContent).toBe('An empty query name is not allowed');
|
|
});
|
|
|
|
it('should show data source picker when callback is passed', async () => {
|
|
renderScenario({ onChangeDataSource: () => {} });
|
|
|
|
expect(screen.queryByTestId(selectors.components.DataSourcePicker.container)).not.toBeNull();
|
|
});
|
|
|
|
it('should not show data source picker when no callback is passed', async () => {
|
|
renderScenario({ onChangeDataSource: undefined });
|
|
|
|
expect(screen.queryByTestId(selectors.components.DataSourcePicker.container)).toBeNull();
|
|
});
|
|
|
|
it('should render variables in the data source picker', async () => {
|
|
renderScenario({ onChangeDataSource: () => {} });
|
|
|
|
const dsSelect = screen.getByTestId(selectors.components.DataSourcePicker.container).querySelector('input')!;
|
|
await userEvent.click(dsSelect);
|
|
expect(await screen.findByText('${dsVariable}')).toBeInTheDocument();
|
|
});
|
|
});
|
|
|
|
function renderScenario(overrides: Partial<Props>) {
|
|
const props: Props = {
|
|
query: {
|
|
refId: 'A',
|
|
},
|
|
queries: [
|
|
{
|
|
refId: 'A',
|
|
},
|
|
{
|
|
refId: 'B',
|
|
},
|
|
],
|
|
dataSource: {} as DataSourceInstanceSettings,
|
|
hidden: false,
|
|
onChange: jest.fn(),
|
|
collapsedText: '',
|
|
};
|
|
|
|
Object.assign(props, overrides);
|
|
|
|
return {
|
|
props,
|
|
renderResult: render(<QueryEditorRowHeader {...props} />),
|
|
};
|
|
}
|