1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- import {render, screen} from 'sentry-test/reactTestingLibrary';
- import ProjectsStore from 'sentry/stores/projectsStore';
- import TeamStore from 'sentry/stores/teamStore';
- import withTeamsForUser from 'sentry/utils/withTeamsForUser';
- describe('withUserTeams HoC', function () {
- const api = new MockApiClient();
- const organization = TestStubs.Organization();
- delete organization.projects;
- function Output({error, teams}) {
- if (error) {
- return <p>Error: {error.responseText}</p>;
- }
- return (
- <p>
- {teams.map(team => (
- <span key={team.slug}>{team.slug}</span>
- ))}
- </p>
- );
- }
- beforeEach(function () {
- MockApiClient.clearMockResponses();
- jest.spyOn(ProjectsStore, 'loadInitialData');
- jest.spyOn(TeamStore, 'loadInitialData');
- });
- it('forwards errors', async function () {
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/user-teams/`,
- statusCode: 400,
- });
- const Container = withTeamsForUser(Output);
- render(<Container organization={organization} api={api} />);
- expect(await screen.findByText(/Error:/)).toBeInTheDocument();
- });
- it('fetches teams and loads stores', async function () {
- const mockProjectA = TestStubs.Project({slug: 'a', id: '1'});
- const mockProjectB = TestStubs.Project({slug: 'b', id: '2'});
- const mockTeams = [
- {
- slug: 'sentry',
- projects: [mockProjectB],
- },
- {
- slug: 'captainplanet',
- projects: [mockProjectA, mockProjectB],
- },
- ];
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/user-teams/`,
- body: mockTeams,
- });
- const Container = withTeamsForUser(Output);
- render(<Container organization={organization} api={api} />);
- expect(await screen.findByText('sentry')).toBeInTheDocument();
- expect(screen.getByText('captainplanet')).toBeInTheDocument();
- });
- });
|