123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- import {OrganizationFixture} from 'sentry-fixture/organization';
- import {ProjectFixture} from 'sentry-fixture/project';
- import {render, screen, waitForElementToBeRemoved} from 'sentry-test/reactTestingLibrary';
- import {textWithMarkupMatcher} from 'sentry-test/utils';
- import {EntryType} from 'sentry/types';
- import useOrganization from 'sentry/utils/useOrganization';
- import usePageFilters from 'sentry/utils/usePageFilters';
- import {DatabaseSpanDescription} from 'sentry/views/starfish/components/spanDescription';
- jest.mock('sentry/utils/useOrganization');
- jest.mock('sentry/utils/usePageFilters');
- describe('DatabaseSpanDescription', function () {
- const organization = OrganizationFixture({
- features: ['performance-database-view-query-source'],
- });
- jest.mocked(useOrganization).mockReturnValue(organization);
- const project = ProjectFixture();
- jest.mocked(usePageFilters).mockReturnValue({
- isReady: true,
- desyncedFilters: new Set(),
- pinnedFilters: new Set(),
- shouldPersist: true,
- selection: {
- datetime: {
- period: '10d',
- start: null,
- end: null,
- utc: false,
- },
- environments: [],
- projects: [],
- },
- });
- const groupId = '2ed2abf6ce7e3577';
- const spanId = 'abfed2aabf';
- const eventId = '65c7d8647b8a76ef8f4c05d41deb7860';
- it('shows preliminary description if no more data is available', async function () {
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/`,
- body: [],
- });
- render(
- <DatabaseSpanDescription
- groupId={groupId}
- preliminaryDescription="SELECT USERS FRO*"
- />
- );
- await waitForElementToBeRemoved(() => screen.getByTestId('loading-indicator'));
- expect(screen.getByText('SELECT USERS FRO*')).toBeInTheDocument();
- });
- it('shows full query if full event is available', async function () {
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/`,
- body: {
- data: [
- {
- 'transaction.id': eventId,
- project: project.slug,
- span_id: spanId,
- },
- ],
- },
- });
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/${project.slug}:${eventId}/`,
- body: {
- id: eventId,
- entries: [
- {
- type: EntryType.SPANS,
- data: [
- {
- span_id: spanId,
- description: 'SELECT users FROM my_table LIMIT 1;',
- },
- ],
- },
- ],
- },
- });
- render(
- <DatabaseSpanDescription
- groupId={groupId}
- preliminaryDescription="SELECT USERS FRO*"
- />
- );
- await waitForElementToBeRemoved(() => screen.getByTestId('loading-indicator'));
- expect(screen.getByText('SELECT users FROM my_table LIMIT 1;')).toBeInTheDocument();
- });
- it('shows query source if available', async function () {
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/`,
- body: {
- data: [
- {
- 'transaction.id': eventId,
- project: project.slug,
- span_id: spanId,
- },
- ],
- },
- });
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/${project.slug}:${eventId}/`,
- body: {
- id: eventId,
- entries: [
- {
- type: EntryType.SPANS,
- data: [
- {
- span_id: spanId,
- description: 'SELECT users FROM my_table LIMIT 1;',
- data: {
- 'code.filepath': '/app/views/users.py',
- 'code.lineno': 78,
- },
- },
- ],
- },
- ],
- },
- });
- render(
- <DatabaseSpanDescription
- groupId={groupId}
- preliminaryDescription="SELECT USERS FRO*"
- />,
- {organization}
- );
- await waitForElementToBeRemoved(() => screen.getByTestId('loading-indicator'));
- expect(screen.getByText('SELECT users FROM my_table LIMIT 1;')).toBeInTheDocument();
- expect(
- screen.getByText(textWithMarkupMatcher('/app/views/users.py at line 78'))
- ).toBeInTheDocument();
- });
- });
|