跳到主要內容

184開發感想

這篇其實開發到一半就想寫了,這次開發真是累翻了,沒有加班的天數居然屈指可數,當覺得超前了,經過一連串測試修正後,進度反而落後了,然後又開始加班了。這次unit test根本沒有作完,總覺得這次bug數一定會破表,雖然在沒有已知的bug的情況下進入了α階段,但是就像考試時,沒有做完完整的的檢查一樣的令人不安,而且實際開發時程與實踐開發衡量方式與預估有很大的不同。回頭來看看,到底為什麼會發生這樣的狀況。

1. 開發時程預估差距過大:

差距最大的還是走勢圖,基本上個股和指數的寫法幾乎完全不同,指數走勢圖所花的時間是個股走勢圖兩到三倍的時間。原本估計的時間是個股和指數一起寫完,原本認為個股寫出來指數也會很快的就完成,所以開發整個走勢圖預估的時間大概是個股走勢圖完成的時間乘以1.5倍,但實際上完成的時間卻幾乎是3倍,也就是說多花了一倍以上的時間,為了趕上進度,就只有不停的加班了。另外一個差距比較大的地方是排行表設定的部份,原本預估的時候,我的想法是盡量不更動原本紀錄架構,只是把UI調整到位,但是看了技術分析的版本的時候,我發現依原本的架構,是沒有辦法達到像技術分析一樣的效果,尤其如果未來在加上更多商品分類,得花更大的功夫開發。只好狠下心把整個架構翻掉,這樣開發的內容超乎我估計,當然又是一次加班的開始。其實我不爽的是我覺得這是很沒有價值的調整,在我精疲力盡之時,又要再加班,這股火氣幾乎另我喪失理智。

2. 港股資料源問題:

在開發走勢圖初期,因為沒有港股資料,開發的方法完全只有自己模擬資料,或依據bk舊的介面實做。但是等到有資料源後開始測試時,又得開始調整。有種事倍功半的感覺,因為每次link test都把之前寫的方法推翻掉,所以每個階段的link test比預估來的還要長,這也是進度不停落後的原因之一。

3. WBS與單元測試進度無法配合:

原本預計的開發流程是當每個WBS完成,應當依據測試計畫測試該WBS應當作的測試案例,但是資料源未完成時,有許多案例無法測試,因此只好進入下個WBS,如此而來原本unit test要與開發實際互相結合的方式便無法實現,結果變成把所有測試丟到後面來作。當開發時間已經不足了,單元測試自然也無法完成了。

4. 以完成日來決定開發時程:

這次時程的安排似乎受到的在某個特定日之前一定要完成的暗示來排定時程,這似乎是我在『在公牛上擠牛奶』這本專案管理書上看到不好的案例,雖然書上講的案例是接案人員,為了搶案胡亂開定時程與功能範圍,而當時程與功能無法配合時,專案自然就會失敗。當我們認定一定要在某日之前就開發完成,當排定的時程超過時,得自動縮減各個開發時程。但是縮減時程,就得面對開發品質不佳的風險。也很容易造成所謂的奈米完成日,在這日準時完成的機率,只有百萬分之一。

5. 規格書出現未預劃時程的規格:

部分規格在開發末期才發現有此規格,除了規格書標示更動之處不明外,其實我認為這是unit test沒有在開發時一併落實的後果之一。當unit test於開發時便一併進行,便容易看到之前沒有看到的部份,不過規格書一改,就要重新測試一遍,也是很麻煩的。但是要規定規格書不改好像又不可能。

這次的開發與183開發有很大的不同,如果下次有此狀況,我的建議是:

1. 先作與資料源無關的部份:

當資料源也一同並行開發時,我覺得先作與資料源無關的部份,當資料源完成後,再進入此處開發,避免事倍功半。或者資料連結部份先跳過去,等資料源完成再回來開發,但是這樣時程的安排會有一點奇怪,可能相同的部份要先跳過

2. 排定密集的link test:

因為相關的資料源也同步在開發,資料源一修正,我們也必須作相對應的測試與變動,以這次開發看來一個禮拜的開發週期排定一天以上的link test會比較佳,而非原來整個時程僅排定兩次的link test,並且以這次開發來看,最後的link test比想像中來的長。

3. Unit test與link test結合:

其實我一直覺得unit test是衡量進度的一種方法,每個WBS的完成意味著已經通過了此部份的unit test。但是如我前面所提得,如果開發與資料源有緊密的關係的話,此WBS是否完成與資料原有很大的干係,因此以link test的時程為unit test的一個衡量點或許會好一點。

4. 不要預設在某日之前一定要完成來規劃開發時程:

當決定在某日之前一定要完成時,會錯估時程的判斷,依實際要開發的時間來估計吧,不要以如果砍時程,那麼就加班來應付,看起來開發過程中,加班是一定的,如果一開始就決定加班,那可真是災難的開始。

5. 測試與修正時程拉長:

測試與測試後的修改應該包含在時程規劃中,而且依這次看來這段時間還不短。拉長的另一個因素是我們不知道最後規格書會修改多少,通常就算規格書新增或修正功能也還是不能延長時程,因此這段時間也應把這個風險吸納進去。

