今日分享:程式碼整潔之道- 單元測試
從開發的角度來講,先把變數、函數依照一定的命名、格式組織好,接下來,開始寫程式碼,在業界,很多提倡測試驅動開發,接著跟大家聊一下單元測試。
TDD是測試驅動開發(Test-Driven Development)的英文簡稱,是敏捷開發中的一項核心實踐和技術,也是一種設計方法論。 TDD的原理是在開發功能程式碼之前,先編寫單元測試案例程式碼。
1、TDD三定律
定律一 在寫不能通過的單元測試前,不可寫生產程式碼。
定律二 只可寫剛好無法通過的單元測試,不能編譯也不算不通過。
定律三 只可寫剛好足以通過目前失敗測試的生產程式碼。
測試與生產程式碼一起編寫,測試只是比生產程式碼早寫幾秒鐘。
2、保持測試整齊
測試程式碼和生產程式碼一樣重要,一樣需要保持足夠的整潔。
測試帶來一切好處。
整齊的單元測試程式碼會為你的程式碼帶來很多好處。測試越髒,程式碼最終會變得越髒。如果遺失了測試,程式碼開始腐爛。
3、整齊的測試
整齊的測試有一個十分重要的要素:可讀性。
測試程式碼要保持明確、整潔,還要有足夠的表達力。在測試中,要以盡可能少的文字表達大量內容。
測試模式:建構-操作-檢驗,
第一環節 建構測試資料
第二環節 操作測試資料
第三環節 驗證操作是否得到期望的結果。
3.1 特定領域的測試語言
使用測試的語言測試,更具可讀性。
3.2 雙重標準
測試API中的程式碼有著與生產程式碼不同的工程標準,要求應當簡單、精悍、足具表達力,但又要和生產程式碼一般有效。
4、每個測試一個斷言
有人認為每個測試函數都應該有且只有一個斷言語句。
每個測試一個概念。
更好的規則或許是每個測試函數中只測試一個概念,只做一件事情。
5、F.I.R.S.T 原則
整齊程式碼應遵循以下規則:
快速(Fast)測試應該夠快。測試應該能快速運作。
獨立(Independent)測試應相互獨立。某個測驗不應為下一個測驗設定條件。
可重複(Repeatable)測試應在任何環境下重複通過。
自足驗證(Self-Validating)測試應該有布林值輸出。無論是失敗還是通過,應直接了當得出結論,而不應該通過查看日誌來確認測試是否通過。
及時(Timely)測試應及時編寫。單元測試應該恰好在使其通過的生產程式碼之前編寫。
6、小結
測試與程式碼同等重要,它保證和增強了生產程式碼的可擴展性、可維護性和可重複使用性。保持測試的整潔,讓測試具有表達力並短小精悍。發明作為特定領域語言的測試API,幫助自己編寫測試。
在實際的開發中,很多團隊,由於各種外部、內部的因素,工期緊、時間少、任務重等諸多因素,很多事沒有TDD、沒有單元測試,即使如此,我們還是要堅持這個原則,慢慢往單元測試這個目標靠近...
你可能喜歡:

熱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)

針對Java中介面和抽象類別進行單元測試的步驟:介面建立一個測試類別。建立一個模擬類別來實作介面方法。使用Mockito庫模擬介面方法並編寫測試方法。抽象類別建立一個測試類別。建立抽象類別的子類別。編寫測試方法來測試抽象類別的正確性。

PHP單元測試工具分析:PHPUnit:適用於大型項目,提供全面功能,易於安裝,但可能冗長且速度較慢。 PHPUnitWrapper:適合小型項目,易於使用,針對Lumen/Laravel優化,但功能受限,不提供程式碼覆蓋率分析,社群支援有限。

效能測試評估應用程式在不同負載下的效能,而單元測試驗證單一程式碼單元的正確性。效能測試著重於測量反應時間和吞吐量,而單元測試則關注函數輸出和程式碼覆蓋率。性能測試透過高負載和並發模擬實際環境,而單元測試在低負載和串行條件下運行。效能測試的目標是識別效能瓶頸和最佳化應用程序,而單元測試的目標是確保程式碼正確性和健全性。

表驅動的測試在Go單元測試中透過表定義輸入和預期輸出簡化了測試案例編寫。語法包括:1.定義一個包含測試案例結構的切片;2.循環遍歷切片並比較結果與預期輸出。在實戰案例中,對字串轉換大寫的函數進行了表格驅動的測試,並使用gotest運行測試,列印通過結果。

單元測試和整合測試是兩種不同的Go函數測試類型,分別用於驗證單一函數或多個函數的交互和整合。單元測試只測試特定函數的基本功能,整合測試測試多個函數之間的互動和與應用程式其他部分的整合。

設計有效的單元測試案例至關重要,遵循以下原則:原子性、簡潔、可重複和明確。步驟包括:確定要測試的程式碼、識別測試場景、建立斷言、編寫測試方法。實戰案例示範了為max()函數建立測試案例,強調了特定測試場景和斷言的重要性。透過遵循這些原則和步驟,可以提高程式碼品質和穩定性。

PHP單元測試中提高程式碼覆蓋率的方法:使用PHPUnit的--coverage-html選項產生覆蓋率報告。使用setAccessible方法覆寫私有方法和屬性。使用斷言覆蓋布林條件。利用程式碼審查工具獲得額外的程式碼覆蓋率洞察。

摘要:透過整合PHPUnit單元測試框架和CI/CD管道,可以提高PHP程式碼品質並加速軟體交付。 PHPUnit允許建立測試案例來驗證元件功能,而GitLabCI和GitHubActions等CI/CD工具可自動執行這些測試。範例:透過測試案例驗證身份驗證控制器,以確保登入功能能如預期運作。