在 appWorks有一些問題我們常常討論,例如:用什么工具、做什么產(chǎn)品、該怎么營(yíng)銷、該跟誰合作、怎么合作、什么時(shí)候增資、該拿多少錢…等等,這些問題往往沒有一定的答案,也必須要視情況而定。但越是沒有標(biāo)準(zhǔn)答案的,我認(rèn)為越是應(yīng)該多討論,這樣才能幫助創(chuàng)業(yè)者們根據(jù)自己的情況,定義出適合自己的處理方式。

  而關(guān)于編碼,「要不要寫 測(cè)試」是其中有一個(gè)這樣的問題。我個(gè)人的意見是當(dāng)你要做一個(gè)非常簡(jiǎn)單、用完即丟的MVP,那不必寫 測(cè)試。如果邏輯比較復(fù)雜、日后有維護(hù)的必要或是有和人家協(xié)同工作,那你一定要逼迫自己寫 測(cè)試。

  這不只是完整性、邏輯性或是身為一個(gè)工程師的職責(zé)問題,而是你如果不寫 測(cè)試,是跟自己過不去?跟好的 comment/documentation 一樣,不做的話,日后要維護(hù)時(shí),你將會(huì)花更多時(shí)間在弄懂自己當(dāng)初寫的 編碼,當(dāng)別人要用你的東西,你也必須花更多時(shí)間跟他解釋,這不是跟自己過不去嗎?

  我得承認(rèn)關(guān)于更深入的判斷什么時(shí)候要寫 測(cè)試、該怎么寫,我不是專家。但是讀到一篇文章寫得很好,在這里跟大家分享。

  1、測(cè)試:讓你用程序功力去挑戰(zhàn)你的程序功力??身為工程師,大家討厭的是不斷的手動(dòng)測(cè)試了,那何不把這些寫成程序?況且好的進(jìn)步方法是以己之矛,攻己之盾,這樣不斷的循環(huán)下去,你的程序功力一定突飛猛進(jìn)。

  2、測(cè)試:讓你跟你寫的程序還有你自己對(duì)話??當(dāng)你若干時(shí)間之后回來看自己寫的 測(cè)試,你將會(huì)重新檢視自己當(dāng)初的邏輯?這樣復(fù)雜的錯(cuò)誤處理真的有必要嗎?這個(gè)對(duì)象夠獨(dú)立嗎…等等,并且想清楚你寫的程序跟整個(gè)系統(tǒng)的架構(gòu)是否吻合。

  3、測(cè)試:提醒你程序是用「用了」多少行衡量,而不是「寫了」多少行??記住,棒的程序代碼,不是程序代碼!

  4、好的測(cè)試:設(shè)計(jì)還包含好的測(cè)試批注??如果你寫好的測(cè)試,別人更容易了解你的程序,和如何跟你介接。

  5、測(cè)試:讓你可以看穿別人寫的編碼??同樣的道理,如果大家都寫好的測(cè)試,那你可以更容易了解別人寫的 編碼,大家都會(huì)進(jìn)步的更快。

  以上,是一些關(guān)于寫 測(cè)試 這件事情的觀念,希望能夠讓你更認(rèn)同測(cè)試 編碼 的價(jià)值。或許你有更有趣的經(jīng)驗(yàn)?歡迎留言跟大家分享。