跳到主要內容

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不停的修正,但事實上實際所花的時間與修正內容還是有差距,只是不停地想跟上所預畫的進度而不斷的加班。

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

留言

這個網誌中的熱門文章

勝券在握

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

10/17部會心得

其實部會一開完,我就想寫了,只是最近沉迷於小說,直到今天才有開始動工的心情。 業務的報告部份就不要講了,一點都不感興趣,講的好像會大賣的樣子,薪水有增加再說啦! 技術方面, DQ 做的功能好像挺有意思的,不過感覺上沒人看出他的價值,不過我覺得最佳的 UI 還是 vs 2005 為主,如果要研發基底的 UI 我覺得要以類 VS 為目標。金融網的東西也令人興奮,我本來就覺得網頁的東西潛力無窮,雖然是抄的,不過覺得還不錯,網頁互抄比 AP 互抄容易多了,很多 AP 的功能要模擬出來,真的比想像中難太多了。雖然金融網聽到最後我睡著了,但我非常期待他下一版能帶來什麼。好吧!說一下我們這邊技術心得,看起來炫,但是我一點都不心動,因為我想不到這東西能增加我們產品的價值嗎? 這場部會最棒的是最後副總的報告,這是第一次瞭解整個產業環境與我們的應對方法,這樣我才清楚為什麼要成立那麼多非資訊本業部門,金融網成立的原因何在,產業鏈垂直整合的價值在哪裡。但是會像如規劃中的成功嗎?其實從旁觀察規劃與現在實際的運作,我抱的期望沒那麼大,不過這是有意思的夢,就看能不能實現囉! 不過在會中,我就想到一個我覺得可以配合上我們的產業架構,而且還不錯的商業模式,這也是我想寫這篇心得的原因。 在副總的報告中,提到金融網是為了提供一個入門的金融資訊,接觸最底層不付費的又想看金融資訊的民眾,其實我想到更進階的是接觸所有上網的人。而這功能結合 43thing 與財務規劃(參考 到底要賺多少錢才能退休呢? )你要作這些你想要做的事情(如遊學、旅遊)或退休,你到底要賺多少錢,然後開始洗腦光靠上班的死薪水是達不成這些目的的,所以要開始投資,投資如何規劃,就是要買我們的金融產品,一步一步引君入彀。這功能主要的對象就不只是想投資的人,而是所有的人,只要你心中有任何的夢想,而這夢想需要錢來達成,就需要這個工具。這就是把基底做的更大,個體經濟學常用的互補效應。所以這功能包含紀錄你要達成的夢想,財務管理包含薪資增加目標、稅務、相關的投資規劃與風險等。目標就是吸引所有人來理財、投資。 另一方面,我想倒也有一些人就是他沒有時間也沒有能力去學如何投資或操作股票,他們只想跟老師聽名牌,那這個就可以結合 blog 的功能來作,吸引一些老師來 blog 建立個人投資說明,開發一個跟單工具,這跟單工具可以比較所...

Web2.0在促銷產品的應用

我想說明一下我在星期五上所提得話題是有背後的理由的,我提到Rss一直無法突破成為一般大眾接受的技術,討論這話題的主要原因是想提醒大家如果你面對的是一般使用者不是進階使用者,這技術可有可無,不會特別增加你的網站流量和黏度。不要跟我講有總比沒有好,請把精力花在重要的地方,這是我的想法,有太多東西該做,不怎麼重要的東西留到最後。第二個我最後提到的問題,研究這個是要幹嘛,要做個2.0網站做啥。原來是要推銷我們的產品,這倒有點意思了,一般我在Mr6上看到介紹有關新型態的網站很少推銷單一產品的,大部分被人稱作Web2.0的網站,通常都當自己為媒體平台來賺錢,如部落格利用Google AdSence賺錢、各相簿與部落格網站也利用版面廣告賺錢、Dig類型或書籤分享類型,也是利用內容特性插入版面廣告賺錢。對單一產品做行銷,好像是所謂Web1.0的特色。行銷單一產品在Web2.0我是沒看過,但是我到是看過一兩則介紹利用blog提昇企業形象,毛寶的企業 blog ,以及我上一篇打的 經商利器部落格 ,或許這適合我們情況。 因此我的想法是架一個部落格,專門探討財經的議題,譬如如何選股,選股該看哪些資訊,這個時段有哪些飆股可選,帶入我們的程式來展現,就像pre sale開課一樣。但是就如那篇經商利器提到的不是介紹我們商品多好、多與眾不同。而是提供一個分析、一些觀念,是有血有肉的內容。從建立關係再來賣產品。企業部落格重點在於溝通,讓客戶了解我們產品的理念,我們聽到他們的需求、意見與批評,有好的也有可能有壞的。並且從這邊或許我們會得到一些反饋,作為開發新產品的基礎。至於怎麼宣傳,這倒容易可以學有名的個人財經部落格 楚狂人 ,每有一篇新著作就到國內最大社群網站ptt po文,只要有內容,人數保證衝的很快,持續不斷的更新,一定會有黏度的。但是可能的缺點是,ptt鄉民一般對商業性宣傳有潛在性的反感,如何改善或隱藏這缺點或許是個重點。總而言之,如果是用blog形式宣傳,最重要是內容與持續不斷的更新,但這不會馬上看到效果,朝這方向做心理要有個底,會有一段毫無績效而令人氣餒的時期。 就技術而言,blog的架設,建議使用wordpress,這架站軟體,不用浪費時間自己一個一個功能寫出來。 其實如果不是以行銷我們產品為目的,我的想法跟仲甫不謀而合,叫做digstock,讓大家去推或噓特定股票,從基本面、技術面...