|
1 | | -import { fireEvent, render, screen } from "@testing-library/react"; |
2 | | -import { Supporters } from "./Supporters"; |
| 1 | +import {fireEvent, render, screen} from "@testing-library/react"; |
| 2 | +import {Supporters} from "./Supporters"; |
3 | 3 | import React from "react"; |
4 | | -import { useWindowSize } from "react-use"; |
5 | | -import { BrowserRouter, Route, Routes } from "react-router"; |
| 4 | +import {useWindowSize} from "react-use"; |
| 5 | +import {BrowserRouter, Route, Routes} from "react-router"; |
| 6 | +import {Sponsor} from "./SponsorsData"; |
6 | 7 |
|
7 | 8 | jest.mock("react-use", () => ({ |
8 | | - useWindowSize: jest.fn(), |
| 9 | + useWindowSize: jest.fn(), |
9 | 10 | })); |
10 | 11 |
|
11 | 12 | describe("Supporters", () => { |
12 | | - beforeEach(() => { |
13 | | - (useWindowSize as jest.Mock).mockReturnValue({ width: 1024 }); // Mock window width for testing |
14 | | - }); |
| 13 | + beforeEach(() => { |
| 14 | + (useWindowSize as jest.Mock).mockReturnValue({width: 1024}); // Mock window width for testing |
| 15 | + }); |
15 | 16 |
|
16 | | - afterEach(() => { |
17 | | - jest.clearAllMocks(); |
18 | | - }); |
| 17 | + afterEach(() => { |
| 18 | + jest.clearAllMocks(); |
| 19 | + }); |
19 | 20 |
|
20 | | - // disabled until supporters included |
21 | | - it.skip("renders component with supporters", () => { |
22 | | - render( |
23 | | - <React.Suspense fallback={<span>Loading...</span>}> |
24 | | - <Routes> |
25 | | - <Route path={""} element={<Supporters />} /> |
26 | | - </Routes> |
27 | | - </React.Suspense>, |
28 | | - { wrapper: BrowserRouter } |
29 | | - ); |
| 21 | + const supporters: Sponsor[] = [{ |
| 22 | + name: "test", |
| 23 | + website: "https://www.acme.com", |
| 24 | + image: "https://www.acme.com/logo.png", |
| 25 | + }]; |
30 | 26 |
|
31 | | - expect(screen.getByTestId("supporters")).toBeInTheDocument(); |
32 | | - expect(screen.getByText("SUPPORTERS")).toBeInTheDocument(); |
33 | | - expect(screen.getAllByRole("link")).toHaveLength(5); |
34 | | - }); |
| 27 | + // disabled until supporters included |
| 28 | + it("renders component with supporters", () => { |
| 29 | + render( |
| 30 | + <React.Suspense fallback={<span>Loading...</span>}> |
| 31 | + <Routes> |
| 32 | + <Route path={""} |
| 33 | + element={<Supporters sponsors={supporters}/>}/> |
| 34 | + </Routes> |
| 35 | + </React.Suspense>, |
| 36 | + {wrapper: BrowserRouter} |
| 37 | + ); |
35 | 38 |
|
36 | | - it.skip("applies hover styles on mouse enter", () => { |
37 | | - render( |
38 | | - <React.Suspense fallback={<span>Loading...</span>}> |
39 | | - <Routes> |
40 | | - <Route path={"*"} element={<Supporters />} /> |
41 | | - </Routes> |
42 | | - </React.Suspense>, |
43 | | - { wrapper: BrowserRouter } |
44 | | - ); |
45 | | - const supportersElement = screen.getByTestId("supporters"); |
| 39 | + expect(screen.getByTestId("supporters")).toBeInTheDocument(); |
| 40 | + expect(screen.getByText("SUPPORTERS")).toBeInTheDocument(); |
| 41 | + expect(screen.getAllByRole("link")).toHaveLength(1); |
| 42 | + }); |
46 | 43 |
|
47 | | - fireEvent.mouseEnter(supportersElement); |
| 44 | + it("applies hover styles on mouse enter", () => { |
| 45 | + render( |
| 46 | + <React.Suspense fallback={<span>Loading...</span>}> |
| 47 | + <Routes> |
| 48 | + <Route path={"*"} |
| 49 | + element={<Supporters sponsors={supporters}/>}/> |
| 50 | + </Routes> |
| 51 | + </React.Suspense>, |
| 52 | + {wrapper: BrowserRouter} |
| 53 | + ); |
| 54 | + const supportersElement = screen.getByTestId("supporters"); |
48 | 55 |
|
49 | | - expect(supportersElement).toHaveClass("SponsorItem"); |
50 | | - expect(screen.getByText("SUPPORTERS")).toHaveStyle( |
51 | | - "color: rgb(255, 252, 249)" |
52 | | - ); |
53 | | - }); |
| 56 | + fireEvent.mouseEnter(supportersElement); |
54 | 57 |
|
55 | | - it.skip("removes hover styles on mouse leave", () => { |
56 | | - render( |
57 | | - <React.Suspense fallback={<span>Loading...</span>}> |
58 | | - <Routes> |
59 | | - <Route path={"*"} element={<Supporters />} /> |
60 | | - </Routes> |
61 | | - </React.Suspense>, |
62 | | - { wrapper: BrowserRouter } |
63 | | - ); |
64 | | - const supporterElement = screen.getByTestId("supporters"); |
| 58 | + expect(supportersElement).toHaveClass("SponsorItem"); |
| 59 | + expect(screen.getByText("SUPPORTERS")).toHaveStyle( |
| 60 | + "color: rgb(255, 252, 249)" |
| 61 | + ); |
| 62 | + }); |
65 | 63 |
|
66 | | - fireEvent.mouseEnter(supporterElement); |
67 | | - fireEvent.mouseLeave(supporterElement); |
| 64 | + it("removes hover styles on mouse leave", () => { |
| 65 | + render( |
| 66 | + <React.Suspense fallback={<span>Loading...</span>}> |
| 67 | + <Routes> |
| 68 | + <Route path={"*"} |
| 69 | + element={<Supporters sponsors={supporters}/>}/> |
| 70 | + </Routes> |
| 71 | + </React.Suspense>, |
| 72 | + {wrapper: BrowserRouter} |
| 73 | + ); |
| 74 | + const supporterElement = screen.getByTestId("supporters"); |
68 | 75 |
|
69 | | - expect(supporterElement).not.toHaveClass("hovered"); |
70 | | - expect(screen.getByText("SUPPORTERS")).toHaveStyle("color: rgb(0, 36, 84)"); |
71 | | - }); |
| 76 | + fireEvent.mouseEnter(supporterElement); |
| 77 | + fireEvent.mouseLeave(supporterElement); |
| 78 | + |
| 79 | + expect(supporterElement).not.toHaveClass("hovered"); |
| 80 | + expect(screen.getByText("SUPPORTERS")).toHaveStyle("color: rgb(0, 36, 84)"); |
| 81 | + }); |
72 | 82 | }); |
0 commit comments