Skip to content

Commit

Permalink
Migrated App test to vitest
Browse files Browse the repository at this point in the history
  • Loading branch information
marekdedic committed Jan 9, 2025
1 parent 98d5f2e commit b087c8e
Show file tree
Hide file tree
Showing 2 changed files with 384 additions and 1,087 deletions.
Original file line number Diff line number Diff line change
@@ -1,95 +1,111 @@
import { render } from "@testing-library/react";
import { mocked } from "jest-mock";
import { MemoryRouter } from "react-router-dom";
import * as swr from "swr";
import { beforeAll, describe, expect, test, vi } from "vitest";

import { App } from "../src/App";
import { testData } from "./testData";

jest.mock("swr");
vi.mock("swr");

describe("App", () => {
beforeAll(() => {
window.scrollTo = jest.fn();
// eslint-disable-next-line @typescript-eslint/no-empty-function -- Function mock
vi.spyOn(window, "scrollTo").mockImplementation(() => {});
});

test("should render correctly", () => {
mocked(swr).default.mockReturnValue({
expect.assertions(1);

vi.mocked(swr).default.mockReturnValue({
data: testData,
error: undefined,
isLoading: false,
isValidating: false,
mutate: jest.fn(),
mutate: vi.fn(),
});
const { container } = render(
<MemoryRouter>
<App />
</MemoryRouter>,
);

expect(container.firstChild).toMatchSnapshot();
});

test("should render projects correctly", () => {
mocked(swr).default.mockReturnValue({
expect.assertions(1);

vi.mocked(swr).default.mockReturnValue({
data: testData,
error: undefined,
isLoading: false,
isValidating: false,
mutate: jest.fn(),
mutate: vi.fn(),
});
const { container } = render(
<MemoryRouter initialEntries={["/projekty"]}>
<App />
</MemoryRouter>,
);

expect(container.firstChild).toMatchSnapshot();
});

test("should render project listing correctly", () => {
mocked(swr).default.mockReturnValue({
expect.assertions(1);

vi.mocked(swr).default.mockReturnValue({
data: testData,
error: undefined,
isLoading: false,
isValidating: false,
mutate: jest.fn(),
mutate: vi.fn(),
});
const { container } = render(
<MemoryRouter initialEntries={["/skaut/skaut-google-drive-gallery"]}>
<App />
</MemoryRouter>,
);

expect(container.firstChild).toMatchSnapshot();
});

test("should render issue listing correctly", () => {
mocked(swr).default.mockReturnValue({
expect.assertions(1);

vi.mocked(swr).default.mockReturnValue({
data: testData,
error: undefined,
isLoading: false,
isValidating: false,
mutate: jest.fn(),
mutate: vi.fn(),
});
const { container } = render(
<MemoryRouter initialEntries={["/skaut/skaut-google-drive-gallery/3"]}>
<App />
</MemoryRouter>,
);

expect(container.firstChild).toMatchSnapshot();
});

test("should handle error gracefully", () => {
mocked(swr).default.mockReturnValue({
expect.assertions(1);

vi.mocked(swr).default.mockReturnValue({
data: undefined,
error: true,
isLoading: false,
isValidating: false,
mutate: jest.fn(),
mutate: vi.fn(),
});
const { container } = render(
<MemoryRouter>
<App />
</MemoryRouter>,
);

expect(container.firstChild).toMatchSnapshot();
});
});
Loading

0 comments on commit b087c8e

Please sign in to comment.