Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
軟體品質與持續整合
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
SJ Chou
April 28, 2015
Technology
110
1
Share
軟體品質與持續整合
軟體品質與持續整合
SJ Chou
April 28, 2015
More Decks by SJ Chou
See All by SJ Chou
LangChain Framework 與 RAG 實做教學
samejack
1
13
LLM RAG 擷取增強生成介紹 - 3 種 RAG/Self-RAG/CRAG 全解析
samejack
1
110
NVIDIA Omniverse Kit Introduction
samejack
1
71
用 Keras 玩 Machine Learning
samejack
1
160
2020 MLaaS 產業介紹
samejack
1
84
Linux Container Introduction
samejack
1
45
Cloud Foundry Introduction
samejack
1
74
WordPress Blog SEO 兩三事
samejack
1
84
小猴子也會的 Ubuntu Desktop 14.04 安裝教學
samejack
1
120
Other Decks in Technology
See All in Technology
3つのボトルネックを解消し、リリースエンジニアリングを再定義した話
nealle
0
330
バックオフィスPJのPjMをコーポレートITが担うとうまくいく3つの理由
yueda256
1
290
BIツール「Omni」の紹介 @Snowflake中部UG
sagara
0
260
Bluesky Meetup in Tokyo vol.4 - 2023to2026
shinoharata
0
130
LLM とプロンプトエンジニアリング/チューターを定義する / LLMs and Prompt Engineering, and Defining Tutors
ks91
PRO
0
320
Hooks, Filters & Now Context: Why MCPs Are the “Hooks” of the AI Era
miriamschwab
0
130
Cortex Codeでデータの仕事を全部Agenticにやりきろう!
gappy50
0
330
【Findy FDE登壇_2026_04_14】— 現場課題を本気で解いてたら、FDEになってた話
miyatakoji
0
800
Kubernetes基盤における開発者体験 とセキュリティの両⽴ / Balancing developer experience and security in a Kubernetes-based environment
chmikata
0
220
制約を設計する - 非決定性との境界線 / Designing constraints
soudai
PRO
6
2.4k
Hello UUID
mimifuwacc
0
130
解剖"React Native"
hacusk
0
120
Featured
See All Featured
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8k
Exploring anti-patterns in Rails
aemeredith
3
310
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.4k
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
410
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.4k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
270
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
54k
Faster Mobile Websites
deanohume
310
31k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
11
880
Ethics towards AI in product and experience design
skipperchong
2
250
The Spectacular Lies of Maps
axbom
PRO
1
680
Transcript
軟體品質與持續整合 Software Quality & Continuous Integration
[email protected]
http://blog.toright.com 2014/12/25
持續整合 Continuous Integration 敏捷開發方法論 其中的武功招式之一
Why ? 想解決什問題...
希望能掌握軟體開發節奏 說好的 Feature 與 Deadline 呢?
開發節奏 Tempo of Development 程式設計師想踏實地寫程式 專案經理想確實地掌握時程 組織想降低成本與開發風險 客戶想拿到品質優良的產品 !?
回顧一下歷史的眼淚先... A Story of Integration Hell
悲劇的初章 PM:各位,明天新功能要上線囉! RD 甲:我負責的功能早完成了! RD 乙:我快完成了,剩下的 Bug 今晚可以搞定。 QA 甲:現在測試狀況還可以,剩下一些
Bug 等著修。 QA 乙:系統怪怪的,總覺的哪裡不對勁... PM:不要緊,大家晚上加個班,讓我們一起迎接明日黎 明的勝利!
黎明的前夕 RD • 處理惱人的程式碼衝突 • 忙著修正系統自動產生的 Bug !? • 執行環境差異太大
• 整合測試出現奇妙的錯誤 (我的電 腦明明正常啊) • 開始用一些所謂「快」的方法解決 問題 (你懂der) QA • 壞的功能貌似修好了 • 原本好的功能變得怪怪的 • 永遠沒有最終版 • 時間緊迫根本測不完 PM • 有時暴跳如雷 (Bug 如雪花般的飛來) • 有時安靜的像隻貓 (禱告中...) • 去全聯買「乖乖」
黎明到來 Bug 已經修正 (隱藏/規避),系統整合後 運作起來還算正常,終於可以上線了!
新功能啟用 大量使用者湧入使用 團隊忐忑不安的心情
PM 正準備吹起勝利的號角 ...
系統炸了,歷史悲劇再度上演!
這故事各位是否熟悉?
面對軟體開發的複雜性 漸漸由 病 轉變為 疾
回到「持續整合」 先從字面上解釋!
持續 整合 不間斷、不停地、一直、有事沒事就做一下
持續 整合 把大家寫的 Code 在一起跑看看有沒有錯!
持續 + 整合 就是 有事沒事就把大家寫的 Code 在一起跑看看有 沒有錯!
持續整合生命週期 Start … End 等同整個軟體生命週期!
結論 持續整合的目的在於掌握軟體開發節奏
How ? 該怎麼做...
有事沒事就把大家寫的 Code 在一起跑看看 有沒有錯! 就是「自動化」!
假自動化 vs 真自動化
假自動化 (半自動 / 手動)
人有失蹄、馬有失足 不管多細心,只要是人做的都會錯!
真自動化才是王道!
天下武功、無堅不摧,為快不破!
自動化的好處 快 執行成本低 錯誤機會低
實行自動化的痛 不知道怎自動化 不容易自動化 沒辦法自動化 自動化過程耗費高成本
如果沒辦法全面自動化呢? 那就盡可能自動化吧!
有事沒事就把大家寫的 Code 在一起跑看看 有沒有錯! 這不就是「版本控制」嗎!?
版本控制系統 Version Control System Git, SVN, CVS...
有事沒事就把大家寫的 Code 在一起跑看看 有沒有錯! 這不就是「系統測試」嗎!?
測試模式 Unit Test、Function Test、Monkey Test、UI Test… 不管黑箱還是白箱,可以自動測的都是好箱!
測試到底該測些什麼? • 對的要對 • 錯的要錯 • 錯的不能對 • 對的不能錯
撰寫自動化測試 最大的問題是? 既有的程式架構根本很難寫測試!
測試驅動開發 TDD, Test-driven development 不寫測試不寫程式 沒有通過測試的程式不是程式
不要迷戀哥(TDD),哥只是個傳說! 有時開發模式的核心不是在實踐,而是在目的!
透過認識方法論,找出適合手段! 透過測試先行幫助思考,進而改善軟體架構、實作與設計...
明明有了測試,怎麼還是錯了? 根本沒測到 (覆蓋率不足) 程式寫錯、測試也剛好寫錯
先別說這個了,你聽過「系統反饋」嗎? 什麼鬼?
系統反饋 System Feedback 如果你傷害它,它就會喊痛!
反饋的喜悅
每日建置 Nightly Build 每晚自動抓最新的程式碼,嘗試進行編譯、封裝、 佈署、測試、建立報告...最後獲得系統反饋
自動化 + 測試 + 系統反饋 持續整合的核心價值!
What ? 實踐...
持續整合系統 Continuous Integration System
今天不介紹 詳細安裝與設定請與我聯繫...
Pull Code Syntax & Coding Style Check JS / CSS
Compress Make Source Map Pack Depoly Generate Document Unit Test Function Test Release Tag Report (Notification)
每件事物都有適合自己的持續整合流程 請試著找出屬於自己的整合流程
請保持心中的信念 我們需要義無反顧的勇氣
對航海的人來說,擱淺的船舶就是燈塔。 [荷蘭諺語] 最後...
Thanks!!
[email protected]
http://blog.toright.com