aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--jest.config.js7
-rw-r--r--src/pages/CallbackPage.tsx2
-rw-r--r--src/setupTests.ts5
-rw-r--r--src/tests/App.test.tsx9
-rw-r--r--src/tests/api/forms.test.ts11
-rw-r--r--src/tests/components/OAuth2Button.test.tsx1
-rw-r--r--src/tests/components/Tag.test.tsx1
-rw-r--r--src/tests/globalStyles.test.ts5
-rw-r--r--src/tests/pages/CallbackPage.test.tsx23
-rw-r--r--src/tests/pages/FormPage.test.tsx32
-rw-r--r--src/tests/pages/LandingPage.test.tsx13
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();
+});