1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- import { render, screen } from '@testing-library/react';
- import userEvent from '@testing-library/user-event';
- import React from 'react';
- import { selectOptionInTest } from 'test/helpers/selectOptionInTest';
- import { byRole } from 'testing-library-selector';
- import { selectors } from '@grafana/e2e-selectors';
- import { setBackendSrv } from '@grafana/runtime';
- 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(),
- };
- const props = { ...defaults, ...options };
- const { rerender } = render(<GeneralSettings {...props} />);
- 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');
- });
- });
- });
|