123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- import {Organization} from 'sentry-fixture/organization';
- import {render, screen} from 'sentry-test/reactTestingLibrary';
- import NoProjectMessage from 'sentry/components/noProjectMessage';
- import ConfigStore from 'sentry/stores/configStore';
- import ProjectsStore from 'sentry/stores/projectsStore';
- import TeamStore from 'sentry/stores/teamStore';
- describe('NoProjectMessage', function () {
- beforeEach(function () {
- ProjectsStore.reset();
- });
- const org = Organization();
- it('renders', function () {
- const organization = Organization({slug: 'org-slug'});
- const childrenMock = jest.fn().mockReturnValue(null);
- ProjectsStore.loadInitialData([]);
- render(
- <NoProjectMessage organization={organization}>{childrenMock}</NoProjectMessage>
- );
- expect(childrenMock).not.toHaveBeenCalled();
- expect(screen.getByText('Remain Calm')).toBeInTheDocument();
- });
- it('shows "Create Project" button when there are no projects', function () {
- ProjectsStore.loadInitialData([]);
- render(<NoProjectMessage organization={org} />);
- expect(screen.getByRole('button', {name: 'Create project'})).toBeEnabled();
- });
- it('disable "Create Project" when user has no org-level access', function () {
- ProjectsStore.loadInitialData([]);
- render(<NoProjectMessage organization={Organization({access: []})} />);
- expect(screen.getByRole('button', {name: 'Create project'})).toBeDisabled();
- });
- it('shows "Create Project" button when user has team-level access', function () {
- ProjectsStore.loadInitialData([]);
- TeamStore.loadInitialData([
- {...TestStubs.Team(), access: ['team:admin', 'team:write', 'team:read']},
- ]);
- // No org-level access
- render(<NoProjectMessage organization={Organization({access: []})} />);
- expect(screen.getByRole('button', {name: 'Create project'})).toBeEnabled();
- });
- it('has no "Join a Team" button when projects are missing', function () {
- ProjectsStore.loadInitialData([]);
- render(<NoProjectMessage organization={org} />);
- expect(screen.queryByRole('button', {name: 'Join a Team'})).not.toBeInTheDocument();
- expect(screen.getByRole('button', {name: 'Create project'})).toBeEnabled();
- });
- it('has a "Join a Team" button when no projects but org has projects', function () {
- ProjectsStore.loadInitialData([TestStubs.Project({hasAccess: false})]);
- render(<NoProjectMessage organization={org} />);
- expect(screen.getByRole('button', {name: 'Join a Team'})).toBeInTheDocument();
- });
- it('has a disabled "Join a Team" button if no access to `team:read`', function () {
- ProjectsStore.loadInitialData([TestStubs.Project({hasAccess: false})]);
- render(<NoProjectMessage organization={{...org, access: []}} />);
- expect(screen.getByRole('button', {name: 'Join a Team'})).toBeDisabled();
- });
- it('shows empty message to superusers that are not members', function () {
- ProjectsStore.loadInitialData([
- TestStubs.Project({hasAccess: true, isMember: false}),
- ]);
- ConfigStore.set('user', {...ConfigStore.get('user'), isSuperuser: true});
- render(
- <NoProjectMessage organization={org} superuserNeedsToBeProjectMember>
- {null}
- </NoProjectMessage>
- );
- expect(
- screen.getByText('You need at least one project to use this view')
- ).toBeInTheDocument();
- });
- });
|