關於 ThoughtWorks Radar 4 的思考
ThoughtWorks 2024 Radar 已發布(您可以一鍵下載 PDF,無需煩人的註冊)。以下是兩件事:
- 我講述了我在組件測試中感到困惑的事情
- 很酷的新工具,用於調查或找出他們從「評估」到「採用」的原因
如果您只是想了解一些很酷的新東西,請跳過我的組件測試咆哮。
組件測試:採用
我對這個「採用」有很多疑問。我現在的雇主投入了大量的培訓和工具來幫助團隊進行組件測試,這是我喜歡的。我不喜歡的是另一種測試技術,它的定義因談論它的人而異。
讓我按照我了解它們的時間順序概述我在野外看到的幾個定義,我認為_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 撰寫的作品作為學習的精彩建議,並且活動希望有一天與他們合作......你可以明白為什麼這種完全相反的觀點是給我帶來了信仰危機。
所以:
- 同意以各種形式進行組件測試
- 不同意 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中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。
