自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

我的神呀,測試驅(qū)動開發(fā)真的有效!

開發(fā) 測試
我們經(jīng)常聽到人們宣揚說,在開發(fā)軟件時寫測試代碼(單元測試,功能測試等)能有效的減少產(chǎn)品中的bug。如何驗證這樣的言論?詳細請看下文

我們經(jīng)常聽到人們宣揚說,在開發(fā)軟件時寫測試代碼(單元測試,功能測試等)能有效的減少產(chǎn)品中的bug。如何驗證這樣的言論?通常,這些人都是已經(jīng)在使用驅(qū)動測試開發(fā)(TDD)或行為驅(qū)動開發(fā)(BDD),而且,他們所在的公司在誕生第一天起就有著很強的測試文化。然而,如何能測量不寫測試程序造成的影響?如何能驗證實踐TDD能真正的減少bug的存在?我們能否在一段時間里停止寫測試程序,看看這對軟件缺陷數(shù)有多大的影響?這方法看起來不太現(xiàn)實。

這篇文章里,我將通過分析當前我工作中的真實數(shù)據(jù)來回答這個問題。以前我們的系統(tǒng)沒有測試代碼,可一旦開始進行測試驅(qū)動開發(fā),我就成為了這種開發(fā)方法的強力倡導者。

測試驅(qū)動開發(fā)前的背景情況

我做Web開發(fā)已經(jīng)有10年了,從2009年起就開始耳聞驅(qū)動測試開發(fā)(TDD)。從那時開始我就打算要多學學這方面的知識。我在當時的公司里已經(jīng)干了兩年,現(xiàn)在已經(jīng)是2012年,在這個公司總共工作了5年,從后3年開始實施測試驅(qū)動開發(fā)方法。

這個過程非常有趣,因為如今我可以瀏覽我們的bug跟蹤系統(tǒng),匯總這段時間的缺陷統(tǒng)計數(shù)據(jù),看看TDD對我們的程序代碼質(zhì)量有多大的影響。

簡單的說一下我們的軟件技術(shù)構(gòu)成:我開發(fā)基于PHP和Javascript的系統(tǒng)UI部分。我是UI部分的主要開發(fā)人員,這就是說,如果UI上有bug,我基本上要對此負責。UI跟后臺的C++服務(wù)交互,這服務(wù)運行在Oracle數(shù)據(jù)庫上,通過PLSQL代碼處理數(shù)據(jù)。

UI部分的PHP代碼是唯一實施了測試驅(qū)動開發(fā)的地方。我們的Javascript代碼沒有測試程序。遺憾的是,公司里的程序員都沒有測試驅(qū)動開發(fā)的實踐經(jīng)驗。系統(tǒng)其它層面的代碼都沒有實施單元測試或功能性測試(公司有專門的QA團隊在開發(fā)完成之后進行測試)。

這使得我們的統(tǒng)計分析數(shù)據(jù)看起來非常的明顯。我可以看到,隨著時間的推移,我們的整個產(chǎn)品和UI模塊的缺陷數(shù)字的變化。這使得我有辦法來回答最初的問題,這個問題在此可以用這樣的問題復述:使用測試驅(qū)動開發(fā)能使我負責的UI模塊的缺陷數(shù)下降嗎?

測試驅(qū)動開發(fā)真的有效嗎?

下面這個圖表是由我們的bug跟蹤系統(tǒng)生成的。它向我們展示了UI部分的bug和整個產(chǎn)品的bug的對比比率。

我們可以從中看出一些有趣的事情:

  • 首先,我可以回答這個問題:在UI中發(fā)現(xiàn)的bug的數(shù)量(下面綠顏色的)減少了50%(起初UI部分相關(guān)的bug數(shù)量占整個產(chǎn)品的35%,如今它已經(jīng)降到了15%)。
  • 在歷史遺留的程序庫上實施測試驅(qū)動開發(fā)并不會很快的顯現(xiàn)出效果。我于2009年第三季度開始TDD。你可以看到,到了2010年第三季度時bug數(shù)才開始下降,而到了2011年第三季度開始大幅度下降。將近用來2年的時間實現(xiàn)了50%的降低。
  • 圖表上顯示,在2010年第二季度和2011年第二季度時,數(shù)據(jù)上下跳動??匆幌挛覀儺a(chǎn)品的發(fā)布歷程,這應該歸結(jié)于這段時間系統(tǒng)里增加了嚴重依賴于Javascript的第三方地圖API功能。我之前也說過,我們并沒有寫Javascript上的測試代碼。這也證實了不寫測試代碼會導致更多的 bug。

