mirror of
https://github.com/grafana/grafana.git
synced 2025-02-11 16:15:42 -06:00
* Refactor API * Fix types * Cleanup * Remove useMemo * Update actions * Update story * Align secondary actions * Replace snapshot tests * Update docs * Update packages/grafana-ui/src/components/Card/Card.tsx Co-authored-by: kay delaney <45561153+kaydelaney@users.noreply.github.com> * Allow overriding child props * Fix types and remove alpha tags Co-authored-by: kay delaney <45561153+kaydelaney@users.noreply.github.com>
42 lines
1.1 KiB
TypeScript
42 lines
1.1 KiB
TypeScript
import React from 'react';
|
|
import { render, screen, fireEvent } from '@testing-library/react';
|
|
import AlertRuleItem, { Props } from './AlertRuleItem';
|
|
|
|
const setup = (propOverrides?: object) => {
|
|
const props: Props = {
|
|
rule: {
|
|
id: 1,
|
|
dashboardId: 1,
|
|
panelId: 1,
|
|
name: 'Some rule',
|
|
state: 'Open',
|
|
stateText: 'state text',
|
|
stateIcon: 'icon',
|
|
stateClass: 'state class',
|
|
stateAge: 'age',
|
|
url: 'https://something.something.darkside',
|
|
},
|
|
search: '',
|
|
onTogglePause: jest.fn(),
|
|
};
|
|
|
|
Object.assign(props, propOverrides);
|
|
|
|
return render(<AlertRuleItem {...props} />);
|
|
};
|
|
|
|
describe('AlertRuleItem', () => {
|
|
it('should render component', () => {
|
|
const mockToggle = jest.fn();
|
|
setup({ onTogglePause: mockToggle });
|
|
|
|
expect(screen.getByText('Some rule')).toBeInTheDocument();
|
|
expect(screen.getByText('state text')).toBeInTheDocument();
|
|
expect(screen.getByText('Pause')).toBeInTheDocument();
|
|
expect(screen.getByText('Edit alert')).toBeInTheDocument();
|
|
|
|
fireEvent.click(screen.getByText('Pause'));
|
|
expect(mockToggle).toHaveBeenCalled();
|
|
});
|
|
});
|