」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 Jest 測試您的 JavaScript 應用程式

使用 Jest 測試您的 JavaScript 應用程式

發佈於2024-09-01
瀏覽:498

Test Your JavaScript App With Jest

測試是軟體開發的關鍵部分,可確保您的應用程式能如預期運作。 Jest 是 JavaScript 生態系統中最受歡迎的測試框架之一。 Jest 由 Facebook 開發,以其簡單易用而聞名,使其成為初學者和經驗豐富的開發人員的絕佳選擇。

開始使用 Jest

在我們深入範例之前,讓我們在您的專案中設定 Jest。如果尚未安裝,可以使用 npm 安裝它:

npm install --save-dev jest

接下來,將測試腳本新增至您的 package.json 中:

"scripts": {
  "test": "jest"
}

現在您已經準備好要寫一些測試了!
讓我們建立一個簡單的函數來測試。建立一個名為 math.js 的檔案:

// math.js
function add(a, b) {
  return a   b;
}
module.exports = add;

現在,讓我們為這個函數寫一個測試。建立一個名為 math.test.js 的檔案:

// math.test.js
const add = require('./math');

test('adds 1   2 to equal 3', () => {
  expect(add(1, 2)).toBe(3);
});

在這個測試中,我們使用測試函數來定義測試案例。 Expect函數用來斷言add(1, 2)的結果等於3。

運行測試

您可以透過在終端機中執行以下命令來執行測試:

npm test

您應該看到表明您的測試已通過的輸出。

測試非同步程式碼

Jest 也支援測試非同步程式碼。讓我們修改 math.js 檔案以包含非同步函數:

// math.js
function fetchData() {
  return new Promise((resolve) => {
    setTimeout(() => {
      resolve('peanut butter');
    }, 1000);
  });
}

module.exports = { add, fetchData };

現在,讓我們為 fetchData 寫一個測試:

// math.test.js
const { add, fetchData } = require('./math');

test('adds 1   2 to equal 3', () => {
  expect(add(1, 2)).toBe(3);
});

test('fetches data', async () => {
  const data = await fetchData();
  expect(data).toBe('peanut butter');
});

在此測試中,我們將測試函數標記為非同步並使用await 等待promise 解析。

模擬函數

Jest 提供了強大的模擬功能。假設您有一個進行 API 呼叫的函數。您可以模擬此函數以在測試期間控制其行為。
這是一個例子:

// api.js
const axios = require('axios');

async function getUser() {
  const response = await axios.get('https://api.example.com/user');
  return response.data;
}

module.exports = getUser;

您可以在測試中模擬 axios:

// api.test.js
const axios = require('axios');
const getUser = require('./api');

jest.mock('axios');

test('fetches user data', async () => {
  const user = { name: 'John Doe' };
  axios.get.mockResolvedValue({ data: user });

  const result = await getUser();
  expect(result).toEqual(user);
});

在此測試中,我們模擬 axios.get 方法以傳回預先定義的回應,從而允許我們在不進行實際 API 呼叫的情況下測試 getUser。

Jest 是一個功能強大的測試框架,可以輕鬆為 JavaScript 應用程式編寫和運行測試。憑藉其簡單的語法、對非同步程式碼的支援以及內建的類比功能,Jest 可以幫助您確保程式碼的可靠性和可維護性。立即開始將 Jest 整合到您的專案中,享受自動化測試的好處。