6. 把企劃拉進來測試:

其實這個想法,上次就提過了,主要的理由是可能他表達的與我們理解的有些差距,在每個階段的測試時把他拉進來看,不是為了測bug,而是確認這是他要的功能,所以他不用作資料正確性的驗證或monkey test,他僅需做的是規格的確認而已。至於QA要不要拉進來,感覺上這是政治的議題,哈哈。他們說沒人力,如果有也只派一個資淺的,那不是一樣嗎,如果在α階段時之前沒有參與測試的QA人員說要改功能,我們能說不討論嗎。如果共同的目標是讓產品有好品質,這自然得討論,如果以他們有人進來測試而沒提出問題來回堵他們,這不是很奇怪嗎。所以我覺得要嗎,進α後規格書都不要改,不然就是QA在開發時就全部進來確認規格與程式功能。不過以上兩點我都覺得不可能達成。所以似乎規格在α期間變動是理所當然的。此外我覺得如果把規格更改的時間也納入我們的α時程,也是件不公平的事,為什麼新加或修正的功能也算在我們頭上呢?所以我覺得如果在α階段有修正或新增功能,而我們又如期進入β,那我們應該算是加分才對啊!

總歸一個原則,把測試含進時程規劃裡,並且不是最後才做而是階段性的作。我所認為的測試,兩個人互測其開發的項目,這樣才會檢查出漏掉的地方,而不是自己單方面的測試。時程預估錯誤,雖然也是進度落後的主因之一,但我覺得是不可避免的,有時候估計的太短,有時候估計的太長,這都是互補的,只是下次預劃時程得更加注意這次預畫錯誤的原因。另外此次雖然WBS不停的修正,但事實上實際所花的時間與修正內容還是有差距,只是不停地想跟上所預畫的進度而不斷的加班。

其實這次開發,學到很多程式的技巧,收穫不少,但是也很累,希望這次的經驗對下次開發有幫助。如果本篇概念有錯的地方請指正,謝謝。

留言

這個網誌中的熱門文章

勝券在握

其實這本書,感覺上寫的有點雜,比上一本講巴非特的書更難懂,兩個講的東西其實是一致的。投資原則便是先選產業,再選公司,慎選時機進場。只買了解的企業是價值投資一貫的原則。價值投資的書大概就先看到這裡了,彼得林區不知道是屬於那一類的,接下來大概會看這部份的書。暫時的目標是把杜金龍介紹的書單看完,真的還不少。接下來的投資會以巴菲特的方法來做,感覺上這比較適合我,練習把漲跌不當一回事,對我而言真的很重要。期權大概不會再玩了,買了以後一直在看漲跌,令人受不了。工作時都不能專心。 就價值投資人而言,真的不需要我們的產品,因為第一點就把我們程式特性打死,不理會股票市場的漲跌,這樣報價功能就沒什麼意義了,價值投資根本不需要技術分析,除非我們能提供相關價值投資的資訊,但我們基本分析真的很爛,看不到什麼資料。有機會我來思考一下價值投資到底要什麼資料,能不能把他寫成一個可運用的程式。 以下是我認為重要的書摘,其實這也只包含最後一章,我認為也只有這章值得做書摘。 巴非特相信使用短期價格來判斷一家公司的成功與否是愚蠢的。取而代之的是,他要公司向他報告因經濟實力成長所獲得的價值,一年一次,他固定檢查幾個變數: 初始的股東權益報酬率。 營運毛利、負債水準與資本支出需求的變化。 該公司的現金產生能力。 如果這些經濟指標正在進展,他知道長期下來,結果會反應在股價上。短期之內,股價所發生的是是不合常理的。 投資策略 不理會股票市場每日的漲跌 不擔心經濟情勢。 買下一家公司,而不是股票 管理企業的投資組合 巴非特原則 企業原則 這家企業是簡單且可以了解的 了解一家企業如何產生利潤的相關經濟活動。 這家企業的營運歷史是否穩定 他必須經得起時間的考驗。 這家企業的長期發展前景是否看好 市場特許權,五力分析 經營原則 經營者是否理性 理性的經營者將只會把多餘的現金,投資在那些產生較資本成本報酬率為高的計畫裡。 經營者對他的股東是誠實坦白的 報告時能知道營業部門如何營業,坦承失敗,了解公司的目的是使股東權益報酬率達到最大。 經營者是會盲從其他法人機構的行為 當心『其他公司也這麼做,一定沒問題』為自己行為辯護的經營者。衡量經營者競爭力的一個方法是,看他們如何運用自己的思考能力以避免依附群眾心理。 財務原則 把重點集中

Slim Diray 1/15

