import {initializeOrg} from 'sentry-test/initializeOrg';
import {render, screen} from 'sentry-test/reactTestingLibrary';
import {Organization} from 'sentry/types';
import {MetricsProvider} from 'sentry/utils/metrics/metricsProvider';
import {useMetricsContext} from 'sentry/utils/useMetricsContext';
function mockMetricsAndTags(orgSlug: Organization['slug']) {
const tagsMock = MockApiClient.addMockResponse({
url: `/organizations/${orgSlug}/metrics/tags/`,
body: [{key: 'environment'}, {key: 'release'}, {key: 'session.status'}],
});
const metasMock = MockApiClient.addMockResponse({
url: `/organizations/${orgSlug}/metrics/meta/`,
body: [
{
name: 'sentry.sessions.session',
type: 'counter',
operations: ['sum'],
},
{
name: 'sentry.sessions.session.error',
type: 'set',
operations: ['count_unique'],
},
],
});
return {tagsMock, metasMock};
}
function TestComponent({other}: {other: string}) {
const {tags, metas} = useMetricsContext();
return (
{other}
{tags && Object.entries(tags).map(([key, tag]) => {tag.key})}
{metas &&
Object.entries(metas).map(([key, meta]) => {meta.name})}
);
}
describe('useMetricsContext', function () {
const {organization, project} = initializeOrg();
it("fetches metrics and tags and save values in the context's state", async function () {
const {tagsMock, metasMock} = mockMetricsAndTags(organization.slug);
render(
);
// Should forward prop
expect(screen.getByText('value')).toBeInTheDocument();
expect(tagsMock).toHaveBeenCalledTimes(1);
expect(metasMock).toHaveBeenCalledTimes(1);
// includes metric tags
expect(await screen.findByText('session.status')).toBeInTheDocument();
// include metric metas
expect(screen.getByText('sentry.sessions.session')).toBeInTheDocument();
expect(screen.getByText('sentry.sessions.session.error')).toBeInTheDocument();
});
it('skip metrics and tags fetches', function () {
const {tagsMock, metasMock} = mockMetricsAndTags(organization.slug);
render(
);
// Should forward prop
expect(screen.getByText('value')).toBeInTheDocument();
expect(tagsMock).not.toHaveBeenCalled();
expect(metasMock).not.toHaveBeenCalled();
// does not include metrics tags
expect(screen.queryByText('session.status')).not.toBeInTheDocument();
// does not include metrics metas
expect(screen.queryByText('sentry.sessions.session')).not.toBeInTheDocument();
expect(screen.queryByText('sentry.sessions.session.error')).not.toBeInTheDocument();
});
it('throw when provider is not set', function () {
// Error is expected, do not fail when calling console.error
jest.spyOn(console, 'error').mockImplementation();
expect(() => render()).toThrow(
/useMetricsContext was called outside of MetricsProvider/
);
});
});