|
1 | 1 | import { jobFactory } from "@test/factories/job"; |
2 | | -import { render } from "@testing-library/react"; |
3 | | -import { expect, test } from "vitest"; |
| 2 | +import { act, render, screen, waitFor, within } from "@testing-library/react"; |
| 3 | +import { userEvent } from "storybook/test"; |
| 4 | +import { expect, test, vi } from "vitest"; |
4 | 5 |
|
5 | 6 | import JobDetail from "./JobDetail"; |
6 | 7 |
|
7 | | -test("adds 1 + 2 to equal 3", () => { |
8 | | - const job = jobFactory.build(); |
9 | | - const cancel = () => {}; |
10 | | - const deleteFn = () => {}; |
11 | | - const retry = () => {}; |
12 | | - const { getByTestId: _getTestById } = render( |
13 | | - <JobDetail cancel={cancel} deleteFn={deleteFn} job={job} retry={retry} />, |
| 8 | +test("requires confirmation before deleting a job", async () => { |
| 9 | + const job = jobFactory.completed().build({ id: 123n }); |
| 10 | + const deleteFn = vi.fn(); |
| 11 | + const user = userEvent.setup(); |
| 12 | + |
| 13 | + render( |
| 14 | + <JobDetail |
| 15 | + cancel={vi.fn()} |
| 16 | + deleteFn={deleteFn} |
| 17 | + job={job} |
| 18 | + retry={vi.fn()} |
| 19 | + />, |
14 | 20 | ); |
15 | | - expect(3).toBe(3); |
| 21 | + |
| 22 | + await act(async () => { |
| 23 | + await user.click(screen.getByRole("button", { name: /^delete$/i })); |
| 24 | + }); |
| 25 | + |
| 26 | + expect(deleteFn).not.toHaveBeenCalled(); |
| 27 | + const dialog = await screen.findByRole("dialog", { name: "Delete job?" }); |
| 28 | + expect( |
| 29 | + within(dialog).getByText(/This permanently deletes job/i), |
| 30 | + ).toBeInTheDocument(); |
| 31 | + expect(within(dialog).getByText("123")).toBeInTheDocument(); |
| 32 | + |
| 33 | + await act(async () => { |
| 34 | + await user.click( |
| 35 | + within(dialog).getByRole("button", { name: /delete job/i }), |
| 36 | + ); |
| 37 | + }); |
| 38 | + |
| 39 | + await waitFor(() => { |
| 40 | + expect(deleteFn).toHaveBeenCalledTimes(1); |
| 41 | + expect( |
| 42 | + screen.queryByRole("dialog", { name: "Delete job?" }), |
| 43 | + ).not.toBeInTheDocument(); |
| 44 | + }); |
| 45 | +}); |
| 46 | + |
| 47 | +test("cancels job delete confirmation", async () => { |
| 48 | + const job = jobFactory.completed().build(); |
| 49 | + const deleteFn = vi.fn(); |
| 50 | + const user = userEvent.setup(); |
| 51 | + |
| 52 | + render( |
| 53 | + <JobDetail |
| 54 | + cancel={vi.fn()} |
| 55 | + deleteFn={deleteFn} |
| 56 | + job={job} |
| 57 | + retry={vi.fn()} |
| 58 | + />, |
| 59 | + ); |
| 60 | + |
| 61 | + await act(async () => { |
| 62 | + await user.click(screen.getByRole("button", { name: /^delete$/i })); |
| 63 | + }); |
| 64 | + const dialog = await screen.findByRole("dialog", { name: "Delete job?" }); |
| 65 | + await act(async () => { |
| 66 | + await user.click(within(dialog).getByRole("button", { name: /cancel/i })); |
| 67 | + }); |
| 68 | + |
| 69 | + await waitFor(() => { |
| 70 | + expect(deleteFn).not.toHaveBeenCalled(); |
| 71 | + expect( |
| 72 | + screen.queryByRole("dialog", { name: "Delete job?" }), |
| 73 | + ).not.toBeInTheDocument(); |
| 74 | + }); |
16 | 75 | }); |
0 commit comments