import {MemberFixture} from 'sentry-fixture/member'; import {TeamFixture} from 'sentry-fixture/team'; import {UptimeRuleFixture} from 'sentry-fixture/uptimeRule'; import {initializeOrg} from 'sentry-test/initializeOrg'; import { render, renderGlobalModal, screen, userEvent, within, } from 'sentry-test/reactTestingLibrary'; import selectEvent from 'sentry-test/selectEvent'; import OrganizationStore from 'sentry/stores/organizationStore'; import {UptimeRulesEdit} from './edit'; describe('uptime/edit', function () { beforeEach(function () { MockApiClient.addMockResponse({ url: '/organizations/org-slug/members/', body: [MemberFixture()], }); MockApiClient.addMockResponse({ url: '/organizations/org-slug/teams/', body: [TeamFixture()], }); }); it('displays the edit form', async function () { const {organization, project, routerProps} = initializeOrg(); OrganizationStore.onUpdate(organization); const uptimeRule = UptimeRuleFixture(); const handleChangeTitle = jest.fn(); MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/uptime/${uptimeRule.id}/`, method: 'GET', body: uptimeRule, }); render( , {organization} ); await screen.findByText('Set a URL to monitor'); expect(screen.getByRole('textbox', {name: 'Project'})).toBeDisabled(); expect(screen.getByRole('textbox', {name: 'Environment'})).toBeDisabled(); const url = screen.getByRole('textbox', {name: 'URL'}); expect(url).toBeDisabled(); expect(url).toHaveValue(uptimeRule.url); const name = screen.getByRole('textbox', {name: 'Uptime rule name'}); expect(name).toBeEnabled(); expect(name).toHaveValue(uptimeRule.name); await selectEvent.openMenu(screen.getByRole('textbox', {name: 'Owner'})); expect(screen.getByRole('menuitemradio', {name: 'Foo Bar'})).toBeChecked(); }); it('can delete rule', async function () { const {organization, project, routerProps} = initializeOrg(); OrganizationStore.onUpdate(organization); const uptimeRule = UptimeRuleFixture(); const handleChangeTitle = jest.fn(); MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/uptime/${uptimeRule.id}/`, method: 'GET', body: uptimeRule, }); render( , {organization} ); await screen.findByText('Set a URL to monitor'); const deleteRule = MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/uptime/${uptimeRule.id}/`, method: 'DELETE', }); renderGlobalModal(); await userEvent.click(screen.getByRole('button', {name: 'Delete Rule'})); const modal = await screen.findByRole('dialog'); await userEvent.click(within(modal).getByRole('button', {name: 'Delete Rule'})); expect(deleteRule).toHaveBeenCalled(); }); it('can update the name and owner', async function () { const {organization, project, routerProps} = initializeOrg(); OrganizationStore.onUpdate(organization); const uptimeRule = UptimeRuleFixture({owner: undefined}); const handleChangeTitle = jest.fn(); MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/uptime/${uptimeRule.id}/`, method: 'GET', body: uptimeRule, }); render( , {organization} ); await screen.findByText('Set a URL to monitor'); const name = screen.getByRole('textbox', {name: 'Uptime rule name'}); await userEvent.clear(name); await userEvent.type(name, 'Updated name'); await selectEvent.select(screen.getByRole('textbox', {name: 'Owner'}), 'Foo Bar'); const updateMock = MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/uptime/${uptimeRule.id}/`, method: 'PUT', }); await userEvent.click(screen.getByRole('button', {name: 'Save Changes'})); expect(updateMock).toHaveBeenCalledWith( expect.anything(), expect.objectContaining({ data: expect.objectContaining({name: 'Updated name', owner: 'user:1'}), }) ); }); });