2011年11月25日 星期五
[專案管理]用Visual Studio 2010實踐團隊開發
在Visual Studio 2010專案中有一項整合開發與專案管理的關鍵,可以讓所有工作記錄相互串連,從開發流程中的任何一點都能找出相關內容,不論是工作記錄、程式碼、測試結果無所遁形,這個關鍵就是Work Item,也是管理開發團隊的利器。只有做到原始碼版本管控還不夠,要善用Work Item才能有效管理開發團隊。
善用Work Item串聯所有開發工作
Work Item能夠讓工作記錄相互勾稽,軟體開發流程中的每一個點,都可以串出其他行為,就像是一串粽子一樣,抓住任何一顆粽子,都可以拉出其他粽子
首度在非洲舉辦的世界盃足球賽剛結束,由擅長全能攻守型的西班牙獲得冠軍,這些球員不見得是全世界技術最頂尖的人,但是他們的確是團隊合作最好的球隊,足球是最重視團隊合作的競賽,前鋒、中場、後衛,守門員各司其職才能打勝仗。
程式開發其實也是團隊合作的成果,不同角色的專案成員,從專案經理、系統分析、系統設計、程式開發、測試人員等各司其職,才能順利執行專案,尤其是複雜的大型專案,更是需要團隊的專業分工才能完成。
開發過程中有很多細節,開發團隊為了有效溝通,需要借助工具和方法,就像是足球教練必須擬定球員互相搭配的戰法,讓前鋒知道如何相互短傳搭配進攻,讓後衛懂得同步移動創造越位陷阱。專案開發也需要一套有效的利器。
不過,經常擔任開發專案顧問的微軟特約顧問胡百敬觀察,臺灣的.NET開發團隊大多只有進行程式碼版本控管,再搭配電話或電子郵件來討論工作和管理文件,並沒有發揮專案管理的功能。
胡百敬指出,電話難以記錄而電子郵件則版本控管不易,每次到開會時才發現,彼此手上的需求文件或功能文件版本不一,每個人看到的專案資訊不一致。而程式碼版本控制程式也無法記錄每個人的開發進度、測試結果或Bug處理狀況,導致專案無法有效管控而容易失敗,不只是開發效率不彰,程式品質也會容易不穩定。
為了控管開發專案的進度,有不少專案經理則是使用Project或Excel來管理,但集英信誠執行顧問陸雲中表示,用不同的工具分別控管程式碼版本以及專案進度,仍舊得透過人工作業來處理兩者的關連,相當麻煩。
微軟為了解決這些開發專案的團隊管理問題,打造了一套團隊開發的專屬工具,也就是Visual Studio和Team Foundation Server(簡稱TFS)。
陸雲中表示,「TFS可以管理和開發整合到同一套系統中,可以讓管理者更容易掌握開發狀況。」
Work Item能讓所有工作記錄相互勾稽
陸雲中說,在同一套系統中,開發文件集中在文件庫,所有專案工作項目記錄在Work Item,原始碼也集中控管,任何人都可以透過Visual Studio的Team Explorer、Office或瀏覽器看到開發專案的內容,「每一個人看到的資訊版本相同,而且有歷史紀錄,確保資訊一致是專案管理很重要的一環。」
除此之外,在TFS中,「每一個工作記錄都能夠互相勾稽,軟體開發流程中的每一個點,都可以串出其他行為,就像是一串粽子一樣,抓住任何一顆粽子,都可以拉出其他粽子。」胡百敬表示:「能夠達到這樣效果的關鍵就是Work Item,所有工作都記錄在Work Item上就可以相互勾稽。」
其實,TFS在2005年版中就提供了Work Item的機制,透過Work Item可以建立程式碼和工作項目的關聯。專案管理者先在TFS中依據工作項目建立Work Item,而開發人員寫完程式碼,簽入系統時,則要指定程式碼所完成的Work Item項目,就可以建立兩者的關聯,「Work Item正是將管理和開發串連的關鍵。」陸雲中說。
不過,VS 2005版本的Work Item功能不盡完善,每個Work Item是平行關係,必須展開到細部內容才能建立與其他Work Item的關聯,長期使用TFS管理開發專案的博暉科技研究開發處協理崔啟文認為,實際使用相當麻煩,而2008版的Work Item功能則和2005年版的差異不大,「直到最新的VS 2010版,Work Item功能才更成熟。」
Work Item不可刪除,確保專案紀錄可追蹤
在VS 2010中,專案經理可以建立樹狀結構的Work Item,可以依據工作性質建立Work Item之間的父子關係,甚至可有前置項關係,可以設定某一項工作完成後才能進行下一項Work Item。而且任何Work Item只能新增、修改,而無法刪除,因此,專案經理可以追蹤到開發專案中所發生的每一件事情。
除此之外, VS 2010也針對測試人員增加了額外的Work Item,例如測試計畫、測試案例等,都是以Work Item形式儲存,測試結果可以和其他Work Item,例如Task、Bug等連結,這些工作還能讓Test Manager在半夜透過Team Build進行編譯,部署到虛擬實驗室所管理的環境中,執行UI自動化測試,「從頭到尾把開發相關的角色都串接起來。」
順利安裝TFS的關鍵
導入TFS時,常遇到的第一個問題是安裝與設定,要建置TFS的執行環境,必須安裝完整的SQL Server,包括Reporter Server和Analysis Server來提供報表功能,另外要安裝SharePoint Server建立團隊入口網站來管理文件,再來就是安裝TFS 2010,另外在使用者端除了可以安裝VS 2010外,還需要Office軟體,如Excel或Project,作為設定和管理專案的另一套Client工具。以上是基本TFS的執行環境,若要進行Build功能則還要安裝Builder Server,或者是安裝Team Lab結合SCVMM來控制Hyper-V虛擬環境。
另外還要分別設定Report Server、SharePoint Server和TFS的授權,前兩者通常是企業現有服務,須由對應負責人另外設定。而編譯後檔案所存放的共享目錄也需要開放權限,否則很容易因無法寫入而編譯失敗。
6階段TFS導入策略
完成安裝與設定後,陸雲中建議,可以分成6個階段導入TFS,第一階段先集中程式碼,建立程式碼版本控制機制,並且讓所有成員開始使用TFS。第二階段則是訂定程式碼分支模式(Branch Model),程式碼的版本管理方法,到此是大多數企業常見的作法。第三階段則要開始加入Work Item,並且建立Work Item的流程,訂定Check-in政策,來結合Work Item和程式碼版本控制,同時可以開始導入Test Manager將測試納入開發專案的管理。「到此算是第一個里程碑,10~20個人的團隊,大約需要6~12個月時間導入。」他說。
第四階段則是導入Unit Test,第五階段是導入Team Build,最後則是進行報表客製化工作。後面這三個階段,大部分時間用來建立開發團隊撰寫Unit Test程式碼的習慣,陸雲中指出,初期開發者得多寫很多測試程式碼,會影響生產力,但是到了中後期,開發者可以不用擔心舊版程式碼會出現錯誤,搭配版本控制很容易找出問題,此外,Unit Test的程式碼也是最好的教科書,可以讓其他開發者快速了解程式。導入4~6階段大約需要半年時間。
不過,陸雲中建議企業,導入評估時就可以開始試用新功能,導入時要採取80分哲學。「不是將既有流程完整搬到TFS中,而是要改變流程配合系統。」而且要最後才進行客製功能,等到運作一段時間後再進行優化,逐步調整開發流程。「如果一開始就進行客製化,很容易因為短時間達不到預期效果而讓導入失敗。」他說。
導入TFS以後,開發團隊得先建立Work Item,才能發揮TFS各種開發專案管理的效果,接下來將用一個實際案例,告訴你如何善用Work Item來管理專案進度。
博暉科技開發流程標準化的秘訣
5年前,博暉科技用Team Foundation Server建立開發制度,讓安全控管、版本控管和流程控管三大流程標準化,今年更進一步導入VS 2010強化專案成本控管
善用本文點有效估算開發專案的時間成本
本文點其實是一個抽象概念,可以用來代表任何單位,主要用來計算,完成一個User Story所需要的時間
在VS 2010中,增加對Scrum方法論的支援,在User Story和Task這兩種Work Item的屬性上多了一項本文點(Story Point)的設計。博暉科技研究開發處協理崔啟文指出,本文點讓VS 2010專案多了時間概念的成本控管方式。今年2月,博暉開始導入VS 2010來開發兩個新專案,就運用了本文點來估算專案的時間成本。
崔啟文表示,本文點其實是一個抽象概念,可以用來代表任何單位,主要用來計算,完成一個User Story所需要的時間。一個本文點可以代表1人時、2人時或者是1人天等,可依實際開發情況自行定義。
常見一種定義本文點的作法是將1點定義成1人天(8小時),不過,崔啟文認為:「用1天的單位所估算的時間太粗略,我剛開始先用1點等於1人時或2人時,再隨著專案開發過程慢慢修正找出合適的對應方式。」
為每一個 Work Item估算本文點時,崔啟文有兩種作法,第一種是依據工作難易度來決定。例如有兩件Task(工作),工作A和工作B,A的難度是B的兩倍,崔啟文就定義A是兩個本文點,而B只有1點。依照這樣的邏輯,相互比較出專案中每項開發工作的本文點,最後可以加總出這個專案所需要的總點數,這就是專案所需要的開發時間或者是開發成本。
崔啟文也提醒,用工作難度的方式來比較本文點,是從研發產品要完成軟體功能的角度來看,比較沒有考慮專案時程的壓力。他建議,若要考慮專案時程,也可直接比較不同Work Item的工作量來估算本文點。
等到專案完成,崔啟文再來比對本文點與實際開發時間的關係,例如一個專案實際上用了5個人和100個工作天,也就是5人乘以100天乘以每天8小時,總共花了4,000 人時。若這個專案的本文點總數是2,000,就可以得出每1個本文點等於2個人時。
經過幾次專案以後,這個用本文點對應人時的對應規則,會越來越接近實際值,就可以用來估算還未進行的開發專案。專案經理只要完成開發專案所需要執行的Work Item,並且估算出每一個Work Item所需本文點數,彙總出新專案的總本文點數,就能運用對應規則估算出這個新專案所需要的時間成本。在VS 2010中也提供了一些進度報表,利用本文點計算出專案的理想進度,崔啟文表示:「當本文點越接近實際情況,這些報表的參考性越高,專案經理更能夠掌控管理專案的實際進度與成本。」他也建議企業,專案經理必須了解Scrum方法論和本文點,才能發揮VS 2010各項報表的效用。
關鍵 1 運用集合和區域來組織專案結構 延伸閱讀
適當規畫專案結構,才能有效管控人力和進度,可用VS 2010集合功能區隔部門,用Team Project和區域功能來分類產品和團隊
關鍵 2 建立原始碼分支原則與文件控管 延伸閱讀
團隊開發需要建立一套程式碼分支原則,建立分支才能同時進行不同的專案任務,提高團隊開發效率,開發文件同樣也要建立控管政策
關鍵 3 建立Work Item才能整合開發與管理 延伸閱讀
在VS 2010專案中,Work Item是讓程式碼開發與專案管理串連的關鍵,必須建立Work Item後,才能進行各項專案管理的措施
關鍵 4 用報表追蹤專案進度和效率 延伸閱讀
VS 2010提供了多種管理專案進度的報表,結合Scrum開發方法論,讓專案經理透過本文點來估算開發專案的時間成本和進度
訂閱:
張貼留言 (Atom)
沒有留言:
張貼留言