import UpsertTask from "@/app/task/upsertTask"; import { CheckAssignmentCompletion } from "@/lib/progress"; import { supabase } from "@/lib/supabase"; import { fireEvent, render, waitFor } from "@testing-library/react-native"; import { router } from "expo-router"; const mockSingle = jest.fn(); const mockSelect = jest.fn(() => ({ single: mockSingle })); const mockInsert = jest.fn(() => ({ select: mockSelect })); jest.mock("expo-router", () => ({ router: { back: jest.fn(), replace: jest.fn(), }, Stack: { Screen: () => null, }, useLocalSearchParams: () => ({ aId: "assignment-123", }), })); jest.mock("@/lib/progress", () => ({ CheckAssignmentCompletion: jest.fn(() => Promise.resolve()), })); jest.mock("@/lib/supabase", () => ({ supabase: { auth: { getUser: jest.fn(() => Promise.resolve({ data: { user: { id: "user-123" } }, error: null, }) ), }, from: jest.fn(() => ({ insert: mockInsert, })), }, })); test("creates a task and navigates back", async () => { mockSingle.mockResolvedValue({ data: { tId: "task-123", title: "Read chapter 4", uId: "user-123", aId: "assignment-123", }, error: null, }); const screen = render(); fireEvent.changeText(screen.getByTestId("task-title-input"), "Read chapter 4"); fireEvent.press(screen.getByTestId("upsert-task-button")); await waitFor(() => { expect(supabase.from).toHaveBeenCalledWith("tasks"); expect(mockInsert).toHaveBeenCalledWith( expect.objectContaining({ title: "Read chapter 4", uId: "user-123", aId: "assignment-123", }) ); expect(mockSelect).toHaveBeenCalled(); expect(mockSingle).toHaveBeenCalled(); expect(CheckAssignmentCompletion).toHaveBeenCalledWith("assignment-123"); expect(router.back).toHaveBeenCalled(); }); });