import {initializeOrg} from 'sentry-test/initializeOrg'; import {render, screen} from 'sentry-test/reactTestingLibrary'; import {CustomMeasurementsProvider} from 'sentry/utils/customMeasurements/customMeasurementsProvider'; import useCustomMeasurements from 'sentry/utils/useCustomMeasurements'; function TestComponent({other}: {other: string}) { const {customMeasurements} = useCustomMeasurements(); return (
{other} {customMeasurements && Object.keys(customMeasurements).map(customMeasurement => ( {customMeasurement} ))}
); } function mockMeasurementsMeta() { return MockApiClient.addMockResponse({ url: `/organizations/org-slug/measurements-meta/`, body: { 'measurements.custom.measurement': { functions: ['p99'], }, 'measurements.another.custom.measurement': { functions: ['p99'], }, }, }); } describe('useCustomMeasurements', function () { it('provides customMeasurements from the custom measurements context', async function () { const {organization} = initializeOrg({ organization: {features: ['dashboard-custom-measurement-widgets']}, project: undefined, projects: [], router: {}, }); const measurementsMetaMock = mockMeasurementsMeta(); render( ); // Should forward prop expect(screen.getByText('value')).toBeInTheDocument(); expect(measurementsMetaMock).toHaveBeenCalledTimes(1); // Renders custom measurements expect( await screen.findByText('measurements.custom.measurement') ).toBeInTheDocument(); expect( screen.getByText('measurements.another.custom.measurement') ).toBeInTheDocument(); }); });