測試二三事|還記得你說,要和我寫測試

更新於 2024/12/15閱讀時間約 6 分鐘

A. 前言

過去在程式導師實驗課程中,整理過這兩篇筆記探討「測試」是怎麼回事:
在轉職後的第一家公司,組內曾嘗試在既有專案中撰寫測試,卻因時程緊湊而不了了之。但或許是一聽到測試就浮現「好麻煩⋯⋯」的想法吧?與其花這個時間去寫程式來進行測試,還不如多修幾個 BUG 來得有效益,打從心底想逃避這件事情,只覺得測試是理想,讓這項 TODO 一直被延宕。
而在求職過程中,時常被問是否有過測試經驗;到了現在第二間公司,寫測試這議題又再次浮現。回想起過去在專案中,時不時發生「改 A 壞 B」 的情況,如果透過測試來事先預期結果,或許就能減少這類錯誤的發生。
於是乎,這篇文章就誕生了ಠ_ಠ
在實作過程中,試著統整過去所學並且記錄下來,文章大致會分成四個段落,在正式介紹 Cypress 這套測試框架之前,會先在上篇補充測試相關的知識:
  • Why we need test?
  • What is Testing?
  • Why Cypress?
  • How to start?
那麼就開始吧!

B. Why we need test?

所以說,為何我們需要測試?
誠如前言提到,透過測試我們能夠先預期結果,找出非預期的錯誤情境。在轉體開發過程中,隨著需求日漸複雜化,多人協作開發不易維護,再加上時程壓力,若沒有制定流程規範,實在很難透過手動測試一次到位。
讓自動化測試取代人工測試,除了能降低成本,也有助於快速驗證程式是否能正常運作,並透過測試報告找出問題所在,不至於在茫茫程式海中迷失方向。
總歸而言,測試能夠確保程式碼的可靠性,避免人為錯誤,提升程式碼的質量、重用性與可維護性。

C. What is Testing?

說了這麼多,到底怎樣才是測試呢?
從我們最熟悉的人工測試,到寫程式來測試程式,其實都是基於同樣的道理:「測試是藉由程式來模擬現實,比較『預期結果』和『實際結果』是否相同的過程」。
C-1. 自動化測試金字塔 Test Automation Pyramid
簡單來說,測試依規模大致可分成三個層次,構成自動化測試金字塔,如下圖所示:
在測試金字塔中,越靠上方所耗費成本越高、執行時間越長;反之,越靠底下所耗費成本低,執行時間越短。
而依照測試方法不同,又可分為黑箱測試與白箱測試:
# 黑箱測試(Black-box Testing)/ 功能測試
  • 以使用者的角度,針對程式的功能面進行測試
  • 應用於整合測試和系統測試
  • 舉例:在表格欄位輸入錯誤的資料格式,檢測系統是否存在漏洞
# 白箱測試(White-box Testing)/ 結構測試
  • 以程式語言的角度,測試內部結構或流程
  • 應用於單元測試
  • 舉例:使用訂單系統,依使用者的情境模擬操作
C-2. 單元測試 Unit Testing
  • 以程式碼的最小單位(function、method 等)進行測試,也是自動測試化的基礎
  • 驗證單一行為、執行快速、具獨立性
  • 常用套件:Jestmochajs & chai
  • 常見開發模式:TDD & BDD
這裡介紹兩種與單元測試(Unit Test)相關的開發流程:
# TDD(Test-Deriven Development)測試驅動開發
  • 先寫測試,後實作功能
  • 專注功能的實現
  • 開發流程會在「單元測試 ⇒ 撰寫能通過測試的程式碼 ⇒ 重構」三者之間循環
# BDD (Behavior-Deriven Development)行為驅動開發
  • 為 TDD 的進化版,但會先寫測試規格書,再寫測試,後實作功能
  • 專注系統的行為,較貼近使用者的角度進行測試
  • 使用 `describe()` 和 `it()` 需求為導向的設計語意化
