“BUG” is a huge emotional word for
Software Engineers
by Israel Romero and Thomas Truong
A library providing the implementation (methods/functions) to mount React components (in a virtual DOM) + the means to access (and interact) with the tree that is created as a result.
import { useEffect, useState } from "react";
import "./App.css";
function App() {
const [name, setName] = useState();
useEffect(() => {
fetch("https://swapi.dev/api/people/1")
.then((response) => response.json())
.then((data) => {
setName(data.name);
});
}, []);
return (
<>
<h1>Star Wars</h1>
<span>name: {name}</span>
</>
);
}
export default App;
import { render, screen } from "@testing-library/react";
import App from "./App";
it("renders text", () => {
render(<App />);
expect(screen.getByText(/star wars/i)).toBeVisible();
});
import { useEffect, useState } from "react";
import "./App.css";
function App() {
const [name, setName] = useState();
useEffect(() => {
fetch("https://swapi.dev/api/people/1")
.then((response) => response.json())
.then((data) => {
setName(data.name);
});
}, []);
return (
<>
<h1>Star Wars</h1>
<span>name: {name}</span>
</>
);
}
export default App;
import { render, screen } from "@testing-library/react";
import App from "./App";
it("renders Luke", async () => {
render(<App />);
expect(await screen.findByText(/Luke/i)).toBeVisible();
});
import { useEffect, useState } from "react";
import "./App.css";
function App() {
const [name, setName] = useState();
useEffect(() => {
fetch("https://swapi.dev/api/people/1")
.then((response) => response.json())
.then((data) => {
setName(data.name);
});
}, []);
return (
<>
<h1>Star Wars</h1>
<span>name: {name}</span>
</>
);
}
export default App;
import { render, screen } from "@testing-library/react";
import App from "./App";
it("something that is not there", () => {
render(<App />);
expect(screen.queryByText(/Darth Vader/i)).toBeNull();
});
import { render, screen } from "@testing-library/react";
import "@testing-library/jest-dom";
import App from "./App";
const mockFetch = jest
.fn()
.mockReturnValue(
Promise.resolve({ json: () => Promise.resolve({ name: "Luke Skywalker" }) })
);
window.fetch = mockFetch;
describe("App Component", () => {
beforeEach(() => {
render(<App />);
});
it("Title is displayed", () => {
expect(screen.getByText(/star wars/i)).toBeVisible();
});
it("Luke is displayed after the fetch", async () => {
expect(screen.queryByText(/luke/i)).toBeNull();
expect(mockFetch).toHaveBeenCalled();
expect(await screen.findByText(/luke/i)).toBeVisible();
});
});
We will be presenting a test demo in Web Members. It can be accessed at the link below:
React-scripts
is a preconfigured set of commands that come out of the box with create-react-app
.
react-scripts test
command expects the tests folder to follow a certain conversation and doesn't work well with extensions.
scripts: {
...
"test": "jest",
...
}
{
"preset": "ts-jest",
"testEnvironment": "jsdom",
"transform": {
"^.+\\.(js|jsx)$": "babel-jest"
},
"moduleNameMapper": {
"\\.(svg|woff|png|mp3)": "<rootDir>/src/__mocks__/fileMock.ts"
},
"setupFiles": ["<rootDir>/src/setupTests.js"],
"testPathIgnorePatterns": [
"/node_modules/",
"src/components/calendars/**/AddAvailabilityForm.test.tsx",
]
}
{
"presets": [
"@babel/preset-env",
"@babel/preset-react"
],
}
https://marketplace.visualstudio.com/items?itemName=Orta.vscode-jest
Demo
Demo
"test": "jest",
"test:ci": "yarn test --maxWorkers=2 --watchAll=false",
"test:ci:cov": "yarn test:ci --coverage",
"test:cov": "yarn test --coverage",
## Description
_Please include a summary of the changes_
**Link to JIRA ticket**
## Checklist
- [ ] Tested with feature branch
- [ ] Added unit test for feature
- name: Run test
run: yarn test:ci:cov --json --outputFile=jest-results.json
- name: Post test results 🚨
if: failure()
uses: im-open/process-jest-test-results@v2.1.3
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
results-file: 'jest-results.json'
jobs:
development:
steps:
- name: Run test
run: yarn test:ci:cov
- name: Build
run: yarn build
production:
steps:
- name: Run test
run: yarn test:ci
- name: Run test
run: yarn test:ci:cov
- name: Add coverage badge
uses: we-cli/coverage-badge-action@main
"coverageThreshold": {
"./src/components/calendars/FullCalendar/components/appointments/": {
"lines": 43
},
"./src/helpers/": {
"lines": 20
}
}
jest.config.json
./coverage/lcov-report/index.html