」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 Playwright-Network-Cache 增強您的 ETests

使用 Playwright-Network-Cache 增強您的 ETests

發佈於2024-11-07
瀏覽:807

Supercharge Your ETests with Playwright-Network-Cache

简介

当使用像 Playwright 这样的端到端测试框架时,处理网络请求通常是一项复杂的任务。依赖外部 API 的测试可能会很慢且不一致,从而引入不必要的不​​稳定。由于服务器缓慢或不可靠,在一次测试运行中成功的网络调用可能在下一次测试运行中失败,从而导致结果不一致。为了解决这个问题,开发人员经常诉诸模拟网络请求,这带来了另一个挑战:管理模拟。

如果有一种自动化的方式来处理缓存和重用网络响应而不需要设置复杂的模拟策略,这不是很棒吗?我研究了现有的方法并开发了一个我想介绍的工具。它通过在文件系统上缓存网络请求来解决这些具体问题,从而实现更快、更可靠的 Playwright 测试。

测试中网络请求的问题

网络请求通常是测试执行中最慢的部分。运行多个测试套件时,重复查询外部 API 会显着增加测试持续时间。此外,现实世界的 API 可能不稳定,偶尔会超时,使您的测试脆弱且不可靠。

缓解这种情况的常见方法是模拟 API 响应。虽然有用,但模拟需要手动干预 - 您需要仔细构建模拟响应,不断更新它们,并确保处理每个潜在的网络场景。随着 API 的发展或测试用例的变化,这可能会成为巨大的维护负担。 Playwright 支持 HAR 文件来捕获和重放网络流量,但使用 HAR 可能很乏味,并且缺乏动态修改响应的灵活性。

输入剧作家网络缓存

playwright-network-cache 旨在简化 Playwright 测试中缓存网络响应的过程,消除对手动模拟或严格的 HAR 文件的需要。有了这个库,网络响应在第一次测试运行期间会自动存储在文件系统上,并且可以在后续运行中重用,从而显着加快测试执行速度。此外,响应保存在清晰、有组织的文件夹结构中,以便根据需要轻松检查和修改它们。

它如何解决问题

  1. 自动缓存:第一次运行测试时,库会自动缓存网络响应。这意味着您的测试在将来的运行中不必等待外部 API 响应 - 将使用缓存的数据,从而实现更快、更可靠的测试。

  2. 动态修改:需要调整特定测试用例的响应? playwright-network-cache 允许您动态修改缓存的响应。无论您想要更改状态代码、标头还是响应正文,该库都提供了即时调整缓存数据的选项,而无需手动维护单独的模拟。

  3. 灵活的结构:缓存系统根据主机名、请求方法和 URL 路径组织文件,确保您可以轻松浏览和管理缓存数据。对于更复杂的情况,您甚至可以按请求查询参数、请求正文或其他自定义字段拆分缓存文件,确保数据存储和重用方式的完全灵活性。

  4. 速度提升:通过重用缓存的响应,您的测试不再需要等待网络调用完成,从而使测试速度显着加快。当使用大型测试套件或在速度至关重要的 CI 环境中运行测试时,这特别有用。

  5. 不再有模拟地狱:忘记手动维护模拟。该库会为您处理一切 - 从缓存到重放,甚至修改响应。您不再需要为每个测试场景手动制作模拟响应,并且可以更多地关注测试逻辑。

  6. 无 HAR 复杂性:HAR 文件对于记录和重放网络交互非常有用,但它们很快就会变得很麻烦,尤其是当您需要修改响应时。 playwright-network-cache 提供了一种更干净、更灵活的 HAR 替代方案,让您可以将各个响应作为简单的 JSON 文件进行管理。

例子

假设您正在测试一个从 API 获取猫列表的应用程序。如果没有缓存,每次测试运行都需要向 API 发出实时请求,从而为您的测试增加延迟和潜在的故障点。

使用 playwright-network-cache,您可以轻松缓存 API 响应:

test('test', async ({ page, cacheRoute }) => {
  await cacheRoute.GET('https://example.com/api/cats');
  // Perform usual test actions...
});

第一次运行时,响应被缓存在 .network-cache 目录中,其结构如下:

