阿里妹導讀:業務的快速發展,須要咱們更快速地響應,和更高質量產品的交付。如何從原來大(xiao)迭(pu)代(bu)的開發模式切換爲精益開發模式?以 2-1-1(2周需求交付週期,1周需求開發週期,1小時集成時長)爲願景驅動改進,達到持續交付價值,響應業務要求成爲咱們的目標。今天,閒魚工程師琪鈺爲咱們分享:閒魚是怎樣朝着這一目標前進的?切換爲精益開發模式後,又面臨了哪些問題和挑戰?weex
名詞解釋:精益開發模式,團隊基於看板組織協做,以持續地交付需求爲目標,需求按優先級,逐步進入開發、提測。因爲在項目協做中,採用看板泳道來管理需求,所以在閒魚,同窗們習慣稱之爲泳道模式。併發
因此,構建一個貫穿從需求到代碼開發,再到測試整個過程的流程,並將其工具化、自動化就顯得十分必要和緊迫,而持續集成就是這一流程的重要形式體現,構建一個高效的持續集成系統擺在咱們面前。這將必定程度下降開發過程當中的溝通成本,流程工具化,加速自動化。工具
如今針對服務端的集成發佈有不少能夠參考的實踐,但對客戶端的集成發佈來講,咱們依然面對以下難點。單元測試
如何作到需求和代碼分支關聯,確保代碼可追溯;測試
如何作到代碼分支和打包項目關聯,代碼變動可自動觸發打包;ui
如何作到代碼範圍和測試範圍關聯,確保測試迴歸範圍。編碼
而要解決上面的這些難點,缺乏一站式的工具平臺支撐(集團內平臺對服務端的發佈有很好的支持,但對於客戶端的集成發佈來講,涉及平臺工具比較多)。spa
爲了解決從需求建立到發佈整個項目研發過程當中協同、構建、集成和測試等遇到的問題,提升團隊的持續交付能力。針對客戶端集成發佈,咱們的總體方案的目標是首先是拉通整個需求交付流程中各個環節,簡化持續交付工做,提供及時的質量反饋機制,讓開發同窗關注在業務的開發;有效提升集成成功率及縮短集成發佈週期,讓版本可以按時上線你們可以按時下班;建設可視化、自動化、智能化的持續集成流水線,讓業務需求真正的可持續交付。blog
空談誤國,實幹興邦。在談論更多的改進以前,咱們先把基礎本的流程經過工具先串起來,只有先看到總體,而後再發現問題逐步改進。開發
流程化
咱們的核心流程是這樣的,一旦建立需求分支,交付通道就已創建,直到需求發佈。
當完成了第一步,將整個流程打通以後,咱們發現,在整個流程中,依然有不少是依賴人工操做的地方,這是最容易出錯,而且極低地影響效率的地方,對咱們來講,這是改進的機會,因此,第二步咱們的重點就是作好無人化和自動化。
無人化
爲了支撐持續集成流水線的運行,以無人化、自動化、可擴展爲目標,及基於最小研發成本原則,咱們作得事情主要分爲精益開發流程協同支撐無人化及測試驗證自動化兩部分。
fish CI 主要是研發流程支撐,如需求綁定、監聽變動、觸發打包、觸發測試等,fish guard 主要測試件調度、執行,結果通知,及後續測試件接入擴展部分。目前已接入的測試件主要有 UI 遍歷、UI 識別、monkey、單元測試等。後續計劃按照分層測試的原則,接入更多的測試件,如代碼靜態掃描、weex 自動化測試、服務端測試件等,加強測試件覆蓋度,拓展自動化測試邊界。關於這一部分,咱們將在後面的文章中作更深刻的分享。
數據度量
管理學之父彼得德魯克說:「若是你不能度量它,你就沒法改進它」,其實也是咱們整個持續集成流水線的自檢,咱們到底作得怎麼樣,持續交付的能力如何,咱們定義了以下指標用於後續統計。
指標主要分爲響應能力、效率、質量三個維度,經過響應能力的這些指標,能夠反應出打包變快了,質量反饋變快了,集成變快了,集成頻率變高了;有效率的指標,反應出流水線工做的有效性,成功率越高說明流水線越穩定;最後質量,主要從代碼質量和項目測試質量來度量,經過修改的文件數,模塊分佈能夠反映出代碼的拆分、依賴等狀況;經過項目測試中 bug 的分佈和庫存,能夠反映出項目質量狀況,是否及時發現及時修復,是否達到發佈標準等。
閒魚從3月中旬開始試運行精益開發模式(持續交付模式)到如今,閒魚全部的業務需求所有走精益開發模式,咱們交付的速度,由一個月一個版本到兩週一個版本。這離不開咱們在流水線各個環節中的改進,如打包變快了,需求分支構建次數愈來愈多,集成頻率愈來愈高,以及自動化測試驗證及時反饋集成質量狀況。此外,閒魚在精益開發模式下質量得到了明顯提高,以下圖所示:
綠色分割線左半部分,是以前未切換到泳道模式前的一個版本,bug 趨勢看,前面編碼階段,測試基本未介入,大量的代碼批量集成後集中測試,在缺陷充分被移除後,才能交付,沒法持續交付。綠色分割線右半部分,是某個業務線的缺陷趨勢圖,小批量的持續集成、及時測試和發現問題、及時修復,能夠快速持續交付。
簡單總結下,咱們作的事情,第一步是拉通整個交付過程,有一個穩定的交付過程,第二步保證交付的效率,即響應變快了,集成變快了,質量反饋變快了,第三步持續交付,關鍵詞是「持續地」,頻次上提出了更高的要求,集成的頻率變高了,之前一個月集成一次,如今天天都能集成,從一個月一次,到 nightly build,再到隨時集成。即相比之前,讓開發同窗「更」有信心集成一次變動併發布。
所以,咱們的終極目標就是7*24隨時發佈,沒有發佈窗口限制,真正作到交付流水線自動化無人化和全自動化測試,下降持續構建成本,拓展自動化測試邊界。
原文連接 本文爲雲棲社區原創內容,未經容許不得轉載。