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
83
軟體品質與持續整合
軟體品質與持續整合
SJ Chou
April 28, 2015
Tweet
Share
More Decks by SJ Chou
See All by SJ Chou
用 Keras 玩 Machine Learning
samejack
0
120
2020 MLaaS 產業介紹
samejack
0
34
Linux Container Introduction
samejack
0
26
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
200
Caching in HTTP
samejack
0
83
Other Decks in Technology
See All in Technology
Classmethod Odyssey 登壇資料
yamahiro
0
390
OSSコミットしてZennの課題を解決した話
dyoshikawa1993
0
150
テスト・設計研修【MIXI 24新卒技術研修】
mixi_engineers
PRO
0
170
「我々はどこに向かっているのか」を問い続けるための仕組みづくり / Establishing a System for Continuous Inquiry about where we are
daitasu
0
170
Datadog Cloud SIEMを使ってAWS環境の脅威を可視化した話/lifeistech-datadog-cloud-siem
gidajun
0
480
年間一億円削減した時系列データベースのアーキテクチャ改善~不確実性の高いプロジェクトへの挑戦~
lycorptech_jp
PRO
3
2.9k
サービスの持続的な成長と技術負債について
siva_official
PRO
10
4.4k
MySQLのロックの種類とその競合
yoku0825
6
1.6k
クラウド利用者の「責任」をどう果たす?AWSセキュリティ対策のススメ #AWSSummit
hiashisan
0
280
ペパボのオブザーバビリティ研修2024 説明資料
kesompochy
0
1.1k
dxd2024-生成AIに振り回された3か月間の成功と失敗/dxd2024-link-and-motivation
lmi
2
260
AOAI Dev Day - Opening Session
yoshidashingo
2
470
Featured
See All Featured
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
121
18k
Designing Experiences People Love
moore
136
23k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
360
22k
In The Pink: A Labor of Love
frogandcode
139
22k
Bootstrapping a Software Product
garrettdimon
PRO
304
110k
Facilitating Awesome Meetings
lara
46
5.8k
Building a Modern Day E-commerce SEO Strategy
aleyda
25
6.7k
Ruby is Unlike a Banana
tanoku
96
10k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
44
4.7k
10 Git Anti Patterns You Should be Aware of
lemiorhan
652
58k
The Invisible Customer
myddelton
117
13k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
226
52k
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