123456789101112131415161718192021222324252627282930313233343536373839404142 |
- import {OrganizationFixture} from 'sentry-fixture/organization';
- import {ProjectFixture} from 'sentry-fixture/project';
- import {TeamFixture} from 'sentry-fixture/team';
- import {TeamIssuesBreakdownFixture} from 'sentry-fixture/teamIssuesBreakdown';
- import {render, screen} from 'sentry-test/reactTestingLibrary';
- import TeamIssuesBreakdown from 'sentry/views/organizationStats/teamInsights/teamIssuesBreakdown';
- describe('TeamIssuesBreakdown', () => {
- it('should render graph with table of issues reviewed', async () => {
- const team = TeamFixture();
- const project = ProjectFixture({id: '2', slug: 'javascript'});
- const organization = OrganizationFixture();
- const teamIssuesActions = MockApiClient.addMockResponse({
- url: `/teams/${organization.slug}/${team.slug}/issue-breakdown/`,
- body: TeamIssuesBreakdownFixture(),
- });
- const statuses = ['new', 'regressed', 'unignored'];
- render(
- <TeamIssuesBreakdown
- organization={organization}
- projects={[project]}
- teamSlug={team.slug}
- period="8w"
- statuses={['new', 'regressed', 'unignored']}
- />
- );
- for (const status of statuses) {
- expect(screen.getByText(status)).toBeInTheDocument();
- }
- expect(await screen.findByText('javascript')).toBeInTheDocument();
- // Total
- expect(screen.getByText('49')).toBeInTheDocument();
- // Reviewed
- expect(screen.getAllByText('30')).toHaveLength(statuses.length);
- expect(teamIssuesActions).toHaveBeenCalledTimes(1);
- });
- });
|