- 首先安裝好Jest
npm install --save-dev jest @types/jest
- 接下來安裝RTL
npm install --save-dev @testing-library/react
- 為了用useful matcher,安裝jest-dom
npm install --save-dev @testing-library/jest-dom
- 因為Babel跑TypeScript爛爛的,作者建議安裝這個(下面這個我還沒裝)
npm install --save-dev ts-jest
如果你的JavaScript檔案有用到Babel,那你還需要安裝這個咚咚
pnpm i babel-jest -D
安裝這個讓 jest 看得懂測試檔裡面的TypeScript
pnpm i @babel/preset-typescript -D
參考jest搭配TypeScript的安裝備置。記得在babelrc檔也要加進去
這樣加下來發現跑測試訊息不一樣了,說render有問題,查了一下是React Testing Library 還需要配置環境
data:image/s3,"s3://crabby-images/1a1a2/1a1a2ffcde586c3e2fde3c558a43a7fcadc06552" alt=""
所以就安裝下面這個
pnpm install --save-dev jest-environment-jsdom
接下來訊息又不一樣惹,說我的App沒有用Provider來包
Error: could not find react-redux context value; please ensure the component is wrapped in a ….
改一下就好了,太簡單就不講了。
接下來測試過了,只剩下一些fetch什麼的API的問題
ReferenceError: fetch is not defined
針對這點查這這篇文章之後,就安裝個這個套件然後加到setup檔就解決了
pnpm i whatwg-fetch -D
data:image/s3,"s3://crabby-images/1028c/1028cd962f2b85613269909a35ff14d735997462" alt=""
data:image/s3,"s3://crabby-images/ed444/ed444923cebb38f6fd856e372a33c0721c069fbe" alt=""
然後大功告成 ~~天啊還蠻簡單的啊
然後發現有的方法用起來會有紅波浪。
TS2339: Property ‘toBeInTheDocument’ does not exist on type ‘JestMatchers ‘.
結果安裝一個奇怪名子的套件就解決了…看它名子怪怪的本來都不想安裝的。而且還不用去eslint配什麼東西,超…超幹
Property ‘toBeChecked’ does not exist on type ‘Matchers<void, Element>’ · Issue #442 · testing-library/jest-dom (github.com)
pnpm install --save-dev @types/testing-library__jest-dom
data:image/s3,"s3://crabby-images/56f97/56f979205f7f61662fc27c0cdfcce6de8cc5c86d" alt=""
data:image/s3,"s3://crabby-images/0f967/0f96738c0e0b075d2c20bda99a0107e0b4623817" alt=""
data:image/s3,"s3://crabby-images/3ad91/3ad919d9e1dfdcae633abd9aeca1010e6860e841" alt=""
data:image/s3,"s3://crabby-images/e138a/e138a19540da005baf7f503ae483537ec077a385" alt=""
之後來做假資料。
pnpm install msw -D