C-3. 整合測試 Integration Testing
  • 整合兩個以上的元件(Component)或模組(Module)之間的互動測
  • 使用 Mock Data 模擬 Mock API 回傳內容,檢測 render DOM 是否呈現預期結果
  • 常用套件:TestBedTesting LibraryEnzyme
為什麼需要整合測試?單元測試都通過不就代表都 OK 了?下圖提供非常好的例子:
根據不同情境所需,有時即使單元測試沒測出問題,一旦跨模組整合就出事了,因此這個階段更重視不同元件或環境之間的整合互動,也更貼近使用者實際行為。
C-4. 端對端測試 End-to-end Testing / E2E Testing
如下所示,為 Cypress 使用範例,能夠看到使用者實際操作頁面的過程:

D. Consolusion

雖說寫測試很重要,但並非寫好寫滿就是最好作法,畢竟需求情境百百種,仍需考慮使用時機與情境,才不會本末導致,花費更多時間維護測試腳本。
透過撰寫測試,(強迫)讓開發者寫出容易被測試的程式碼,並在有限的資源中,以有效的測試來確保程式的品質。
然而,這些測試的道理我都懂,但到底該如何開始呢?下篇會繼續探討,如何透過 Cypress 這套工具進行 E2E Testing,並且實際應用到專案中!

E. Reference