飲食:早餐/麵包;午餐/自助餐;晚餐/蘋果*1+柿乾*1+蛋糕*2。晚餐八點前吃。 運動:Boot camp1+Boot camp3 +腹部運動*1 體重: -7.8 公斤 (與前日同重) 74.2 公斤 大腿圍:57cm(+-0) 腰圍:88.5cm(+-0cm) 就寢時間: 02:00 檢討:今天晚上吃的也不多,運動量也不少,但是減不下來,人體真是奇妙啊!一點都搞不懂。 今天下班回來,經過健身工廠,想去看看他們免入會費後費用如何,結果一個長得很像浩角翔起阿翔的教練叫DJ,來推銷,還蠻會說話的,也很活潑,看起來瘦瘦的,但是他說他是海陸的,說他也是練得很厲害,胸肌還動了一下,秀一下胸大肌。他講解的感覺上是不錯啦!我也想知道我要怎樣減下肢與腹部,只是這個分館,太小了,預計4/1開幕,綁一年約月繳1000左右,還要繳手續費1000元,並不便宜,一直跟我說1000/30一天也才30幾元。但是我又不是每天報到,一禮拜去2-3天就不錯了,一個月最多十幾次,這樣一次就7-80了吧。這還是比較有空一點的時候,如果工作忙的時候,可能那個月就泡湯了。可見只要不是美女推銷員,我的智力正常多了。我跟他說看公司可不可以簽約,當作員工福利,我就先參考看看。對了Emma姊,要去看一下胸大肌跳動嗎!你不是要減肥嗎?要尋找春天嗎?我覺得DJ很適合ㄟ,會搞笑,最近剛結束三個月戀情,他正在尋找戀情。他是引誘我說他們已經很多女會員簽約了,跟我講一起找。 普魯斯特問卷 11.你最奢侈的是什麼? 我骨子裡是一個很強調C/P的人,基本上我覺得我的花費值得這個價的話,我就不會覺得奢侈了,我最大的單一消費也就是出國旅遊吧!但是我覺得這是值得的,每一趟旅遊,我都盡量讓他成為我人生不可磨滅的一部分。所以只要有出去我就寫遊記。如果在別人眼中,大概會覺得我花在腳踏車上的費用太高了,但是有在騎腳踏車的人,就會覺得我都買入門級和便宜貨。全身上下的腳踏車裝備也都是最便宜等級的。其實我覺得我最奢侈的是,我只做短暫不明的分析,就決定購買某種投資商品。賠了不少學費。卻每次都覺得沒學到什麼投資概念。這才是最奢侈的。 補一個現在我覺得最奢侈的幸福,就是女朋友躺在我懷中一起在床上看影片,(妄想課長上身,發春中)。

Slim Diray 1/13

飲食:早餐/麵包*2;午餐/大板條;晚餐/蘋果*1+魚肉*30g+餅乾*1。晚餐八點前吃。 運動:Boot camp2+Boot camp3 +腹部運動*1 體重: -6.8 公斤 (與前日同重) 75.2 公斤 大腿圍:57cm(+-0) 腰圍:88.5cm(+-0cm) 就寢時間: 02:00 檢討:晚上吃的很少,運動也超量,但就是沒減下來。又到了停滯期了嗎? 昨天講馥菁是大魔王,我就想到電車男中的陣釜大魔王,嗯!的確有那股味道在。今天一整天都在為昨天知道的消息煩惱。先靜下心吧!還是什麼都別想。 昨天一直想寫一個點,昨天又跟之前台北的美麗保險推銷員通電話了,嗯!要繳保險了,打電話來關心一下。她也是我遇到美女智力會下降的證明,簽約的時候根本就是失神狀,講哪裡就簽哪裡,被賣了都不知道。她是高雄人,這次過年會回來,一定要照張像留個念。當初判斷她好像結婚了(無名指戴戒指),但是看她的習性,應該是還沒有,這次一定要問出來,如果他在高雄工作,我一定追她。(謎之聲...明明就是嘴砲,她又不會在高雄工作)。 想到她,我就想到我當初在台北想追的女孩,這件事過了很久,我也離職了,可以解密了。他是同部門的助理,她很可愛,因為不同樓層,很少見面,所以當初是用msn進攻,不過他都打火星文,看她的字,傷透腦筋,要拐超多彎。那時她有男朋友了,經過兩個多月的聊天,忘記當初怎樣問到她男友的,她說他男友一直打魔獸不理她,很不高興(魔獸真是去死去死團的好友啊!),我就心想喔!時機到了,那個禮拜六,就打電話給她,想請她這個士林在地人帶我逛士林夜市,這是之前在msn承諾我的。結果她說沒空。我就想說好吧!下禮拜吧! 結果下禮拜一,她就..........消失了,禮拜三的時候,主管開會的時候,就問我們有沒有跟她連絡,她什麼都不講就消失三天了,問是不是我們某人害的,那時我心裡就想,靠!不會吧!不想履約,也不用連工作都不要了吧!因為那時是msn聊天,所以沒有人知道我跟她超熟的。是的,到我離職也沒有人知道這個秘密。之後msn上,也沒看到她了。我一直以為他封鎖我了,(造成'我打電話約女生的陰影...)。過了一、兩個月後,突然看到她上msn,原來她上線的時間,剛好跟我相反,那時我下班都不會注意msn,所以都沒注意到她上線,後來聊了才知道其實他當初離職,是主