mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* Scenes: Support new top nav * Page: Make Page component support new and old dashboard page layouts * Pass scrollbar props * Fixing flex layout for dashboard * Progress on dashboard settings working with topnav * Updated * Annotations working * Starting to work fully * Fix merge issue * Fixed tests * Added buttons to annotations editor * Updating tests * Move Page component to each page * fixed general settings page * Fixed versions * Fixed annotation item page * Variables section working * Fixed tests * Minor fixes to versions * Update * Fixing unit tests * Adding add variable button * Restore annotations edit form so it's the same as before * Fixed semicolon in dashboard permissions * Fixing unit tests * Fixing tests * Minor test update * Fixing unit test * Fixing e2e tests * fix for e2e test * fix a11y issues * Changing places Settings -> General * Trying to fix a11y * I hope this fixes the e2e test * Fixing merge issue * tweak
85 lines
2.8 KiB
TypeScript
85 lines
2.8 KiB
TypeScript
import { render, screen } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
import React from 'react';
|
|
import { BrowserRouter } from 'react-router-dom';
|
|
import { selectOptionInTest } from 'test/helpers/selectOptionInTest';
|
|
import { getGrafanaContextMock } from 'test/mocks/getGrafanaContextMock';
|
|
import { byRole } from 'testing-library-selector';
|
|
|
|
import { selectors } from '@grafana/e2e-selectors';
|
|
import { setBackendSrv } from '@grafana/runtime';
|
|
import { GrafanaContext } from 'app/core/context/GrafanaContext';
|
|
|
|
import { DashboardModel } from '../../state';
|
|
|
|
import { GeneralSettingsUnconnected as GeneralSettings, Props } from './GeneralSettings';
|
|
|
|
setBackendSrv({
|
|
get: jest.fn().mockResolvedValue([]),
|
|
} as any);
|
|
|
|
const setupTestContext = (options: Partial<Props>) => {
|
|
const defaults: Props = {
|
|
dashboard: new DashboardModel(
|
|
{
|
|
title: 'test dashboard title',
|
|
description: 'test dashboard description',
|
|
timepicker: {
|
|
refresh_intervals: ['5s', '10s', '30s', '1m', '5m', '15m', '30m', '1h', '2h', '1d', '2d'],
|
|
time_options: ['5m', '15m', '1h', '6h', '12h', '24h', '2d', '7d', '30d'],
|
|
},
|
|
timezone: 'utc',
|
|
},
|
|
{
|
|
folderId: 1,
|
|
folderTitle: 'test',
|
|
}
|
|
),
|
|
updateTimeZone: jest.fn(),
|
|
updateWeekStart: jest.fn(),
|
|
sectionNav: {
|
|
main: { text: 'Dashboard' },
|
|
node: {
|
|
text: 'Settings',
|
|
},
|
|
},
|
|
};
|
|
|
|
const props = { ...defaults, ...options };
|
|
|
|
const { rerender } = render(
|
|
<GrafanaContext.Provider value={getGrafanaContextMock()}>
|
|
<BrowserRouter>
|
|
<GeneralSettings {...props} />
|
|
</BrowserRouter>
|
|
</GrafanaContext.Provider>
|
|
);
|
|
|
|
return { rerender, props };
|
|
};
|
|
|
|
describe('General Settings', () => {
|
|
describe('when component is mounted with timezone', () => {
|
|
it('should render correctly', async () => {
|
|
setupTestContext({});
|
|
screen.getByDisplayValue('test dashboard title');
|
|
screen.getByDisplayValue('test dashboard description');
|
|
expect(await screen.findByTestId(selectors.components.TimeZonePicker.containerV2)).toHaveTextContent(
|
|
'Coordinated Universal Time'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('when timezone is changed', () => {
|
|
it('should call update function', async () => {
|
|
const { props } = setupTestContext({});
|
|
await userEvent.click(screen.getByTestId(selectors.components.TimeZonePicker.containerV2));
|
|
const timeZonePicker = screen.getByTestId(selectors.components.TimeZonePicker.containerV2);
|
|
await userEvent.click(byRole('combobox').get(timeZonePicker));
|
|
await selectOptionInTest(timeZonePicker, 'Browser Time');
|
|
expect(props.updateTimeZone).toHaveBeenCalledWith('browser');
|
|
expect(props.dashboard.timezone).toBe('browser');
|
|
});
|
|
});
|
|
});
|