import {DetailedEventsFixture} from 'sentry-fixture/events';
import {GroupFixture} from 'sentry-fixture/group';
import {initializeOrg} from 'sentry-test/initializeOrg';
import {act, render, screen} from 'sentry-test/reactTestingLibrary';
import GroupingStore from 'sentry/stores/groupingStore';
import GroupMergedView from 'sentry/views/issueDetails/groupMerged';
describe('Issues -> Merged View', function () {
const events = DetailedEventsFixture();
const group = GroupFixture();
const mockData = {
merged: [
{
latestEvent: events[0],
state: 'unlocked',
id: '2c4887696f708c476a81ce4e834c4b02',
},
{
latestEvent: events[1],
state: 'unlocked',
id: 'e05da55328a860b21f62e371f0a7507d',
},
],
};
beforeEach(function () {
GroupingStore.init();
MockApiClient.clearMockResponses();
MockApiClient.addMockResponse({
url: `/organizations/org-slug/issues/${group.id}/hashes/?limit=50&query=`,
body: mockData.merged,
});
});
it('renders initially with loading component', async function () {
const {organization, project, router} = initializeOrg({
router: {
params: {groupId: 'groupId'},
},
});
render(
,
{router, organization}
);
expect(screen.getByTestId('loading-indicator')).toBeInTheDocument();
await act(tick);
});
it('renders with mocked data', async function () {
const {organization, project, router} = initializeOrg({
router: {
params: {groupId: 'groupId'},
},
});
render(
,
{router, organization}
);
expect(await screen.findByText(mockData.merged[0].id)).toBeInTheDocument();
const title = await screen.findByText('Fingerprints included in this issue');
expect(title.parentElement).toHaveTextContent(
'Fingerprints included in this issue (2)'
);
});
});