」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 Cypress 進行 API 測試:完整指南

使用 Cypress 進行 API 測試:完整指南

發佈於2024-11-04
瀏覽:339

API Testing with Cypress: A Complete Guide

介绍

Cypress 以其端到端测试能力而闻名,但它也是测试 API 的强大工具。 API 测试是确保现代 Web 应用程序的可靠性、性能和安全性的重要组成部分,因为当今许多应用程序严重依赖后端服务和 API。这篇文章将引导您了解使用 Cypress 进行 API 测试的基础知识,包括设置 API 测试、发出请求、验证响应以及自动化流程。

为什么使用 Cypress 进行 API 测试?

  1. 内置功能: Cypress 具有用于发出 HTTP 请求、断言和管理异步测试的内置功能。
  2. 轻松集成:您可以轻松地将 API 测试与 UI 测试一起集成到现有的 Cypress 测试套件中。
  3. 出色的开发人员体验: Cypress 提供用户友好的界面、快速反馈和实时调试。
  4. 自动化:您可以在 CI/CD 管道中自动化 API 测试,确保每次部署时对 API 进行一致的测试。

Cypress 中的 API 测试入门

如果您已经安装了 Cypress 进行端到端测试,那么您就可以开始 API 测试了。如果没有,请按照以下安装步骤操作。

第 1 步:安装 Cypress

npm install cypress --save-dev

安装后,您可以使用以下命令运行 C​​ypress:

npx cypress open

第 2 步:设置您的第一个 API 测试
Cypress 提供了 cy.request() 方法,可用于发送 HTTP 请求。以下是测试返回用户列表的 API 的基本示例:

describe('API Testing with Cypress', () => {
  it('should retrieve a list of users', () => {
    cy.request('GET', 'https://jsonplaceholder.typicode.com/users')
      .then((response) => {
        // Validate the status code
        expect(response.status).to.eq(200);

        // Validate the response body
        expect(response.body).to.have.length(10);
        expect(response.body[0]).to.have.property('name');
      });
  });
});

在此示例中,我们正在测试 GET 请求来检索用户列表。 Cypress 验证响应状态代码并检查响应正文是否包含 10 个用户。

API测试中常用的HTTP方法

以下是如何在 Cypress 中执行常见的 HTTP 请求,例如 GET、POST、PUT 和 DELETE。

GET请求
GET 请求用于从服务器检索数据。例如:

cy.request('GET', 'https://jsonplaceholder.typicode.com/posts/1')
  .then((response) => {
    expect(response.status).to.eq(200);
    expect(response.body).to.have.property('id', 1);
  });

POST 请求
POST 请求用于在服务器上创建新资源。以下是测试 POST 请求的方法:

cy.request('POST', 'https://jsonplaceholder.typicode.com/posts', {
  title: 'New Post',
  body: 'This is the content of the new post.',
  userId: 1
})
  .then((response) => {
    expect(response.status).to.eq(201);
    expect(response.body).to.have.property('title', 'New Post');
  });

PUT 请求
PUT 请求用于更新现有资源。例子:

cy.request('PUT', 'https://jsonplaceholder.typicode.com/posts/1', {
  id: 1,
  title: 'Updated Post Title',
  body: 'Updated content',
  userId: 1
})
  .then((response) => {
    expect(response.status).to.eq(200);
    expect(response.body).to.have.property('title', 'Updated Post Title');
  });

删除请求
DELETE 请求用于删除资源。例子:

cy.request('DELETE', 'https://jsonplaceholder.typicode.com/posts/1')
  .then((response) => {
    expect(response.status).to.eq(200);
  });

先进的API测试技术

一旦您掌握了基本的 API 请求,您就可以继续学习更高级的 API 测试技术,例如处理身份验证、测试 API 失败和链接 API 调用。

处理身份验证
某些 API 需要通过令牌或 API 密钥进行身份验证。 Cypress 可以通过设置自定义标头来处理身份验证。例如:

cy.request({
  method: 'GET',
  url: 'https://api.example.com/protected',
  headers: {
    Authorization: `Bearer ${Cypress.env('auth_token')}`
  }
})
  .then((response) => {
    expect(response.status).to.eq(200);
  });

此处,授权标头用于随请求一起发送令牌。

测试 API 失败
测试 API 在出现问题(例如无效输入或缺少资源)时的行为非常重要。例如,测试404错误:

cy.request({
  method: 'GET',
  url: 'https://jsonplaceholder.typicode.com/posts/9999',
  failOnStatusCode: false
})
  .then((response) => {
    expect(response.status).to.eq(404);
  });