.network-cache
└── example.com
    └── api-cats
        └── GET
            ├── headers.json
            └── body.json

在后续运行中,缓存的响应将被重用,从而使测试速度更快,并且无需访问实际的 API。

您可以根据特定测试需求修改缓存的响应:

test('test', async ({ page, cacheRoute }) => {
  await cacheRoute.GET('https://example.com/api/cats', {
    modify: async (route, response) => {
      const json = await response.json();
      json[0].name = 'Kitty-1';
      await route.fulfill({ json });
    }
  });
  // Perform usual test actions...
});

要在测试中获取可用的 cacheRoute 变量,请像任何其他 Playwright 固定装置一样实例化它:

// fixtures.js
import { test as base } from '@playwright/test';
import { CacheRoute } from 'playwright-network-cache';

export const test = base.extend({
  cacheRoute: async ({ page }, use) => {
    const cacheRoute = new CacheRoute(page, { /* cache options */ });
    await use(cacheRoute);
  },
});

库文档中还有许多其他示例和用例。

不仅仅是缓存

playwright-network-cache 不仅仅是缓存。它提供高级功能,例如:

  • 修改响应:使用自定义函数动态调整缓存响应中的数据。
  • 处理状态代码:根据特定的 HTTP 状态代码缓存响应,包括错误。
  • 灵活的目录结构:自定义缓存文件的存储方式和位置,允许您根据需要定制缓存策略。
  • 禁用或更新缓存:暂时禁用特定测试的缓存或在需要时强制更新缓存。

利用这些强大的功能,您可以精细地控制测试中网络请求的管理方式。

回顾

如果您希望让 Playwright 测试更快、更可靠,请尝试 playwright-network-cache。通过在文件系统上缓存网络响应并允许动态修改,它消除了手动模拟的需要,并为 HAR 文件提供了灵活、易于使用的替代方案。

感谢您的阅读❤️

