編寫 Jest 測試多年後,我最近偶然發現了快照測試 — Jest 中的一項功能,可以簡化對某些類型程式碼(尤其是 UI 元件)的測試。如果您不熟悉,快照測試是斷言元件的渲染輸出沒有意外更改的一種方法。 Jest 產生元件輸出的「快照」並儲存它。未來的測試將當前輸出與此快照進行比較,標記可能表示意外更改的差異。
在這篇文章中,我將分享迄今為止在 Jest 中進行快照測試的經驗,包括我在過程中遇到的優點和缺點。讓我們開始吧!
快照測試是一種捕獲組件或函數的輸出並將其保存為文件的測試技術。當您執行測試時,Jest 會將目前輸出與已儲存的快照進行比較,以確定是否有任何變更。
這是 Jest 中快照測試的簡單範例:
// myComponent.test.js import renderer from 'react-test-renderer'; import Link from '../Link'; it('renders correctly', () => { const tree = renderer .create(<Link page="http://www.facebook.com">Facebook</Link>) .toJSON(); expect(tree).toMatchSnapshot(); });
在此測試中,Jest 渲染 MyComponent 並將輸出儲存為快照。
// myComponent.test.js.snap exports[`renders correctly 1`] = ` <a className="normal" href="http://www.facebook.com" onMouseEnter={[Function]} onMouseLeave={[Function]} > Facebook </a> `;
在後續測試運行中,Jest 會將新輸出與已儲存的快照進行比較,以檢查是否有任何變更。如果輸出發生變化,Jest 會提醒您,以便您查看差異。
快速又簡單: 建立快照測驗很快。透過執行 toMatchSnapshot(),Jest 自動儲存元件目前結構的快照,讓您可以專注於功能。生成的快照儲存在 .snap 檔案中,並與其他快照一起進行版本控制,使變更易於程式碼審查。
減少樣板:快照測試可以幫助消除重複的斷言,特別是在處理複雜的 UI 結構時。這在 UI 狀態頻繁變化的 Vue 或 React 中特別有用。
擷取意外變更:快照測試非常適合擷取程式碼中的意外變更。如果 UI 元件的輸出意外更改,Jest 會將其標記為失敗的測試,提示您查看更改。這可以幫助您及早發現回歸並防止 bug 被遺漏。
Ujian Rapuh: Salah satu kelemahan ujian syot kilat ialah ujian boleh menjadi rapuh dari semasa ke semasa. Jika komponen UI anda kerap berubah, syot kilat mungkin perlu dikemas kini dengan kerap juga. Ini boleh menyebabkan banyak bunyi dalam keputusan ujian anda dan menjadikannya lebih sukar untuk mengenal pasti isu sebenar. Selain itu, syot kilat yang besar boleh membawa kepada fenomena yang dipanggil "buta syot kilat", di mana pembangun tanpa berfikir panjang meluluskan perubahan tanpa memeriksanya dengan teliti.
Kekurangan Konteks: Apabila ujian syot kilat gagal, mungkin sukar untuk memahami sebab output telah berubah. Jest memberikan perbezaan visual tentang perubahan, tetapi ia tidak selalu memberikan anda konteks penuh tentang perkara yang menyebabkan perubahan itu. Ini boleh menjadikan kegagalan penyahpepijatan lebih sukar, terutamanya untuk komponen yang kompleks.
Cerapan Terhad: Semasa syot kilat menyemak sama ada struktur komponen tidak berubah, ia tidak mengesahkan aspek tingkah laku. Anda mungkin masih memerlukan ujian unit atau penyepaduan untuk menampung kes ini. Ujian syot kilat paling sesuai untuk menguji output visual komponen, bukan kefungsiannya.
Ujian syot kilat dalam Jest ialah alat yang berkuasa untuk menguji komponen UI dan menangkap perubahan dalam kod anda. Walaupun ia menawarkan beberapa faedah, seperti persediaan mudah dan menangkap perubahan yang tidak dijangka, ia juga mempunyai kelemahannya, seperti ujian rapuh dan positif palsu. Mungkin lebih baik menggunakan ujian snap shot dengan berhati-hati, untuk komponen yang sepatutnya jarang berubah, dan oleh itu mempunyai syot kilat yang stabil. Ia juga penting untuk diingat bahawa ujian syot kilat hanyalah satu bahagian teka-teki ujian dan harus digunakan bersama-sama dengan strategi ujian lain untuk memastikan liputan ujian yang komprehensif.
Secara keseluruhan, ujian syot kilat ialah teknik yang berguna untuk dimiliki dalam senjata ujian anda, tetapi seperti mana-mana alat, adalah penting untuk menggunakannya dengan bijak dan memahami batasannya. Dengan menimbang kebaikan dan keburukan ujian syot kilat, anda boleh membuat keputusan termaklum tentang sama ada pilihan itu tepat untuk aliran kerja ujian anda.
Atas ialah kandungan terperinci Meneroka Ujian Syot Kilat dalam Jest: Kebaikan dan Keburukan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!