搜尋
首頁web前端js教程有效的前端測試
有效的前端測試Sep 14, 2024 am 06:18 AM

On to effective frontend testing

面試已經有一段時間了。在這個痛苦的過程中最突出的是,如果提出測試問題,面試就注定失敗。這是因為我的經驗主要是前端開發,而我待過的兩家公司在前端測試方面都很糟糕。

--- 如果想直接進入討論請跳過 ---

從某種意義上說,我的缺乏是產業文化的副產品。前端測試一直是一件事,但十年前,公司結構已經將測試問題與開發過程分開。因此,我們有一個專門的 QA 團隊,他們將為我們的開發人員編寫 E2E/自動化測試。所以測試甚至沒有出現在工作描述中。此外,小型新創公司的不幸事實是交付始終高於一切,因此由於測試會阻礙生產力,因此我們開發人員沒有進行測試。我們甚至沒有在儲存庫中安裝任何測試庫(Jasmine/Mocha/PhantomJS...)。

我在一家更大的公司找到了第二份工作(消費者平台團隊有大約 150 名開發人員?)。然而,從本質上講,並沒有進行任何測試。每個團隊(按結帳、忠誠度、註冊等功能劃分的團隊)再次有專門的 QA 成員來編寫這些 E2E 測試。一旦這種文化形成並且品質保證從預算中削減,就沒有人接受它們,因為沒有人可以向他們學習。我試圖為我們的團隊進行一些 E2E 測試,但留下的程式碼甚至無法正常工作,而且充滿了明顯的錯誤(很多 WTF)。再加上時間緊迫,測試又落後了。人們談論測試的唯一一次是實用函數和自訂反應掛鉤。

---討論開始---

受到無測試文化的困擾,我至少必須想出一些我可以在面試中抽像地談論測試的東西。我將跳過不測試樣式或實現之類的常見廢話。

請隨意加入討論。這影響了我至少 300 位過去的同事!

1.) 測試全域狀態:
根據我的經驗,最粗糙的功能之一是「如果發生這種情況,我們會自動為您執行此操作」類型的行為。例如,我擁有的一個應用程式是一個可高度配置的圖形視覺化儀表板。一項配置更改可能會導致其他配置也發生更改,具體取決於返回的資料以及未返回的資料。有些配置副作用並不直接。因此,您需要測試自動配置變更以及狀態是否全面持久/未變更/一致。因此,如果您圍繞此類行為進行測試,與 PM、經理、設計和 QA 團隊保持一致是非常有價值的。

2.)不要花太多時間測試 UI 輸入的完整性:
我看到很多教程都在談論測試輸入,例如當我在搜尋欄中輸入“泰勒·斯威夫特”並按 Enter 鍵時,我們的搜尋功能將獲得泰勒·斯威夫特作為輸入。

這毫無幫助。如果您的資料綁定被破壞,那麼很明顯您應該在開發時自己捕獲它,或者它不能自動測試,因為某些東西阻礙了功能,例如搜尋欄上方的不可見 div,因此用戶無法輸入搜尋。

如果你是透過程式碼行付費的,那就繼續吧:)

3.)測試輸入作為輸入的副作用是可取的:
與第二點相反,您需要測試對使用者互動完全產生副作用的功能呼叫。例如,當使用者點擊按鈕時,應該呼叫一個請求來註冊該使用者操作以進行資料分析。這種與核心功能完全分離的副作用應該自動測試,這樣我們就不會因為一些無意的更改而措手不及。非核心副作用對其他團隊來說可能至關重要,我曾在其他團隊之一中工作:D

那麼如何建構這些測驗需求呢?
讓我們分解一下前端架構:MVC(你可以說你是 MVVM 或什麼不是,這並不重要)。

V - 視圖 (html/jsx): 這非常適合 E2E/無頭瀏覽器測試,並且是業界標準。

C - 控制器(業務邏輯):花一些時間確保功能正確。例如,如果您具有/抽象化為純函數,那麼預期的輸入輸出過程是否仍然完好無損?有點行業標準,但人們通常不會費心將有狀態函數變成純函數並進行測試。

M - 模型(api 呼叫/狀態): 這是我最想關注的。您的(非渲染)狀態應該是全域的並且每個概念都是單例的。這不是什麼新想法,因為 Redux 基本上就是這樣。然而,出於我們的測試目的,它不一定是 Flux。您可以擁有 jotai 原子,但您可以編寫一個包裝器,以便可以公開集中的 setter 函數進行測試。

應該在您的 api 呼叫/第三方程式庫上執行類似的操作。它應該是全局的和單例的,以便您可以自信地測試“當我這樣做時,是應用程式中進行的核心/非核心 api 調用”。以我有限的經驗,這是在後端應用程式中例行完成的。它也應該在前端應用程式中完成。

這聽起來怎麼樣?我確信已經有人這麼做了,你的經驗是什麼?有什麼可以改進的?我很想聽聽人們的意見,他們認為前端測試不僅僅是 E2E/無頭瀏覽器和簡單的單元測試。

以上是有效的前端測試的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在JavaScript中替換字符串字符在JavaScript中替換字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

自定義Google搜索API設置教程自定義Google搜索API設置教程Mar 04, 2025 am 01:06 AM

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

構建您自己的Ajax Web應用程序構建您自己的Ajax Web應用程序Mar 09, 2025 am 12:11 AM

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

示例顏色json文件示例顏色json文件Mar 03, 2025 am 12:35 AM

本文系列在2017年中期進行了最新信息和新示例。 在此JSON示例中,我們將研究如何使用JSON格式將簡單值存儲在文件中。 使用鍵值對符號,我們可以存儲任何類型的

8令人驚嘆的jQuery頁面佈局插件8令人驚嘆的jQuery頁面佈局插件Mar 06, 2025 am 12:48 AM

利用輕鬆的網頁佈局:8 ESTISSEL插件jQuery大大簡化了網頁佈局。 本文重點介紹了簡化該過程的八個功能強大的JQuery插件,對於手動網站創建特別有用

什麼是這個'在JavaScript?什麼是這個'在JavaScript?Mar 04, 2025 am 01:15 AM

核心要點 JavaScript 中的 this 通常指代“擁有”該方法的對象,但具體取決於函數的調用方式。 沒有當前對象時,this 指代全局對象。在 Web 瀏覽器中,它由 window 表示。 調用函數時,this 保持全局對象;但調用對象構造函數或其任何方法時,this 指代對象的實例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。這些方法使用給定的 this 值和參數調用函數。 JavaScript 是一門優秀的編程語言。幾年前,這句話可

通過來源查看器提高您的jQuery知識通過來源查看器提高您的jQuery知識Mar 05, 2025 am 12:54 AM

jQuery是一個很棒的JavaScript框架。但是,與任何圖書館一樣,有時有必要在引擎蓋下發現發生了什麼。也許是因為您正在追踪一個錯誤,或者只是對jQuery如何實現特定UI感到好奇

10張移動秘籍用於移動開發10張移動秘籍用於移動開發Mar 05, 2025 am 12:43 AM

該帖子編寫了有用的作弊表,參考指南,快速食譜以及用於Android,BlackBerry和iPhone應用程序開發的代碼片段。 沒有開發人員應該沒有他們! 觸摸手勢參考指南(PDF)是Desig的寶貴資源

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器