mirror of
https://github.com/ets-cfuhrman-pfe/EvalueTonSavoir.git
synced 2025-08-11 21:23:54 -04:00
added admintable component test
This commit is contained in:
parent
b4d981527c
commit
3f9d53eb5e
2 changed files with 77 additions and 1 deletions
|
|
@ -0,0 +1,77 @@
|
|||
import React from "react";
|
||||
import { render, screen, fireEvent, waitFor } from "@testing-library/react";
|
||||
import AdminTable from "../../../components/AdminTable/AdminTable";
|
||||
import { AdminTableType } from "../../../Types/AdminTableType";
|
||||
import "@testing-library/jest-dom";
|
||||
|
||||
const mockData: AdminTableType[] = [
|
||||
{ _id: "1", name: "John Doe", email: "john@example.com", created_at: new Date("2024-01-01"), roles: ["Admin"] },
|
||||
{ _id: "2", name: "Jane Doe", email: "jane@example.com", created_at: new Date("2024-02-01"), roles: ["User"] },
|
||||
{ _id: "3", name: "Alice Smith", email: "alice@example.com", created_at: new Date("2024-03-01"), roles: ["Editor"] },
|
||||
];
|
||||
|
||||
const labelMap = {
|
||||
name: "Name",
|
||||
email: "Email",
|
||||
created_at: "Created At",
|
||||
roles: "Roles",
|
||||
};
|
||||
|
||||
describe("AdminTable Component", () => {
|
||||
let mockOnDelete: jest.Mock;
|
||||
|
||||
beforeEach(() => {
|
||||
mockOnDelete = jest.fn();
|
||||
});
|
||||
|
||||
test("render AdminTable", () => {
|
||||
render(<AdminTable data={mockData} onDelete={mockOnDelete} labelMap={labelMap} />);
|
||||
|
||||
expect(screen.getByText("Name")).toBeInTheDocument();
|
||||
expect(screen.getByText("Email")).toBeInTheDocument();
|
||||
expect(screen.getByText("Created At")).toBeInTheDocument();
|
||||
expect(screen.getByText("Roles")).toBeInTheDocument();
|
||||
expect(screen.getByText("John Doe")).toBeInTheDocument();
|
||||
expect(screen.getByText("jane@example.com")).toBeInTheDocument();
|
||||
});
|
||||
|
||||
test("filters data based on search input", () => {
|
||||
render(<AdminTable data={mockData} onDelete={mockOnDelete} labelMap={labelMap} />);
|
||||
const searchInput = screen.getByPlaceholderText("Recherche: Enseignant, Courriel...");
|
||||
|
||||
fireEvent.change(searchInput, { target: { value: "Alice" } });
|
||||
|
||||
expect(screen.getByText("Alice Smith")).toBeInTheDocument();
|
||||
expect(screen.queryByText("John Doe")).not.toBeInTheDocument();
|
||||
});
|
||||
|
||||
test("opens and closes confirmation dialog", async () => {
|
||||
render(<AdminTable data={mockData} onDelete={mockOnDelete} labelMap={labelMap} />);
|
||||
const deleteButton = screen.getAllByRole("button")[0];
|
||||
|
||||
fireEvent.click(deleteButton);
|
||||
expect(screen.getByText("Confirm Deletion")).toBeInTheDocument();
|
||||
fireEvent.click(screen.getByRole("button", { name: /cancel/i }));
|
||||
await waitFor(() => {
|
||||
expect(screen.queryByText("Confirm Deletion")).not.toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
||||
test("onDelete when confirming delete", () => {
|
||||
render(<AdminTable data={mockData} onDelete={mockOnDelete} labelMap={labelMap} />);
|
||||
const deleteButton = screen.getAllByRole("button")[0];
|
||||
fireEvent.click(deleteButton);
|
||||
|
||||
fireEvent.click(screen.getByText("Delete"));
|
||||
expect(mockOnDelete).toHaveBeenCalledWith(mockData[0]);
|
||||
});
|
||||
|
||||
test("pagination buttons test click", () => {
|
||||
render(<AdminTable data={mockData} onDelete={mockOnDelete} labelMap={labelMap} />);
|
||||
|
||||
const nextButton = screen.getByLabelText("Go to next page");
|
||||
fireEvent.click(nextButton);
|
||||
|
||||
expect(screen.getByText("Alice Smith")).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
|
@ -1 +0,0 @@
|
|||
//TODO TESTS
|
||||
Loading…
Reference in a new issue