搜尋
首頁web前端js教程關於 ThoughtWorks Radar 4 的思考

Thoughts on ThoughtWorks Radar 4

ThoughtWorks 2024 Radar 已發布(您可以一鍵下載 PDF,無需煩人的註冊)。以下是兩件事:

  1. 我講述了我在組件測試中感到困惑的事情
  2. 很酷的新工具,用於調查或找出他們從「評估」到「採用」的原因

如果您只是想了解一些很酷的新東西,請跳過我的組件測試咆哮。

組件測試:採用

我對這個「採用」有很多疑問。我現在的雇主投入了大量的培訓和工具來幫助團隊進行組件測試,這是我喜歡的。我不喜歡的是另一種測試技術,它的定義因談論它的人而異。

讓我按照我了解它們的時間順序概述我在野外看到的幾個定義,我認為_ThoughtWorks 的定義是最後一個:

  • Storybook 幫助單獨測試 React 元件,被元件框架作者大量使用
  • 使用 Cypress 的元件測試在隔離的瀏覽器環境中測試元件
  • 我對賽普拉斯白盒測試的最新定義,意味著所有外部 I/O 呼叫(fetch/xhr、加載 JSON、讀取本地存儲等)都是 cy.intercepted 或存根/模擬

這些都不一樣。上述上下文中的元件是指 UI 元件,類似於 a 或 a,它由許多其他元件、程式碼和 CSS 組成。我說“有點”,因為在 Storybook 和 Cypress 中,你使用的是真正的瀏覽器,而不是像 JSDom 這樣的假​​瀏覽器。在這種情況下,我相信使用真正的瀏覽器可以解決很多問題,特別是圍繞驗收測試,而不是單元測試。我的經歷與他們所引用的相反:你可以讓Cypress/Playwright 變得非常快(使用像it.only 之類的東西,大量存根,設計你的UI 以更加解耦來測試特定的用戶流),以及數量對於用戶來說,我對應用程式的運作充滿信心。考慮到 Elm 的類型系統,這是您驗證 Elm 程式碼中是否存在競爭條件的主要方法,而且這很好,因為您可以花更多時間使用該技術編寫驗收測試。 Cypress 白盒測試並不脆弱;它們具有確定性,這就是我們都喜歡它們的原因。

但是,我確實承認除錯可能具有挑戰性。僅僅因為你「在瀏覽器中」並不總是能讓你廣泛地了解為什麼某些東西會崩潰,儘管有斷點、調試器關鍵字、編譯的源代碼、對網絡調用的洞察以及各種日誌都可供你使用(不是開玩笑) ,即使如此,你仍然可以說“夥計,為什麼這不起作用……”)

接下來,ThoughtWorks 和 Cypress 都引用了「端到端」測試。這裡的定義也很模糊。以下是我看過的一些定義:

  • Dave Farley 的 e2e 方案,基本上是驗證「所有事物」協同工作(不要與早期 All Up 測試的推動相混淆)
  • 賽普拉斯的黑盒測試,您不會存根/模擬 ajax 呼叫和其他 I/O,這只是測試「您的網站及其整合」
  • ThoughtWorks 似乎在說 Playwright/Cypress/Selenium 主要是 e2e 工具,我將它們視為驗收測試工具,不包括 Cypress 組件測試功能,這與 Storybook 有點相似
  • 希勒爾‧韋恩也這麼稱呼他們

最後,我從來不喜歡 React 的元件測試擴充。它們充斥著大量的模擬/副作用,並強烈鼓勵您使用JQuery 技能來驗證“我的組件正確渲染”,這並不總是等同於“正確工作”,感覺就像打破抽象,並測試React 是否正確正在工作。相反,無論是React、Angular 還是Elm,我一直覺得測試你的程式碼是有效的,主要創建純元件,並測試你在驗收測試(Cypress 或Playwright)中驗證的「智慧元件」(例如具有副作用的元件) .