通过设置failOnStatusCode: false,Cypress 不会自动对非 2xx 响应进行测试失败,从而允许您验证错误响应。

链接 API 调用
有时,您需要将多个 API 调用链接在一起,例如,创建一个资源,然后在后续测试中使用它:

cy.request('POST', 'https://jsonplaceholder.typicode.com/posts', {
  title: 'Post for chaining',
  body: 'Chained post content',
  userId: 1
}).then((postResponse) => {
  cy.request('GET', `https://jsonplaceholder.typicode.com/posts/${postResponse.body.id}`)
    .then((getResponse) => {
      expect(getResponse.body).to.have.property('title', 'Post for chaining');
    });
});

在此示例中,POST 请求创建一个新帖子,GET 请求根据第一次调用返回的 ID 检索该帖子。

在 CI/CD 管道中自动化 API 测试

为了确保 API 的稳定性,将 API 测试作为持续集成/持续部署 (CI/CD) 管道的一部分来运行至关重要。 Cypress 可以轻松集成到 Jenkins、GitHub Actions 或 Travis CI 等 CI/CD 工具中。

以下是在每次推送时运行 Cypress 测试的 GitHub Actions 工作流程示例:

name: CI

on:
  push:
    branches:
      - main

jobs:
  test:
    runs-on: ubuntu-latest

    steps:
      - name: Checkout code
        uses: actions/checkout@v2

      - name: Set up Node.js
        uses: actions/setup-node@v2
        with:
          node-version: '14'

      - name: Install dependencies
        run: npm install

      - name: Run Cypress tests
        run: npx cypress run

此工作流程确保每次将代码推送到主分支时都会自动执行 API 测试。

使用 Cypress 进行 API 测试的最佳实践

为了确保您的 API 测试可靠、可维护且高效,请遵循以下最佳实践:

  1. 使用环境变量: 在环境变量中存储 API 密钥、令牌或基本 URL 等敏感数据。
  2. 必要时模拟响应:如果您不想每次都访问真实的 API,请使用 cy.intercept() 模拟 API 响应。
  3. 处理速率限制:如果您的 API 有速率限制,请确保您的测试通过在请求之间添加重试或延迟来适当处理它们。
  4. 保持测试独立:确保每个 API 测试独立于其他测试,以便它们可以按任何顺序运行而不会出现依赖性问题。
  5. 关注边缘情况: 测试快乐路径和边缘情况(例如无效输入、大数据集、速率限制)以涵盖所有潜在场景。

结论

API 测试是确保应用程序无缝运行的重要组成部分,即使它依赖于外部服务或后端 API。 Cypress 提供了一种简单而强大的方法来测试 API 和 UI 测试,使其成为使用现代 JavaScript 应用程序的开发人员的绝佳选择。通过利用 cy.request()、断言和 CI/CD 集成等功能,您可以构建强大且可靠的 API 测试套件,以尽早发现问题并确保 API 的质量。

立即开始​​使用 Cypress 测试您的 API,并通过自动化、可靠的测试改进您的开发工作流程!