版本聲明 本文轉載於:https://dev.to/jospin6/test-your-javascript-app-with-jest-314c?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 React 中建立無限滾動元件
    在 React 中建立無限滾動元件
    介绍 我们在应用程序和网页中看到无限滚动,尤其是希望我们滚动的社交媒体。虽然无意识地滚动不好,但构建自己的无限滚动是很棒的。作为开发人员,我们应该尝试重新创建我们在网上冲浪时看到的组件。它可以挑战您在实现某些组件时了解更多信息并跳出框框进行思考。 此外,如果您希望在应用程序中实现无...
    程式設計 發佈於2024-11-06
  • 在 React 中建立響應式會議圖塊的動態網格系統
    在 React 中建立響應式會議圖塊的動態網格系統
    In the era of remote work and virtual meetings, creating a responsive and dynamic grid system for displaying participant video tiles is crucial. Inspi...
    程式設計 發佈於2024-11-06
  • 使用 Spring Boot 和 Spring Cloud 開發微服務
    使用 Spring Boot 和 Spring Cloud 開發微服務
    微服務架構已成為建構可擴展和模組化系統的流行解決方案。透過微服務,您可以將單一應用程式分解為更小的、獨立的和專業的服務,這使得系統的維護和發展變得更加容易。在這篇文章中,我們將探討如何使用 Spring Boot 和 Spring Cloud 來創造健壯且有效率的微服務。 微服務簡介 微服務背後的...
    程式設計 發佈於2024-11-06
  • 克服 PHP DOM XML 解析中的挑戰:問題與解決方案
    克服 PHP DOM XML 解析中的挑戰:問題與解決方案
    簡化PHP DOM XML 解析:揭開要點當您瀏覽PHP DOM 函數的複雜性時,可能會出現某些障礙。為了解決這些挑戰,讓我們開始了解 DOM 的複雜性,並找出常見問題的解決方案。 問題1:使用xml:id 馴服ID當使用ID 來防止樹中出現重複頁面時,PHP 的DOM 遇到了一個難題:getEle...
    程式設計 發佈於2024-11-06
  • 密碼重設功能:使用 OTP 重設密碼
    密碼重設功能:使用 OTP 重設密碼
    後端 2. 重設密碼 轉向下一個 API。 PUT 上 /api/reset-password, req -> otp, email, 新密碼, res -> nocontent // controllers/passwordReset.go func Reset...
    程式設計 發佈於2024-11-06
  • 如何從全域站點套件繼承 Virtualenv 中的特定套件?
    如何從全域站點套件繼承 Virtualenv 中的特定套件?
    從全域網站套件繼承Virtualenv 中的特定套件為了增強虛擬環境(virtualenv) 的功能,您可能會想要從全域網站繼承特定套件網站套件目錄。這種方法允許您選擇性地將重要的程式庫合併到您的 virtualenv 中,而無需直接安裝它們。 繼承方法要實現這種繼承,請使用以下命令建立新的virt...
    程式設計 發佈於2024-11-06
  • 如何解決 EF6 中的“找不到 'MySql.Data.MySqlClient\'\”錯誤?
    如何解決 EF6 中的“找不到 'MySql.Data.MySqlClient\'\”錯誤?
    MySQL 實體框架的提供者註冊使用MySQL 和實體框架時,您可能會遇到錯誤「找不到Entity Framework提供者” 'MySql.Data.MySqlClient' ADO.NET 提供者。 「儘管安裝了最新的MySQL 連接器,您可能仍然會遇到此問題。出現此問題的原因是...
    程式設計 發佈於2024-11-06
  • 如何利用PHP防止郵件傳輸中的惡意輸入?
    如何利用PHP防止郵件傳輸中的惡意輸入?
    保護電子郵件傳輸的使用者輸入在PHP 中,必須在發送電子郵件之前清理使用者輸入,以防止惡意或有害內容外洩你的系統。考慮下面的簡單 PHP 郵件腳本的程式碼片段:<?php $to = "[email protected]"; $name = $_POST['name']; ...
    程式設計 發佈於2024-11-06
  • 應用程式頁面開發
    應用程式頁面開發
    Если посмотреть на исходный проект, то можно увидеть, что нам необходимо создать одну главную страницу. Результаты поиска авиабилетов, отелей и туров ...
    程式設計 發佈於2024-11-06
  • Java 應用程式中的「No X11 DISPLAY Variable」錯誤:如何為 GUI 功能設定 DISPLAY 變數?
    Java 應用程式中的「No X11 DISPLAY Variable」錯誤:如何為 GUI 功能設定 DISPLAY 變數?
    Java 應用程式中的「No X11 DISPLAY Variable」錯誤Java 應用程式依賴X Window 系統(X11) 來實作圖形使用者介面( GUI)功能。 「未設定 X11 DISPLAY 變數」錯誤表示應用程式無法存取 X11 顯示環境。 要解決此問題,請設定 X11 DISPLA...
    程式設計 發佈於2024-11-06
  • 破解 HashMap 的基礎知識:Java 開發人員的關鍵概念
    破解 HashMap 的基礎知識:Java 開發人員的關鍵概念
    介紹 了解 HashMap 類對於開發人員至關重要,無論是在實際應用程式還是面試中。在這篇文章中,我們將探討如何在 HashMap 中插入、更新和管理鍵值對。這些知識也將為我們的下一篇文章奠定基礎,我們將深入研究 HashSet 並了解這兩個集合之間的關係。 什麼...
    程式設計 發佈於2024-11-06
  • 如何在 .htaccess 中啟用 PHP 錯誤顯示和日誌記錄?
    如何在 .htaccess 中啟用 PHP 錯誤顯示和日誌記錄?
    透過 .htaccess 解決 PHP 錯誤顯示問題測試網站並遇到問題時,錯誤顯示至關重要。但是,此顯示有時可能會被停用。對於僅有權存取 .htaccess 檔案並希望啟用錯誤顯示的用戶,此問題提供了全面的解決方案。 此問題解決了 .htaccess 檔案是唯一可存取資源的情況。它建議添加三個 PH...
    程式設計 發佈於2024-11-06
  • 精選的最佳 React 管理儀表板模板
    精選的最佳 React 管理儀表板模板
    Hi there ?. I'm Syakir, a Front-end engineer. In this page, i curated premium react admin templates from various vendors with top features and design ...
    程式設計 發佈於2024-11-06
  • Gosync.Pool 及其背後的機制
    Gosync.Pool 及其背後的機制
    这是帖子的摘录;完整的帖子可以在这里找到:https://victoriametrics.com/blog/go-sync-pool/ 这篇文章是关于 Go 中处理并发的系列文章的一部分: Gosync.Mutex:正常和饥饿模式 Gosync.WaitGroup 和对齐问题 Gosync.Poo...
    程式設計 發佈於2024-11-06
  • 如何在 PHP 中包含 CSS:詳細指南
    如何在 PHP 中包含 CSS:詳細指南
    在PHP 中包含CSS 檔案:綜合指南在進行Web 開發時,將CSS 樣式合併至PHP 程式碼中對於管理至關重要您的頁面的呈現。然而,眾所周知,使用 HTML 程式碼包含 CSS 檔案是標準方法。在本文中,我們將深入研究基於 PHP 的解決方案,幫助您了解如何將 CSS 檔案直接匯入 PHP 程式碼...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3