import {OrganizationFixture} from 'sentry-fixture/organization'; import { render, renderGlobalModal, screen, userEvent, } from 'sentry-test/reactTestingLibrary'; import {PageHeaderActions} from 'sentry/views/metrics/pageHeaderActions'; jest.mock('sentry/views/metrics/useCreateDashboard'); describe('Metrics Page Header Actions', function () { describe('add metric buttons', function () { it('display "add custom metrics" button', async function () { const addCustomMetric = jest.fn(); render(); const button = screen.getByRole('button', {name: 'Add Custom Metrics'}); expect(button).toBeInTheDocument(); await userEvent.click(button); expect(addCustomMetric).toHaveBeenCalled(); }); it('display "add new metric" button', async function () { render( jest.fn()} />, { organization: OrganizationFixture({ features: [ 'custom-metrics-extraction-rule', 'custom-metrics-extraction-rule-ui', ], }), } ); renderGlobalModal(); const button = screen.getByRole('button', {name: 'Add New Metric'}); expect(button).toBeInTheDocument(); await userEvent.click(button); expect( await screen.findByRole('heading', {name: /Configure Metric/}) ).toBeInTheDocument(); }); }); });