import {Organization} from 'sentry-fixture/organization';
import {render, screen, userEvent, waitFor} from 'sentry-test/reactTestingLibrary';
import ConfigStore from 'sentry/stores/configStore';
import OrganizationCreate from 'sentry/views/organizationCreate';
describe('OrganizationCreate', function () {
beforeEach(() => {
ConfigStore.get('termsUrl');
ConfigStore.get('privacyUrl');
});
afterEach(() => {
MockApiClient.clearMockResponses();
jest.resetAllMocks();
});
it('renders without terms', function () {
render();
});
it('renders with terms', function () {
ConfigStore.set('termsUrl', 'https://example.com/terms');
ConfigStore.set('privacyUrl', 'https://example.com/privacy');
render();
});
it('creates a new org', async function () {
const orgCreateMock = MockApiClient.addMockResponse({
url: '/organizations/',
method: 'POST',
body: Organization(),
});
ConfigStore.set('termsUrl', 'https://example.com/terms');
ConfigStore.set('privacyUrl', 'https://example.com/privacy');
render();
expect(screen.getByText('Create a New Organization')).toBeInTheDocument();
await userEvent.type(screen.getByPlaceholderText('e.g. My Company'), 'Good Burger');
await userEvent.click(
screen.getByRole('checkbox', {
name: 'I agree to the Terms of Service and the Privacy Policy',
})
);
await userEvent.click(screen.getByText('Create Organization'));
await waitFor(() => {
expect(orgCreateMock).toHaveBeenCalledWith(
'/organizations/',
expect.objectContaining({
data: {agreeTerms: true, defaultTeam: true, name: 'Good Burger'},
})
);
});
expect(window.location.assign).toHaveBeenCalledTimes(1);
expect(window.location.assign).toHaveBeenCalledWith(
'/organizations/org-slug/projects/new/'
);
});
it('creates a new org with customer domain feature', async function () {
const orgCreateMock = MockApiClient.addMockResponse({
url: '/organizations/',
method: 'POST',
body: Organization({
features: ['customer-domains'],
}),
});
ConfigStore.set('termsUrl', 'https://example.com/terms');
ConfigStore.set('privacyUrl', 'https://example.com/privacy');
render();
expect(screen.getByText('Create a New Organization')).toBeInTheDocument();
await userEvent.type(screen.getByPlaceholderText('e.g. My Company'), 'Good Burger');
await userEvent.click(
screen.getByRole('checkbox', {
name: 'I agree to the Terms of Service and the Privacy Policy',
})
);
await userEvent.click(screen.getByText('Create Organization'));
await waitFor(() => {
expect(orgCreateMock).toHaveBeenCalledWith(
'/organizations/',
expect.objectContaining({
data: {agreeTerms: true, defaultTeam: true, name: 'Good Burger'},
})
);
});
expect(window.location.assign).toHaveBeenCalledTimes(1);
expect(window.location.assign).toHaveBeenCalledWith(
'https://org-slug.sentry.io/projects/new/'
);
});
});