JavaScript Web 開發人員有不同的觀點和不同的單字定義。這通常很好,但作為一個將ThoughtWorks 作為年輕成年英雄的人,不斷推薦Martin Fowler 和其他ThoughtWorks 撰寫的作品作為學習的精彩建議,並且活動希望有一天與他們合作......你可以明白為什麼這種完全相反的觀點是給我帶來了信仰危機。

所以:

  1. 同意以各種形式進行組件測試
  2. 不同意 JSDom 並在您選擇的單元測試語言中「斷言我的組件的列表項目 2 有一個粗體標記,內部文本為‘cow’」。

無論如何,以上內容在各種語言中都有細微差別。例如,Angular 和 Lit/WebComponents,如果您避免模板具有超出 if 的任何邏輯,並將綁定切換到公共組件變量,那麼與 React 和其他公開的當前框架相比,單元測試和斷言副作用會更容易。然而,Angular 和一些 WebComponent 框架需要冗長的設定程式碼,這些程式碼本身極難調試,而 React/Elm 則相反。

此外,我知道創建這些 PDF 是一項艱鉅的工作,嘗試總結技術方面的任何內容也是如此,所以我確信我只是缺少大量的上下文。

持續部署:採用

看到我的執行長在年度演講中談論這一點,真是太棒了。我知道嘗試最小 CD 的活動對人們來說可能是一個巨大的改變,但這是我在工作中見過的最好的方式,很高興看到它在採用中被明確地調用。

傀儡:評估

當 Zio 創作者參與創建這個名為 Golem 的不會崩潰的狀態機即服務時,我感到非常興奮。我更加興奮,因為他們支持 Grain,一種 OCAML 風格的 FP 健全類型語言。我永遠找不到時間/靈感去玩,因為我仍然感覺自己陷入了「一切都是 AWS」的漩渦中。是的,我在生產中使用過 CloudFlare,但…作為 AWS Step Functions 的粉絲,這似乎是一個很酷的主意。其中一個週末我會再嘗試使用 TypeScript,因為 Grain 似乎不再是選項。

布魯諾:採用

許多 REST 用戶端(其中一些內建於 VSCode 中)正被各種公司阻止,因為它們在其伺服器上託管您的內部 API 詳細資訊或將詳細資訊發佈到其他地方。像 Postman 和 Insomnia 這樣的東西已經開始要求訂閱,儘管他們聲稱不需要,但這只會讓事情變得更糟。因此,人們迫切需要尋找不共享資料的類似工具。 Bruno 是我需要檢查的一個,因為我不再被允許使用 ThunderClient。

視覺迴歸測試工具:採用

CSS 可以透過多種方式破壞整個應用程序,並且無法輕鬆地進行單元測試或驗收測試來防止這種情況發生。我真的很難使用早期的 React 快照工具,並且考慮到大量的誤報,我覺得較小的網站沒有投資回報率。 Applit 和 BackstopJS 等工具是眾多工具中的一部分,包括服務,用於驗證您的網站外觀和工作是否正常。它們通常在管道中的驗收測試之後或同時運行。我大約有 5 分鐘使用 Applit 工具的經驗,但絕對想看看 Backstop。

GitButler:評估

我最興奮的是 GitButler。作為一個在經歷了基於主幹的開發後討厭Pull Requests 的人,並對圍繞「抽象而不是PR」的各種工具的狀態和放棄感到失望,GitButler 看起來可以在切換到製作PR 的PR 的上下文中恢復我的理智。

米斯:評估

Mise 有點奇怪,因為我從來沒有遇到過使用 nvm 管理 Node.js 版本和使用 pipelinev 管理/運行 Python 專案的問題,所以很好奇,可以嘗試一下,看看有什麼大驚小怪的。

模擬:評估

我討厭嘲笑。我傾向於使用允許副作用的語言,並且與不遵循 Pure Core、Imperative Shell 的開發人員一起工作。因此,我能做的任何事情來更多地了解我的敵人以及如何管理它,都是對時間的一種很好的利用,Mockoon 是另一位模擬創建者。

Rspack:評估

