diff options
Diffstat (limited to '')
-rw-r--r-- | jest.config.js | 7 | ||||
-rw-r--r-- | src/pages/CallbackPage.tsx | 2 | ||||
-rw-r--r-- | src/setupTests.ts | 5 | ||||
-rw-r--r-- | src/tests/App.test.tsx | 9 | ||||
-rw-r--r-- | src/tests/api/forms.test.ts | 11 | ||||
-rw-r--r-- | src/tests/components/OAuth2Button.test.tsx | 1 | ||||
-rw-r--r-- | src/tests/components/Tag.test.tsx | 1 | ||||
-rw-r--r-- | src/tests/globalStyles.test.ts | 5 | ||||
-rw-r--r-- | src/tests/pages/CallbackPage.test.tsx | 23 | ||||
-rw-r--r-- | src/tests/pages/FormPage.test.tsx | 32 | ||||
-rw-r--r-- | src/tests/pages/LandingPage.test.tsx | 13 |
11 files changed, 102 insertions, 7 deletions
diff --git a/jest.config.js b/jest.config.js index 165e711..a126998 100644 --- a/jest.config.js +++ b/jest.config.js @@ -3,4 +3,11 @@ module.exports = { '^.+\\.(t|j)sx?$': ['@swc/jest'], '^.+\\.svg$': ['jest-svg-transformer'] }, + collectCoverageFrom: [ + "src/**/*.{js,jsx,ts,tsx}", + "!**/node_modules/**", + ], + collectCoverage: true, + coverageProvider: "v8", + setupFilesAfterEnv: ["./src/setupTests.ts"] } diff --git a/src/pages/CallbackPage.tsx b/src/pages/CallbackPage.tsx index caa384f..d085d28 100644 --- a/src/pages/CallbackPage.tsx +++ b/src/pages/CallbackPage.tsx @@ -4,7 +4,7 @@ import { useState } from "react"; export default function CallbackPage() { const [hasSent, setHasSent] = useState(false); - const params = new URLSearchParams(document.location.search); + const params = new URLSearchParams(location.search); const code = params.get("code"); diff --git a/src/setupTests.ts b/src/setupTests.ts index 74b1a27..4dc2c73 100644 --- a/src/setupTests.ts +++ b/src/setupTests.ts @@ -1,5 +1,2 @@ -// jest-dom adds custom jest matchers for asserting on DOM nodes. -// allows you to do things like: -// expect(element).toHaveTextContent(/react/i) -// learn more: https://github.com/testing-library/jest-dom + import '@testing-library/jest-dom/extend-expect'; diff --git a/src/tests/App.test.tsx b/src/tests/App.test.tsx new file mode 100644 index 0000000..e050d4f --- /dev/null +++ b/src/tests/App.test.tsx @@ -0,0 +1,9 @@ +import React from 'react'; +import { render } from '@testing-library/react'; + +import App from "../App"; + +test('renders app to body', () => { + const { container } = render(<App />); + expect(container).toBeInTheDocument(); +}); diff --git a/src/tests/api/forms.test.ts b/src/tests/api/forms.test.ts new file mode 100644 index 0000000..7c851a7 --- /dev/null +++ b/src/tests/api/forms.test.ts @@ -0,0 +1,11 @@ +import { getForm, getForms } from "../../api/forms"; + +test('fetch a list of all forms', () => { + expect(getForms()).toBeInstanceOf(Array); +}); + +test('fetch a specific form', () => { + expect(getForm("ban-appeals")).resolves.toHaveProperty("title", "Ban Appeals") +}); + +export default null; diff --git a/src/tests/components/OAuth2Button.test.tsx b/src/tests/components/OAuth2Button.test.tsx index 49c0f8a..53875dc 100644 --- a/src/tests/components/OAuth2Button.test.tsx +++ b/src/tests/components/OAuth2Button.test.tsx @@ -1,6 +1,5 @@ import React from 'react'; import { render } from '@testing-library/react'; -import '@testing-library/jest-dom/extend-expect'; import OAuth2Button from "../../components/OAuth2Button"; test('renders oauth2 sign in button text', () => { diff --git a/src/tests/components/Tag.test.tsx b/src/tests/components/Tag.test.tsx index 26c8afb..67f2a85 100644 --- a/src/tests/components/Tag.test.tsx +++ b/src/tests/components/Tag.test.tsx @@ -1,6 +1,5 @@ import React from 'react'; import { render } from '@testing-library/react'; -import '@testing-library/jest-dom/extend-expect'; import Tag from "../../components/Tag"; test('renders tag with specified text', () => { diff --git a/src/tests/globalStyles.test.ts b/src/tests/globalStyles.test.ts new file mode 100644 index 0000000..d44cc51 --- /dev/null +++ b/src/tests/globalStyles.test.ts @@ -0,0 +1,5 @@ +import globalStyles from "../globalStyles"; + +test("global styles emotion css compiles", () => { + expect(globalStyles.styles).not.toBeUndefined(); +}) diff --git a/src/tests/pages/CallbackPage.test.tsx b/src/tests/pages/CallbackPage.test.tsx new file mode 100644 index 0000000..e878577 --- /dev/null +++ b/src/tests/pages/CallbackPage.test.tsx @@ -0,0 +1,23 @@ +import React from 'react'; +import { render } from '@testing-library/react'; + +import CallbackPage from '../../pages/CallbackPage'; + +test('callback page renders provided code', () => { + global.opener = { + postMessage: jest.fn() + } + + let mockLocation = new URL("https://forms.pythondiscord.com/authorize?code=abcdef"); + + Object.defineProperty(global, "location", {value: mockLocation}) + + let comp = <CallbackPage />; + + const { getByText } = render(comp); + + + let codeText = getByText(/Code is abcdef/); + expect(codeText).toBeInTheDocument(); + expect(global.opener.postMessage).toBeCalledTimes(1) +}); diff --git a/src/tests/pages/FormPage.test.tsx b/src/tests/pages/FormPage.test.tsx new file mode 100644 index 0000000..7bfc763 --- /dev/null +++ b/src/tests/pages/FormPage.test.tsx @@ -0,0 +1,32 @@ +import React from 'react'; +import { render } from '@testing-library/react'; + +import { createMemoryHistory } from "history"; + +import { Route, BrowserRouter as Router } from "react-router-dom"; +import FormPage from '../../pages/FormPage'; + +import * as forms from "../../api/forms"; + +test('renders specific form page with loading bar', () => { + const history = createMemoryHistory(); + history.push("/form/route"); + + const { getByText } = render(<Router><Route history={history} ><FormPage /></Route></Router>); + // If we rendered the headerbar we rendered the forms page. + let headerBar = getByText(/Loading.../); + expect(headerBar).toBeInTheDocument(); +}); + +test('calls api method to load form', () => { + const history = createMemoryHistory(); + history.push("/form/ban-appeals"); + + let oldImpl = forms.getForm; + + Object.defineProperty(forms, "getForm", {value: jest.fn(oldImpl)}); + + render(<Router><Route history={history}><FormPage /></Route></Router>); + + expect(forms.getForm).toBeCalled(); +}); diff --git a/src/tests/pages/LandingPage.test.tsx b/src/tests/pages/LandingPage.test.tsx new file mode 100644 index 0000000..ba32bab --- /dev/null +++ b/src/tests/pages/LandingPage.test.tsx @@ -0,0 +1,13 @@ +import React from 'react'; +import { render } from '@testing-library/react'; + +import LandingPage from "../../pages/LandingPage"; + +import { BrowserRouter as Router } from "react-router-dom"; + +test('renders landing page', () => { + const { getByText } = render(<Router><LandingPage /></Router>); + // If we rendered the headerbar we rendered the landing page. + let headerBar = getByText(/Python Discord Forms/); + expect(headerBar).toBeInTheDocument(); +}); |