avatar-img
0會員
7內容數
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
Heidi Liu的沙龍 的其他內容
「平凡的我啊,哪有時間低頭回望?」 — — 《排球少年 264 話》 各位安安,我是 Heidi,從年前就一直思考,應該如何總結這一年來的學習心得,結果又拖到現在,不知不覺都已經入職快兩個月了XD 這篇是記錄我在 Lidemy 學習半年的結業心得,也會稍微帶到多人協作和求職總結。
“Do not, for one repulse, give up the purpose that you resolved to effect.” — William Shakespeare. 幾天前分享的上篇心得有稍微提到,前半段會偏向描寫過去的個人經驗,是有關於在開始學習程式之前的自己
“Never regret. If it’s good, it’s wonderful. If it’s bad, it’s experience. “ — Victoria Holt. 前言 從六月初開始,參加第四期程式導師計畫以來,這段日子過得飛快,轉眼間一個禮拜又過去,自己也迎來了課程中場。
“If you wish to reach the highest, begin at the lowest.” — Publilius Syrus.
「平凡的我啊,哪有時間低頭回望?」 — — 《排球少年 264 話》 各位安安,我是 Heidi,從年前就一直思考,應該如何總結這一年來的學習心得,結果又拖到現在,不知不覺都已經入職快兩個月了XD 這篇是記錄我在 Lidemy 學習半年的結業心得,也會稍微帶到多人協作和求職總結。
“Do not, for one repulse, give up the purpose that you resolved to effect.” — William Shakespeare. 幾天前分享的上篇心得有稍微提到,前半段會偏向描寫過去的個人經驗,是有關於在開始學習程式之前的自己
“Never regret. If it’s good, it’s wonderful. If it’s bad, it’s experience. “ — Victoria Holt. 前言 從六月初開始,參加第四期程式導師計畫以來,這段日子過得飛快,轉眼間一個禮拜又過去,自己也迎來了課程中場。
“If you wish to reach the highest, begin at the lowest.” — Publilius Syrus.
你可能也想看
Google News 追蹤
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
本文介紹了TCO(Testing Coverage Outline)測試覆蓋大綱的概念及其在測試過程中的重要性。TCO有助於分析被測系統的需求,梳理和結構化資訊,使測試人員能夠清晰瞭解測試範圍。此外,還探討了繪製TCO的方法。通過進行資訊的提煉與重組,TCO能有效促進測試的準備和執行。
Thumbnail
測試你的金錢恐懼指數有多高? ┈┈┈┈┈◦•✩•◦┈┈┈┈┈ 花1分鐘測一下你的金錢恐懼指數有多高? 對照一下你的收入?
Thumbnail
本文探討了臺灣側室制度的歷史背景,並分析一起近期的法律爭議案件,涉及一名男子因母親身份問題而導致的無名屍處置情況。側室在歷史上雖未被合法入籍,但這是否意味著他們的基本人權便不受保障呢?
Thumbnail
因為盛飯升國三,只好把『老婆們』交給母親代管。 『關於我與那些動漫媳婦同居』這件事。 媳婦們,讓我們好好培養感情呀~ 話說大老婆進門這麼久,盛飯怎麼連一句俄語都還不會?🤔 明天開學第一天,就要『模模考』-模擬『模擬考』的考試💔 懷挺!苦逼國三生💪
Thumbnail
大家來玩吧!🐰 不知有誰跟我一樣是小八呢? https://quiz.kuioo.tw/which-chiikawa-character-are-you/
Thumbnail
11122233543654765e 5 54yopjrsodihjer089yhzp
測試網站和應用程式時需要注意以下事項和執行以下工作: 注意事項: 跨平台相容性: 確保網站或應用程式在各種瀏覽器和設備上的相容性,包括桌面、平板和手機等。 響應式設計測試: 測試網站或應用程式在不同螢幕尺寸和解析度下的表現,確保響應式設計正常運作。 安全性測試: 確保網站或應用程式的安全性,
中文網站介面 測試:安著手機、蘋果電腦。 瀏覽器:皆是Google瀏覽器。 結果:過多人使用時即使登入系統也無法查看訂單和購物車,但過一陣子會自動更新變回正常。
Thumbnail
11111111111 111111111 1111111111111111111 1111111111111111 1111111111111 1111111111111111 111111111111111111 11111111111 111111111111111 1111
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
本文介紹了TCO(Testing Coverage Outline)測試覆蓋大綱的概念及其在測試過程中的重要性。TCO有助於分析被測系統的需求,梳理和結構化資訊,使測試人員能夠清晰瞭解測試範圍。此外,還探討了繪製TCO的方法。通過進行資訊的提煉與重組,TCO能有效促進測試的準備和執行。
Thumbnail
測試你的金錢恐懼指數有多高? ┈┈┈┈┈◦•✩•◦┈┈┈┈┈ 花1分鐘測一下你的金錢恐懼指數有多高? 對照一下你的收入?
Thumbnail
本文探討了臺灣側室制度的歷史背景,並分析一起近期的法律爭議案件,涉及一名男子因母親身份問題而導致的無名屍處置情況。側室在歷史上雖未被合法入籍,但這是否意味著他們的基本人權便不受保障呢?
Thumbnail
因為盛飯升國三,只好把『老婆們』交給母親代管。 『關於我與那些動漫媳婦同居』這件事。 媳婦們,讓我們好好培養感情呀~ 話說大老婆進門這麼久,盛飯怎麼連一句俄語都還不會?🤔 明天開學第一天,就要『模模考』-模擬『模擬考』的考試💔 懷挺!苦逼國三生💪
Thumbnail
大家來玩吧!🐰 不知有誰跟我一樣是小八呢? https://quiz.kuioo.tw/which-chiikawa-character-are-you/
Thumbnail
11122233543654765e 5 54yopjrsodihjer089yhzp
測試網站和應用程式時需要注意以下事項和執行以下工作: 注意事項: 跨平台相容性: 確保網站或應用程式在各種瀏覽器和設備上的相容性,包括桌面、平板和手機等。 響應式設計測試: 測試網站或應用程式在不同螢幕尺寸和解析度下的表現,確保響應式設計正常運作。 安全性測試: 確保網站或應用程式的安全性,
中文網站介面 測試:安著手機、蘋果電腦。 瀏覽器:皆是Google瀏覽器。 結果:過多人使用時即使登入系統也無法查看訂單和購物車,但過一陣子會自動更新變回正常。
Thumbnail
11111111111 111111111 1111111111111111111 1111111111111111 1111111111111 1111111111111111 111111111111111111 11111111111 111111111111111 1111