版本聲明 本文轉載於:https://dev.to/vitalets/supercharge-your-e2e-tests-with-playwright-network-cache-58jm?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在細胞編輯後,如何維護自定義的JTable細胞渲染?
    在細胞編輯後,如何維護自定義的JTable細胞渲染?
    在JTable中維護jtable單元格渲染後,在JTable中,在JTable中實現自定義單元格渲染和編輯功能可以增強用戶體驗。但是,至關重要的是要確保即使在編輯操作後也保留所需的格式。 在設置用於格式化“價格”列的“價格”列,用戶遇到的數字格式丟失的“價格”列的“價格”之後,問題在設置自定義單元...
    程式設計 發佈於2025-07-08
  • 如何正確使用與PDO參數的查詢一樣?
    如何正確使用與PDO參數的查詢一樣?
    在pdo 中使用類似QUERIES在PDO中的Queries時,您可能會遇到類似疑問中描述的問題:此查詢也可能不會返回結果,即使$ var1和$ var2包含有效的搜索詞。錯誤在於不正確包含%符號。 通過將變量包含在$ params數組中的%符號中,您確保將%字符正確替換到查詢中。沒有此修改,PD...
    程式設計 發佈於2025-07-08
  • C++成員函數指針正確傳遞方法
    C++成員函數指針正確傳遞方法
    如何將成員函數置於c 的函數時,接受成員函數指針的函數時,必須同時提供對象的指針,並提供指針和指針到函數。需要具有一定簽名的功能指針。要通過成員函數,您需要同時提供對象指針(此)和成員函數指針。這可以通過修改Menubutton :: SetButton()(如下所示:[&& && && &&華)...
    程式設計 發佈於2025-07-08
  • Java字符串非空且非null的有效檢查方法
    Java字符串非空且非null的有效檢查方法
    檢查字符串是否不是null而不是空的 if(str!= null && str.isementy())二手: if(str!= null && str.length()== 0) option 3:trim()。 isement(Isement() trim whitespace whites...
    程式設計 發佈於2025-07-08
  • C++20 Consteval函數中模板參數能否依賴於函數參數?
    C++20 Consteval函數中模板參數能否依賴於函數參數?
    [ consteval函數和模板參數依賴於函數參數在C 17中,模板參數不能依賴一個函數參數,因為編譯器仍然需要對非contexexpr futcoriations contim at contexpr function進行評估。 compile time。 C 20引入恆定函數,必須在編譯時進...
    程式設計 發佈於2025-07-08
  • 找到最大計數時,如何解決mySQL中的“組函數\”錯誤的“無效使用”?
    找到最大計數時,如何解決mySQL中的“組函數\”錯誤的“無效使用”?
    如何在mySQL中使用mySql 檢索最大計數,您可能會遇到一個問題,您可能會在嘗試使用以下命令:理解錯誤正確找到由名稱列分組的值的最大計數,請使用以下修改後的查詢: 計數(*)為c 來自EMP1 按名稱組 c desc訂購 限制1 查詢說明 select語句提取名稱列和每個名稱...
    程式設計 發佈於2025-07-08
  • 如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    如何將PANDAS DataFrame列轉換為DateTime格式並按日期過濾?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用時間數據時...
    程式設計 發佈於2025-07-08
  • 如何檢查對像是否具有Python中的特定屬性?
    如何檢查對像是否具有Python中的特定屬性?
    方法來確定對象屬性存在尋求一種方法來驗證對像中特定屬性的存在。考慮以下示例,其中嘗試訪問不確定屬性會引起錯誤: >>> a = someClass() >>> A.property Trackback(最近的最新電話): 文件“ ”,第1行, attributeError:SomeClass實...
    程式設計 發佈於2025-07-08
  • 在PHP中如何高效檢測空數組?
    在PHP中如何高效檢測空數組?
    在PHP 中檢查一個空數組可以通過各種方法在PHP中確定一個空數組。如果需要驗證任何數組元素的存在,則PHP的鬆散鍵入允許對數組本身進行直接評估:一種更嚴格的方法涉及使用count()函數: if(count(count($ playerList)=== 0){ //列表為空。 } 對...
    程式設計 發佈於2025-07-08
  • 為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    為什麼我在Silverlight Linq查詢中獲得“無法找到查詢模式的實現”錯誤?
    查詢模式實現缺失:解決“無法找到”錯誤在銀光應用程序中,嘗試使用LINQ建立錯誤的數據庫連接的嘗試,無法找到以查詢模式的實現。 ”當省略LINQ名稱空間或查詢類型缺少IEnumerable 實現時,通常會發生此錯誤。 解決問題來驗證該類型的質量是至關重要的。在此特定實例中,tblpersoon可能...
    程式設計 發佈於2025-07-08
  • 如何使用FormData()處理多個文件上傳?
    如何使用FormData()處理多個文件上傳?
    )處理多個文件輸入時,通常需要處理多個文件上傳時,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    程式設計 發佈於2025-07-08
  • PHP SimpleXML解析帶命名空間冒號的XML方法
    PHP SimpleXML解析帶命名空間冒號的XML方法
    在php 很少,請使用該限制很大,很少有很高。例如:這種技術可確保可以通過遍歷XML樹和使用兒童()方法()方法的XML樹和切換名稱空間來訪問名稱空間內的元素。
    程式設計 發佈於2025-07-08
  • 如何使用“ JSON”軟件包解析JSON陣列?
    如何使用“ JSON”軟件包解析JSON陣列?
    parsing JSON與JSON軟件包 QUALDALS:考慮以下go代碼:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    程式設計 發佈於2025-07-08
  • 如何使用Python有效地以相反順序讀取大型文件?
    如何使用Python有效地以相反順序讀取大型文件?
    在python 中,如果您使用一個大文件,並且需要從最後一行讀取其內容,則在第一行到第一行,Python的內置功能可能不合適。這是解決此任務的有效解決方案:反向行讀取器生成器 == ord('\ n'): 緩衝區=緩衝區[:-1] ...
    程式設計 發佈於2025-07-08
  • 如何使用node-mysql在單個查詢中執行多個SQL語句?
    如何使用node-mysql在單個查詢中執行多個SQL語句?
    Multi-Statement Query Support in Node-MySQLIn Node.js, the question arises when executing multiple SQL statements in a single query using the node-mys...
    程式設計 發佈於2025-07-08

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

Copyright© 2022 湘ICP备2022001581号-3