一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

我們的測試驅(qū)動開發(fā)經(jīng)驗

  你應(yīng)該聽過或讀過不少關(guān)于測試驅(qū)動開發(fā)的討論,測試驅(qū)動開發(fā)往往被比喻為神奇的獨角獸,它能幫你照看你的軟件,讓大家樂得其所。于是,在寫了18.000行“神奇獨角獸”代碼后,我想把我們的體驗從整體的角度闡述一下。

  真相其實是,測試驅(qū)動開發(fā)真TMD太痛苦了。寫那些沒完沒了的測試需要很強的自律,遠(yuǎn)不是你想象的那么簡單容易。

  但你知道什么更讓人討厭嗎?是缺少這些測試而出現(xiàn)的麻煩。

  讓我澄清一下。我并不是想來勸說你去實施測試驅(qū)動開發(fā)。我想做的只是要給你一個真實的認(rèn)識,讓你明白TDD是如何工作的,以及你能從中得到哪些好處。

  對軟件開發(fā)來說,我基本上把測試驅(qū)動開發(fā)當(dāng)做一種保險。它能保證你的軟件有一個預(yù)設(shè)的質(zhì)量關(guān)卡,大多數(shù)是依據(jù)bug的數(shù)量和軟件變更的風(fēng)險度來判定。它同時能降低萬一你的主要開發(fā)人員被車撞后造成的損失,以及你的軟件所依賴的平臺上的API遭遇類似事件所帶來的危害。

  然而,在我們所生活的這個星球上,仍然有成百萬的人每天過著沒有保險的生活,很顯然,達(dá)到目的的方式并不是只有一條途徑。這完全依賴于你的責(zé)任心和你能或你想怎么去做事情。

  在Transloadit公司,我們 100%的代碼都是由測試驅(qū)動開發(fā)的。我們這樣做的主要原因是我們的系統(tǒng)用了node.js,這種技術(shù)目前來看在某種程度上仍然是有很高的風(fēng)險的技術(shù),也許這正是我們最大的麻煩,但同時也是我們最大的優(yōu)勢所在。另外一個很大的風(fēng)險是我們使用的第三方工具包,例如ffmpeg和image magick,這些東西在升級時出奇的危險,因為它們動不動就改變API和接口運行方式。而最后一個,但絕對不是最不重要的一個,是我們的某些東西太復(fù)雜了。

  現(xiàn)在,讓我解釋一下我們?nèi)绾卫脺y試驅(qū)動開發(fā)來避免這些風(fēng)險的。首先,在開發(fā)所有的新功能前先寫系統(tǒng)測試。所有的系統(tǒng)測試都是利用整套的REST service,它產(chǎn)生真實的HTTP請求,評估響應(yīng)的信息,同時也檢查這個過程中產(chǎn)生的文件。我們通過文件的元數(shù)據(jù)信息來確認(rèn)文件,對于圖片我們使用特定的設(shè)計進(jìn)行可視化比較。對于視頻我們使用截屏圖像進(jìn)行可視化對比。

  一旦寫出來測試程序(也許是失敗的測試),我們就開始寫單元測試。讓我來解釋一下我們所說的“單元“。對于我們來說,一個單元是我們能測試的一個最小粒度的功能片段。只要存在函數(shù)調(diào)用,類的創(chuàng)建,甚至閉包的回調(diào),我們都會把它挑出來。所有的測試都是孤立的、分離的、能夠自動的運行處理。你可以想象的出,這部分工作是痛苦的,需要勇氣。

  可是,產(chǎn)生的結(jié)果卻是不可否認(rèn)的漂亮。寫這些測試感覺就像是在驗證數(shù)學(xué)理論。每一個步驟都是能夠分解的最小的邏輯單元。所有的步驟都是基于之前的一步。沒有必要每次都測試所有的 1 – 1000000個功能點,除非你有邏輯上的需求,需要一個特殊結(jié)果。

  很顯然,在這個過程中你有很多機會去做傻事,或者迷失了原始方向。這時系統(tǒng)測試就來拯救你了。任何當(dāng)你不知道下一步該做什么的時候,只要運行一下系統(tǒng)測試,它就會告訴你還少些什么要做。

  完美的過程嗎?不,在我們的產(chǎn)品中的這里或那里,多少都會有些bug,但不多,我十個手指頭都能數(shù)過來。上周末,我們對我們的產(chǎn)品做了一個瘋狂的改動:我們把底層的MySQL驅(qū)動(我們用的是php,別問我怎么做的)換成了node-mysql。我們已經(jīng)在node-mysql上工作了,同樣使用的是TDD-masochism,升級相當(dāng)?shù)钠椒€(wěn)(目前為止)。這種成績對于一個牽涉有6000行代碼的改動來說很不錯了。

  這就是我們做的。并不會由于我們使用了TDD,我們公司的產(chǎn)品就必然的優(yōu)于我們的競爭對手。但我們承擔(dān)的風(fēng)險要小的多,我們可以輕而易舉的做心臟手術(shù)。這給了我們分配資金的信心,給了我們能力去把剩余有限的資源(我們做事情步步為營)使用在新功能的開發(fā)上,而不是花在解決我們軟件里無處不在的缺陷上。

  那么,TDD適合你嗎?這要視情況而定。按TDD模式寫程序需要很強的自律,獨角獸不會一直陪在你身旁讓你放心。想好了再去這樣做。有時一些系統(tǒng)測試程序會用掉你80%的努力來測試只是20%的工作。而有些情況會讓你把剩余的20%也搭上。我們很幸運能使用一種靈活的語言,我們大部分的接口都是使用的JSON。這使我們的測試成本更低。這些我們銘記在心。

  [英文出處]:Test driven development at Transloadit

it知識庫我們的測試驅(qū)動開發(fā)經(jīng)驗,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲a在线观看 | 日韩精品一区二区三区乱码 | 欧美日韩一区二区三区自拍 | www.91成人| 亚洲丶国产丶欧美一区二区三区 | 国产伦精品一区二区三区女 | 韩国毛片视频 | 四虎影视永久在线观看 | 天天天天天干 | 在线小毛片 | 色爱综合网 | 巨大巨粗巨长的黑吊免费视频 | 999热成人精品国产免 | 91探花福利精品国产自产在线 | 一区二区三区四区五区 | 国内精品哆啪啪 | 亚洲一区二区三区在线 | 日本在线视频www色 日本在线视频免费观看 | 在线国产一区二区三区 | 99国产精品免费观看视频 | 精品在线视频免费 | 狠狠干狠狠干狠狠干 | 欧美精品第二页 | 五月婷婷在线免费观看 | 久久国产精品麻豆映画 | 97精品久久天干天天蜜 | 国产精品视频h | 国产精品亚洲一区二区三区正片 | 亚洲欧美综合图片 | 91杏吧在线网站 | 国产综合欧美日韩视频一区 | 91国视频| 青青草国产免费国产是公开 | 亚洲免费色视频 | 91精品啪在线观看国产18 | 999成人精品视频在线 | 日韩视频在线观看一区 | 黄视频在线免费看 | 精品久久看 | 九九久久亚洲综合久久久 | 欧美午夜a级精美理论片 |