譯者按: 也許你討厭測(cè)試拖刃,但是你不得不面對(duì)它,所以至少區(qū)分一下單元測(cè)試贪绘、集成測(cè)試與功能測(cè)試兑牡?對(duì)吧...
原文: What are Unit Testing, Integration Testing and Functional Testing?
譯者: Fundebug
為了保證可讀性,本文采用意譯而非直譯税灌。另外均函,本文版權(quán)歸原作者所有,翻譯僅用于學(xué)習(xí)菱涤。
JavaScript代碼測(cè)試有很多分類(lèi)苞也,比如單元測(cè)試(unit test)、集成測(cè)試(integration test)粘秆、功能測(cè)試(functional test)如迟、端到端測(cè)試(end to end test)、回歸測(cè)試(regression test)攻走、瀏覽器測(cè)試(browser test)...
也許你會(huì)傻傻地分不清楚殷勘,它們是什么?如何使用昔搂?什么情況下使用玲销?這篇博客將解答你的疑問(wèn)。
單元測(cè)試
單元測(cè)試指的是測(cè)試小的代碼塊巩趁,通常指的是獨(dú)立測(cè)試單個(gè)函數(shù)痒玩。如果某個(gè)測(cè)試依賴(lài)于一些外部資源淳附,比如網(wǎng)絡(luò)或者數(shù)據(jù)庫(kù)议慰,那它就不是單元測(cè)試。
單元測(cè)試一般很容易寫(xiě)奴曙。一個(gè)單元測(cè)試通常是這樣的:為某個(gè)函數(shù)提供某些輸入值别凹,然后驗(yàn)證函數(shù)的返回值是否正確。然而洽糟,如果你的代碼設(shè)計(jì)非常糟糕炉菲,則單元測(cè)試會(huì)很難寫(xiě)堕战。從另一個(gè)角度理解,單元測(cè)試可以幫助我們寫(xiě)更好的代碼拍霜。
從某種意義上嘱丢,單元測(cè)試就是代碼的骨干。通過(guò)單元測(cè)試祠饺,可以幫助你優(yōu)化代碼設(shè)計(jì)越驻,可以保證修改代碼時(shí)正確無(wú)誤。
單元測(cè)試可以幫助我們避免一些常見(jiàn)的BUG道偷。通常缀旁,程序員會(huì)在同一個(gè)細(xì)節(jié)上反復(fù)犯錯(cuò),如果為這些BUG添加單元測(cè)試勺鸦,則可以有效避免這種情況并巍。當(dāng)然,你也可以使用集成測(cè)試和功能測(cè)試來(lái)解決這個(gè)問(wèn)題换途,但是單元測(cè)試更加適合懊渡,因?yàn)閱卧獪y(cè)試更加細(xì)致,可以幫助我們快速定位和解決問(wèn)題军拟。
什么時(shí)候應(yīng)該做單元測(cè)試呢距贷?采用測(cè)試驅(qū)動(dòng)開(kāi)發(fā)(test driven development)的話(huà),你應(yīng)該一直寫(xiě)單元測(cè)試吻谋。好的單元測(cè)試不僅可以避免BUG忠蝗,還可以優(yōu)化代碼,并且保證修改或者重構(gòu)代碼時(shí)不會(huì)出錯(cuò)漓拾。
流行的JavaScript單元測(cè)試工具有Mocha, Jasmine和Tape阁最。
集成測(cè)試
集成測(cè)試就是測(cè)試應(yīng)用中不同模塊如何集成,如何一起工作骇两,這和它的名字一致速种。集成測(cè)試與單元測(cè)試相似,但是它們也有很大的不同:?jiǎn)卧獪y(cè)試是測(cè)試每個(gè)獨(dú)立的模塊低千,而集成測(cè)試恰好相反配阵。比如,當(dāng)測(cè)試需要訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的代碼時(shí)示血,單元測(cè)試不會(huì)真的去訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)棋傍,而集成測(cè)試則會(huì)。
單元測(cè)試不夠時(shí)难审,這時(shí)就需要集成測(cè)試了瘫拣。當(dāng)你需要去驗(yàn)證兩個(gè)獨(dú)立的模塊,比如數(shù)據(jù)庫(kù)和應(yīng)用告喊,保證它們能夠正確的一起工作麸拄,這時(shí)就需要集成測(cè)試了派昧。為了驗(yàn)證測(cè)試結(jié)果,你就需要通過(guò)查詢(xún)數(shù)據(jù)庫(kù)驗(yàn)證數(shù)據(jù)正確性拢切。
集成測(cè)試通常比單元測(cè)試慢蒂萎,因?yàn)樗訌?fù)雜。并且淮椰,集成測(cè)試還需要配置測(cè)試環(huán)境岖是,比如配置測(cè)試數(shù)據(jù)庫(kù)或者其他依賴(lài)的組件。這就使得編寫(xiě)和維護(hù)集成測(cè)試更加困難实苞,因此豺撑,你應(yīng)該專(zhuān)注于單元測(cè)試,除非你真的需要集成測(cè)試黔牵。
你需要的集成測(cè)試應(yīng)該少于單元測(cè)試聪轿。除非你需要測(cè)試多個(gè)模塊,或者你的代碼太復(fù)雜時(shí)猾浦,你才需要集成測(cè)試陆错。并且,當(dāng)你的代碼過(guò)于復(fù)雜時(shí)金赦,我建議優(yōu)化代碼以便進(jìn)行單元測(cè)試音瓷,而不是直接寫(xiě)集成測(cè)試。
通常夹抗,我們可以使用單元測(cè)試工具編寫(xiě)集成測(cè)試绳慎。
功能測(cè)試
功能測(cè)試有時(shí)候也被稱(chēng)作端到端測(cè)試,或者瀏覽器測(cè)試漠烧,它們指的是同一件事杏愤。
功能測(cè)試指的是測(cè)試應(yīng)用的某個(gè)完整的功能。對(duì)于網(wǎng)頁(yè)應(yīng)用已脓,功能測(cè)試意味著使用工具模擬瀏覽器珊楼,然后通過(guò)點(diǎn)擊頁(yè)面來(lái)測(cè)試應(yīng)用。
單元測(cè)試可以測(cè)試單個(gè)函數(shù)度液,集成測(cè)試可以測(cè)試兩個(gè)模塊一起工作厕宗。功能測(cè)試則完全是另外一個(gè)層次。你可以有上百個(gè)單元測(cè)試堕担,但是通常你只有少量的功能測(cè)試已慢。這是因?yàn)楣δ軠y(cè)試太復(fù)雜了,難于編寫(xiě)和維護(hù)照宝。功能測(cè)試很慢蛇受,因?yàn)樗枰M真實(shí)用戶(hù)進(jìn)行網(wǎng)頁(yè)交互句葵。
事實(shí)上厕鹃,你不需要編寫(xiě)非常詳細(xì)的功能測(cè)試兢仰。功能測(cè)試并不意味著你需要測(cè)試每一個(gè)功能,其實(shí)剂碴,你只需要測(cè)試一些常見(jiàn)的用戶(hù)行為把将。如果你需要在瀏覽器中手動(dòng)測(cè)試應(yīng)用的某個(gè)流程,比如注冊(cè)賬號(hào)忆矛,這時(shí)你可以編寫(xiě)一個(gè)功能測(cè)試察蹲。
對(duì)于單元測(cè)試,你會(huì)使用代碼去驗(yàn)證結(jié)果催训,在功能測(cè)試中也應(yīng)該這樣做洽议。以注冊(cè)賬號(hào)為例,你可以驗(yàn)證瀏覽器是否跳轉(zhuǎn)到了"感謝注冊(cè)"頁(yè)面漫拭。
當(dāng)有些測(cè)試你需要手動(dòng)在瀏覽器下重復(fù)進(jìn)行時(shí)亚兄,你應(yīng)該編寫(xiě)功能測(cè)試。注意不要寫(xiě)得太細(xì)致了采驻,否則維護(hù)這些測(cè)試將是一個(gè)噩夢(mèng)审胚。
最流行的功能測(cè)試工具是 Selenium。Selenium WebDriver或者Protractor通常與Selenium一起使用礼旅,有時(shí)也使用PhantomJS和CasperJS 膳叨,注意你不需要使用真實(shí)瀏覽器。
總結(jié)
測(cè)試JavaScript代碼時(shí)痘系,應(yīng)該著重于單元測(cè)試菲嘴,它非常容易編寫(xiě)和維護(hù),除了可以減少BUG還有很多益處汰翠。而集成測(cè)試與功能測(cè)試應(yīng)該作為補(bǔ)充临谱。
關(guān)于Fundebug
Fundebug專(zhuān)注于JavaScript、微信小程序奴璃、微信小游戲悉默、支付寶小程序、React Native苟穆、Node.js和Java實(shí)時(shí)BUG監(jiān)控抄课。 自從2016年雙十一正式上線(xiàn),F(xiàn)undebug累計(jì)處理了7億+錯(cuò)誤事件雳旅,得到了Google跟磨、360、金山軟件攒盈、百姓網(wǎng)等眾多知名用戶(hù)的認(rèn)可抵拘。歡迎免費(fèi)試用!
版權(quán)聲明:
轉(zhuǎn)載時(shí)請(qǐng)注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2017/06/26/javascript-test-type/