mirror of
https://github.com/grafana/grafana.git
synced 2025-02-10 07:35:45 -06:00
* Hide query history when anonymous user uses Explore * Show query history to anonymous users when local storage is used * Fix integration test
79 lines
2.7 KiB
TypeScript
79 lines
2.7 KiB
TypeScript
import { render, screen } from '@testing-library/react';
|
|
import userEvent from '@testing-library/user-event';
|
|
import { noop } from 'lodash';
|
|
import React from 'react';
|
|
|
|
import { SecondaryActions } from './SecondaryActions';
|
|
|
|
describe('SecondaryActions', () => {
|
|
it('should render component with three buttons', () => {
|
|
render(
|
|
<SecondaryActions
|
|
onClickAddQueryRowButton={noop}
|
|
onClickRichHistoryButton={noop}
|
|
onClickQueryInspectorButton={noop}
|
|
/>
|
|
);
|
|
|
|
expect(screen.getByRole('button', { name: /Add row button/i })).toBeInTheDocument();
|
|
expect(screen.getByRole('button', { name: /Rich history button/i })).toBeInTheDocument();
|
|
expect(screen.getByRole('button', { name: /Query inspector button/i })).toBeInTheDocument();
|
|
});
|
|
|
|
it('should not render hidden elements', () => {
|
|
render(
|
|
<SecondaryActions
|
|
addQueryRowButtonHidden={true}
|
|
richHistoryRowButtonHidden={true}
|
|
onClickAddQueryRowButton={noop}
|
|
onClickRichHistoryButton={noop}
|
|
onClickQueryInspectorButton={noop}
|
|
/>
|
|
);
|
|
|
|
expect(screen.queryByRole('button', { name: /Add row button/i })).not.toBeInTheDocument();
|
|
expect(screen.queryByRole('button', { name: /Rich history button/i })).not.toBeInTheDocument();
|
|
expect(screen.getByRole('button', { name: /Query inspector button/i })).toBeInTheDocument();
|
|
});
|
|
|
|
it('should disable add row button if addQueryRowButtonDisabled=true', () => {
|
|
render(
|
|
<SecondaryActions
|
|
addQueryRowButtonDisabled={true}
|
|
onClickAddQueryRowButton={noop}
|
|
onClickRichHistoryButton={noop}
|
|
onClickQueryInspectorButton={noop}
|
|
/>
|
|
);
|
|
|
|
expect(screen.getByRole('button', { name: /Add row button/i })).toBeDisabled();
|
|
expect(screen.getByRole('button', { name: /Rich history button/i })).toBeInTheDocument();
|
|
expect(screen.getByRole('button', { name: /Query inspector button/i })).toBeInTheDocument();
|
|
});
|
|
|
|
it('should map click handlers correctly', async () => {
|
|
const user = userEvent.setup();
|
|
|
|
const onClickAddRow = jest.fn();
|
|
const onClickHistory = jest.fn();
|
|
const onClickQueryInspector = jest.fn();
|
|
|
|
render(
|
|
<SecondaryActions
|
|
onClickAddQueryRowButton={onClickAddRow}
|
|
onClickRichHistoryButton={onClickHistory}
|
|
onClickQueryInspectorButton={onClickQueryInspector}
|
|
/>
|
|
);
|
|
|
|
await user.click(screen.getByRole('button', { name: /Add row button/i }));
|
|
expect(onClickAddRow).toBeCalledTimes(1);
|
|
|
|
await user.click(screen.getByRole('button', { name: /Rich history button/i }));
|
|
expect(onClickHistory).toBeCalledTimes(1);
|
|
|
|
await user.click(screen.getByRole('button', { name: /Query inspector button/i }));
|
|
expect(onClickQueryInspector).toBeCalledTimes(1);
|
|
});
|
|
});
|