值得慶幸的是,我從來不需要與 Webpack 整合。不幸的是,我多次受到_其他人_與 Webpack 整合的影響。 Vite 是呼吸新鮮空氣的地方;超級快,而且成功了。因此,聽到另一個速度競爭者是很有趣的。 Vite 獲勝不僅是因為其驚人的速度,還因為出色的開發者體驗,太酷了,看看 Rspack 會發生什麼。

澤德:評估

儘管 VSCode 對我來說很重要,但我很高興嘗試 Zed IDE,因為內建結對程式設計、超快的速度,而且因為 Roc lang 創作者加入了他們的團隊。

PKL:試用

我第一次轉向 Pkl 是在我的 Dhall 幻滅低谷階段(Dhall 很酷,但男人太難了),是 James Ward 帶來的。它看起來是一種具有足夠類型的語言,可以更安全地編譯 YAML/JSON 設定檔。我已經有足夠多的YAML/JSON 錯誤配置破壞了生產,所以我開始尋找編譯這些問題的方法,Dhall 提供了很多幫助,但是學習曲線和編譯器錯誤很難解決,而且我從未在同行中感到興奮。希望 Pkl 能夠在這裡取得進展。

結論

請務必自己下載 PDF,因為我忽略了其中的大量新技術和現有技術(法學碩士、基礎設施、數據科學),我覺得這些技術很無聊,但其他人可能會覺得引人注目。

以上是關於 ThoughtWorks Radar 4 的思考的詳細內容。更多資訊請關注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

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

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

如何創建和發布自己的JavaScript庫?如何創建和發布自己的JavaScript庫?Mar 18, 2025 pm 03:12 PM

文章討論了創建,發布和維護JavaScript庫,專注於計劃,開發,測試,文檔和促銷策略。

如何在瀏覽器中優化JavaScript代碼以進行性能?如何在瀏覽器中優化JavaScript代碼以進行性能?Mar 18, 2025 pm 03:14 PM

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

如何使用瀏覽器開發人員工具有效調試JavaScript代碼?如何使用瀏覽器開發人員工具有效調試JavaScript代碼?Mar 18, 2025 pm 03:16 PM

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

jQuery矩陣效果jQuery矩陣效果Mar 10, 2025 am 12:52 AM

將矩陣電影特效帶入你的網頁!這是一個基於著名電影《黑客帝國》的酷炫jQuery插件。該插件模擬了電影中經典的綠色字符特效,只需選擇一張圖片,插件就會將其轉換為充滿數字字符的矩陣風格畫面。快來試試吧,非常有趣! 工作原理 插件將圖片加載到畫布上,讀取像素和顏色值: data = ctx.getImageData(x, y, settings.grainSize, settings.grainSize).data 插件巧妙地讀取圖片的矩形區域,並利用jQuery計算每個區域的平均顏色。然後,使用

如何構建簡單的jQuery滑塊如何構建簡單的jQuery滑塊Mar 11, 2025 am 12:19 AM

本文將引導您使用jQuery庫創建一個簡單的圖片輪播。我們將使用bxSlider庫,它基於jQuery構建,並提供許多配置選項來設置輪播。 如今,圖片輪播已成為網站必備功能——一圖胜千言! 決定使用圖片輪播後,下一個問題是如何創建它。首先,您需要收集高質量、高分辨率的圖片。 接下來,您需要使用HTML和一些JavaScript代碼來創建圖片輪播。網絡上有很多庫可以幫助您以不同的方式創建輪播。我們將使用開源的bxSlider庫。 bxSlider庫支持響應式設計,因此使用此庫構建的輪播可以適應任何

如何使用Angular上傳和下載CSV文件如何使用Angular上傳和下載CSV文件Mar 10, 2025 am 01:01 AM

數據集對於構建API模型和各種業務流程至關重要。這就是為什麼導入和導出CSV是經常需要的功能。在本教程中,您將學習如何在Angular中下載和導入CSV文件

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.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 英文版

SublimeText3 英文版

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境