單元測(cè)試

單元測(cè)試是什么

單元測(cè)試是一種軟件測(cè)試抑进,其測(cè)試軟件的各個(gè)單元或組件茬末。目的是驗(yàn)證軟件代碼每個(gè)單元是否按照預(yù)期執(zhí)行候址。單元測(cè)試由開(kāi)發(fā)人員在應(yīng)用程序的開(kāi)發(fā)(編碼階段)中完成变姨。單元測(cè)試隔離一段代碼并驗(yàn)證其正確性族扰。一個(gè)單元可能是單個(gè)功能,方法定欧,過(guò)程渔呵,模塊或?qū)ο?/strong>。

為什么做單元測(cè)試

  • 在開(kāi)發(fā)階段砍鸠,單元測(cè)試可以幫助更早發(fā)現(xiàn)并修復(fù)BUG扩氢,并節(jié)省成本

  • 它有助于開(kāi)發(fā)人員了解代碼庫(kù),并使他們能夠快速做出修改

  • 好的單元測(cè)試相當(dāng)于項(xiàng)目文檔

  • 單元測(cè)試有助于代碼重用爷辱,將我們的代碼和測(cè)試都遷移到新項(xiàng)目录豺。調(diào)整代碼,直到測(cè)試再次運(yùn)行饭弓。

單元測(cè)試的好處

  • 通過(guò)單元測(cè)試双饥,開(kāi)發(fā)者可以了解到提供了什么功能,對(duì)單元測(cè)試API有基本了解
  • 單元測(cè)試允許程序員在以后重構(gòu)代碼弟断,并確保模塊仍然正常工作(即回歸測(cè)試)咏花。該過(guò)程是針對(duì)所有功能和方法編寫(xiě)測(cè)試用例,以便每當(dāng)更改導(dǎo)致故障時(shí)阀趴,都可以快速識(shí)別并修復(fù)該故障昏翰。
  • 由于單元測(cè)試的模塊化性質(zhì),我們可以測(cè)試項(xiàng)目的各個(gè)部分舍咖,而無(wú)需等待其他部分完成矩父。

單元測(cè)試的壞處

  • 單元測(cè)試不能夠捕獲程序中每個(gè)錯(cuò)誤锉桑。即使在最簡(jiǎn)單的程序中排霉,也不可能評(píng)估每種單元測(cè)試執(zhí)行的路徑。
  • 單元測(cè)試的本質(zhì)是將重點(diǎn)放在代碼的單元上民轴。因此攻柠,它不能捕獲集成測(cè)試的錯(cuò)誤和更廣泛的系統(tǒng)層面的錯(cuò)誤。

推薦:?jiǎn)卧獪y(cè)試和其他測(cè)試手段一起使用

VUE項(xiàng)目中使用單元測(cè)試

我們使用Vue-Test-Utils這個(gè)Vue.js官方的單元測(cè)試實(shí)用工具庫(kù)后裸,來(lái)編寫(xiě)VUE應(yīng)用中的單元測(cè)試瑰钮。

安裝

這里,我們默認(rèn)已經(jīng)通過(guò)VUE的腳手架生成了項(xiàng)目微驶,那么我們集成unit-jest插件就可以了浪谴。

vue add @vue/unit-jest

編寫(xiě)簡(jiǎn)單測(cè)試用例

單元測(cè)試的文件:

// tests/unit/example.spec.js
import { shallowMount } from '@vue/test-utils'
import HelloWorld from '@/components/HelloWorld.vue'

describe('HelloWorld.vue', () => {
  it('renders props.msg when passed', () => {
    const msg = 'new message'
    const wrapper = shallowMount(HelloWorld, {
      propsData: { msg }
    })
    expect(wrapper.text()).toMatch(msg)
  })
})

單元測(cè)試的組件:

<!--scr/components/HellowWorld.vue-->
<template>
  <div class="hello-world">msg is :{{msg}}</div>
</template>

<script>
export default {
  name: 'hello-world',
  data() {
    return {}
  },
  props: {
    msg: {
      type: String,
      default: 'this is props msg'
    }
  }
}
</script>

此時(shí)开睡,執(zhí)行下面的命令行即可:

yarn run test:unit
或者
npm run test:unit

這個(gè)時(shí)候,你就可以在控制臺(tái)上看到測(cè)試用例正在跑~

參考資料

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末苟耻,一起剝皮案震驚了整個(gè)濱河市篇恒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌凶杖,老刑警劉巖胁艰,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異智蝠,居然都是意外死亡腾么,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén)杈湾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)解虱,“玉大人,你說(shuō)我怎么就攤上這事漆撞》顾拢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵叫挟,是天一觀的道長(zhǎng)艰匙。 經(jīng)常有香客問(wèn)我,道長(zhǎng)抹恳,這世上最難降的妖魔是什么员凝? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮奋献,結(jié)果婚禮上健霹,老公的妹妹穿的比我還像新娘。我一直安慰自己瓶蚂,他們只是感情好糖埋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著窃这,像睡著了一般瞳别。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上杭攻,一...
    開(kāi)封第一講書(shū)人閱讀 51,301評(píng)論 1 301
  • 那天祟敛,我揣著相機(jī)與錄音,去河邊找鬼兆解。 笑死馆铁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的锅睛。 我是一名探鬼主播埠巨,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼历谍,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了辣垒?” 一聲冷哼從身側(cè)響起扮饶,我...
    開(kāi)封第一講書(shū)人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎乍构,沒(méi)想到半個(gè)月后甜无,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡哥遮,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年岂丘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片眠饮。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡奥帘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出仪召,到底是詐尸還是另有隱情寨蹋,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布扔茅,位于F島的核電站已旧,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏召娜。R本人自食惡果不足惜运褪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望玖瘸。 院中可真熱鬧秸讹,春花似錦、人聲如沸雅倒。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蔑匣。三九已至劣欢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間殖演,已是汗流浹背氧秘。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工年鸳, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留趴久,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓搔确,卻偏偏與公主長(zhǎng)得像彼棍,于是被迫代替她去往敵國(guó)和親灭忠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容