下一步的計劃?

之前我說過,我只是在PHP代碼上實施了測試驅(qū)動開發(fā)。觀察如今產(chǎn)生的bug,我注意到它們通??梢詺w為這樣兩類:

  • Javascript代碼中的bug(這些是沒有自動化測試程序的)
  • 系統(tǒng)集成時產(chǎn)生的bug(例如,獨立的PHP組件通過了單元測試,但組合起來運行時卻出了問題)

這很自然的將我引入了下一步的測試探險:我要在Javascript代碼里加入測試套件代碼,并最終加入集成測試套件代碼。

今年整個夏天我都在做這項工作。對于Javascript代碼,開發(fā)了基于Jasmine BDD框架的測試套件。對于端對端的測試,我使用Cucumber。在這兩種情況中,我使用Selenium Web Driver在真實的瀏覽器中運行測試代碼,或胡亂的使用強大的Phantom.js。

我們即將開始下一個開發(fā)周期,我期望通過這些新的措施,我們能開發(fā)出更有質(zhì)量的軟件。我希望明年還能寫出這樣的一篇文章來分析這些測試開發(fā)工具的效果。很有可能它們會進一步的降低我們的bug數(shù)量。

還有,把這些數(shù)據(jù)分享給我的同事,這讓一些開發(fā)人員也開始相信測試驅(qū)動開發(fā)的好處。我們產(chǎn)品中另外一些服務(wù)上的開發(fā)人員對TDD表現(xiàn)出了興趣,準備研究如何在他們的程序庫上實施測試驅(qū)動開發(fā)。觀察他們的在實踐中能獲得什么樣的成果將會是一件有趣的事情。

結(jié)束語

你呢?測試驅(qū)動開發(fā)(TDD)和行為驅(qū)動開發(fā)(BDD)是如何影響你們的代碼質(zhì)量的?你是否也有類似的統(tǒng)計數(shù)據(jù)可以分享?請在下面的評論里寫出來。

原文鏈接:http://www.aqee.net/test-driven-development-actually-works/

責任編輯:林師授 來源: 外刊IT評論
相關(guān)推薦

2023-02-23 19:28:09

ODD測試

2014-04-09 11:13:37

測試驅(qū)動開發(fā)

2013-08-07 14:30:33

微信5.0

2013-02-21 09:38:48

測試軟件測試測試驅(qū)動

2009-12-15 09:36:32

Visual Stud

2013-03-01 10:15:43

敏捷開發(fā)敏捷

2022-05-26 05:58:23

數(shù)據(jù)驅(qū)動業(yè)務(wù)數(shù)據(jù)分析

2009-10-10 10:55:48

TDD技術(shù)

2021-01-27 11:32:12

接口測試代碼

2023-10-07 08:49:56

測試驅(qū)動開發(fā)Xunit 框架

2018-07-09 14:21:29

Python電影數(shù)據(jù)

2021-04-16 14:24:35

網(wǎng)絡(luò)安全遠程辦公IT

2023-05-13 17:38:03

ZOMBIES軟件開發(fā)

2020-05-15 09:20:35

瀏覽器 Chrome Google

2023-09-11 11:05:49

軟件開發(fā)TDD

2022-05-26 10:12:21

前端優(yōu)化測試

2012-05-02 10:03:56

2022-07-21 18:51:13

性能優(yōu)化

2019-01-23 11:17:22

電腦程序員工作

2020-03-26 15:10:34

蘋果iPhone手機
點贊
收藏

51CTO技術(shù)棧公眾號