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
SJ Chou
April 28, 2015
Technology
1
90
軟體品質與持續整合
軟體品質與持續整合
SJ Chou
April 28, 2015
Tweet
Share
More Decks by SJ Chou
See All by SJ Chou
NVIDIA Omniverse Kit Introduction
samejack
0
5
用 Keras 玩 Machine Learning
samejack
0
130
2020 MLaaS 產業介紹
samejack
0
38
Linux Container Introduction
samejack
0
32
Cloud Foundry Introduction
samejack
0
45
WordPress Blog SEO 兩三事
samejack
0
67
小猴子也會的 Ubuntu Desktop 14.04 安裝教學
samejack
0
110
Android_Day_2013_-_Mobile_Web_App_Design.pdf
samejack
0
89
REST to RESTful Web Service
samejack
2
210
Other Decks in Technology
See All in Technology
リスクから学ぶKubernetesコンテナセキュリティ/k8s-risk-and-security
mochizuki875
1
310
LINEヤフー新卒採用 コーディングテスト解説 実装問題編
lycorp_recruit_jp
1
12k
15 JSON serializers for Ruby
okuramasafumi
2
100
山手線一周のパフォーマンス改善
suzukahr
0
150
【shownet.conf_】AI技術とUX監視の応用でShowNetの基盤を支えるモニタリングシステム
shownet
PRO
0
350
ITエンジニアとして知っておいてほしい、電子メールという大きな穴
logica0419
6
1.1k
【shownet.conf_】クロージングセッション
shownet
PRO
0
290
成果のためのコミュニケーション - 語彙を育てよう -/communication-for-good-outcome-developing-vocabulary
hassaku63
4
160
【shownet.conf_】トポロジ図の歩き方
shownet
PRO
0
480
エムスリーマネジメントチーム紹介資料 / Introduction of M3 Management Team
m3_engineering
0
270
スタサプ ForSCHOOLアプリのシンプルな設計
recruitengineers
PRO
2
420
これはPerl? それともRuby? クイズ〜〜〜〜〜!!!- Perl or Ruby Quiz
moznion
2
1.6k
Featured
See All Featured
Documentation Writing (for coders)
carmenintech
65
4.3k
Done Done
chrislema
181
16k
Clear Off the Table
cherdarchuk
91
320k
Agile that works and the tools we love
rasmusluckow
327
21k
A better future with KSS
kneath
236
17k
Happy Clients
brianwarren
97
6.7k
The Pragmatic Product Professional
lauravandoore
31
6.2k
Teambox: Starting and Learning
jrom
131
8.7k
Practical Orchestrator
shlominoach
186
10k
Building an army of robots
kneath
302
42k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
26
1.3k
Building a Modern Day E-commerce SEO Strategy
aleyda
38
6.8k
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