版本聲明 本文轉載於:https://dev.to/aswani25/api-testing-with-cypress-a-complete-guide-7p7?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-18
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-18
  • 如何在JQuery AJAX中同時傳送FormData和字串資料?
    如何在JQuery AJAX中同時傳送FormData和字串資料?
    在JQuery AJAX 中同時發送FormData 和字串資料處理涉及文件上傳的表單時,需要將文件資料與附加資料結合起來用於提交到伺服器的字串資料。以下是如何在JQuery AJAX 中使用FormData() 來實現此目的:使用檔案和字串資料建立FormData:// Create a new ...
    程式設計 發佈於2024-11-18
  • 為什麼 Go 中的 http.Request 類型使用指標?
    為什麼 Go 中的 http.Request 類型使用指標?
    瞭解http.Request中的指標要求在Go程式語言中,指針對於有效處理大型結構至關重要。 http.Request 類型表示傳入的 HTTP 請求,是這種結構的一個主要範例。 在 Go 的語法中,指標是一種儲存另一個值的位址的資料類型。當參數透過指標傳遞時,函數內對該參數所做的任何變更都會全域反...
    程式設計 發佈於2024-11-18
  • 如何在 Chrome 實驗功能中使用 JavaScript 從瀏覽器連接到 TCP 套接字?
    如何在 Chrome 實驗功能中使用 JavaScript 從瀏覽器連接到 TCP 套接字?
    使用JavaScript 從瀏覽器連接到TCP 套接字當您尋求在瀏覽器的JavaScript 和.NET 應用程式託管的TCP 套接字之間在建立雙向通訊時,目前的Web 技術格局提出了挑戰。 到目前為止,流行的瀏覽器缺乏 JavaScript 的標準化套接字 API。然而,有希望的進展正在發生。允許...
    程式設計 發佈於2024-11-18
  • 如果 Go 函數發生緊急情況,如何回傳錯誤?
    如果 Go 函數發生緊急情況,如何回傳錯誤?
    從Go 中的Defer 返回您遇到了這樣的問題:如果Go 中的函數發生緊急情況,您希望返回錯誤。這是對您的程式碼的分析和修復:func getReport(filename string) (rep report, err error) { rep.data = make(map[strin...
    程式設計 發佈於2024-11-18
  • 如何有效調試 Python 程式碼:實用技巧和工具
    如何有效調試 Python 程式碼:實用技巧和工具
    Python 調試:實用技巧與工具Python 調試:實用技巧與工具在對Python 程式碼進行故障排除時,擁有一個可供使用的調試技術工具包至關重要。以下是一些非常有效的技巧:PDB:強大的斷點工具import pdb a = "a string" pdb.set_trace()...
    程式設計 發佈於2024-11-17
  • 如何在不重新啟動伺服器的情況下清除MySQL查詢快取?
    如何在不重新啟動伺服器的情況下清除MySQL查詢快取?
    在不恢復伺服器的情況下減輕MySQL 查詢快取儘管MySQL 查詢快取提供了更高的效能,但在需要時可能會發生這種情況可以在不中斷伺服器運行的情況下進行清除。以下是實現此目的的一些方法:重置查詢快取如果執行命令的使用者俱有重新載入權限,則可以使用以下命令明確刪除查詢快取指令:RESET QUERY C...
    程式設計 發佈於2024-11-17
  • MySQL 如何處理表名和列名的區分大小寫?
    MySQL 如何處理表名和列名的區分大小寫?
    MySQL 中列名和表名的大小寫敏感度MySQL 中的大小寫敏感度主題可能會讓許多用戶感到困惑。了解列名和表名的大小寫敏感度對於確保正確的資料庫操作和避免潛在的陷阱至關重要。 表名表名是否區分大小寫取決於在執行 MySQL 伺服器的作業系統上。在基於 Unix 的系統(例如 Linux)上,表名稱區...
    程式設計 發佈於2024-11-17
  • 為什麼將常數引用綁定到臨時物件會延長其生命週期?
    為什麼將常數引用綁定到臨時物件會延長其生命週期?
    為什麼將常數引用綁定到臨時物件會延長臨時物件的生命週期? C 程式語言允許常數引用來延長臨時物件的生命週期。這種行為一直是許多爭論的主題,有些人認為它可以提高程式碼設計的效能和靈活性。 這種語言功能的起源可以追溯到 1993 年,當時它被提議作為以下問題的解決方案:綁定到引用時臨時變數的處理不一致。...
    程式設計 發佈於2024-11-17
  • 如何在共享主機的子目錄中託管 Laravel 專案而不在 URL 中暴露“/public”
    如何在共享主機的子目錄中託管 Laravel 專案而不在 URL 中暴露“/public”
    在共享主機上託管 Laravel 專案時,一個常見的挑戰是確保 URL 不需要 /public 目錄。這是在子目錄中託管 Laravel 應用程式同時保持 URL 乾淨的逐步指南。 第 1 步:將 Laravel 專案上傳到伺服器 登入您的託管帳戶並存取您的文件管理器。 導覽至 ...
    程式設計 發佈於2024-11-17
  • 程式設計面試中解決問題的終極指南
    程式設計面試中解決問題的終極指南
    Common Strategies for Coding Interview Questions Two Pointers The two pointers technique is often used to solve array-related problem...
    程式設計 發佈於2024-11-17
  • 為什麼 ASAP (Atlassian) Auth 是 REST API 驗證的快速且安全的選擇?
    為什麼 ASAP (Atlassian) Auth 是 REST API 驗證的快速且安全的選擇?
    作为一名广泛使用 API 的高级开发人员,安全性和效率始终是重中之重。在保护 REST API 方面,有多种身份验证方法可用,但并非所有方法都是相同的。 Atlassian 的 ASAP(服务和项目身份验证)Auth 作为一个强大、可扩展且安全的选项而脱颖而出,特别是在处理需要强大身份验证机制的...
    程式設計 發佈於2024-11-17

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

Copyright© 2022 湘ICP备2022001581号-3