vitest單元測試簡單分享(一)

先上源碼:demo

文件路徑:在項(xiàng)目根目錄/vue3/my-vue-app文件夾下

一嫌变、項(xiàng)目搭建
安裝vite和vue厅贪,使用 npm 或者 yarn、pnmp都行,終端命令如下:

# npm 6.x
npm create vite@latest my-vue-app --template vue

# npm 7+, extra double-dash is needed:
npm create vite@latest my-vue-app -- --template vue

# yarn
yarn create vite my-vue-app --template vue

# pnpm
pnpm create vite my-vue-app --template vue

二雪隧、Vitest、jsdom、 coverage安裝
使用 npm 或者 yarn、pnmp都行竞端,終端命令如下:

# npm
npm install -D vitest jsdom @vitest/coverage-c8

# yarn
yarn add -D vitest jsdom @vitest/coverage-c8

# pnpm
pnpm add -D vitest jsdom @vitest/coverage-c8

提示:Vitest 需要 Vite >=v3.0.0 和 Node >=v14

三、 修改項(xiàng)目根目錄下的vite.config.js的配置文件庙睡,增加:

test: { include: ["tests/*/.test.ts"], environment: "jsdom"}

完整內(nèi)容如下:

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  // 單元測試配置
  test: {
    include: ["tests/**/*.test.ts"],
    environment: "jsdom"
  }
})

四事富、修改package.json配置文件,增加:

"scripts": {"test": "vitest", "coverage": "vitest run --coverage"}

完整內(nèi)容如下:

{
  "name": "my-vue-app",
  "private": true,
  "version": "0.0.0",
  "type": "module",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview",
    "test": "vitest",
    "coverage": "vitest run --coverage"
  },
  "dependencies": {
    "vue": "^3.2.45"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^4.0.0",
    "@vitest/coverage-c8": "^0.29.1",
    "@vue/test-utils": "^2.3.0",
    "jsdom": "^21.1.0",
    "vite": "^4.1.0",
    "vitest": "^0.29.1"
  }
}

五埃撵、在項(xiàng)目根目錄下新建一個tests文件夾赵颅,然后在tests文件夾下新建一個單元測試文件demo.test.ts,完整內(nèi)容如下:

import { describe, expect, it } from 'vitest'
import { mount } from '@vue/test-utils'
// 需要測試的組件頁面
import Test from '@/pages/demo/test.vue'

const author1 = {
  name: 'pany',
  email: '939630029@qq.com',
  url: 'https://github.com/pany-ang',
}

const author2 = {
  name: 'pany',
  email: '939630029@qq.com',
  url: 'https://github.com/pany-ang',
}

describe('Test', () => {
  it('測試基礎(chǔ)數(shù)據(jù)類型', () => {
    expect(1 + 1).toBe(2)
  })
  it('測試引用類型', () => {
    expect(author1).toEqual(author2)
  })
  it('組件正常渲染', () => {
    const wrapper: any = mount(Test)
    expect(wrapper.contains('div')).toBe(true)
  })
})

參考資料:

  1. vue官網(wǎng)
  2. vite中文網(wǎng)
  3. vitest中文網(wǎng)
  4. Vue Test Utils
  5. 年輕人的第一款單元測試框架
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末暂刘,一起剝皮案震驚了整個濱河市饺谬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌谣拣,老刑警劉巖募寨,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異森缠,居然都是意外死亡拔鹰,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進(jìn)店門贵涵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來列肢,“玉大人,你說我怎么就攤上這事宾茂〈陕恚” “怎么了?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵跨晴,是天一觀的道長欧聘。 經(jīng)常有香客問我,道長端盆,這世上最難降的妖魔是什么怀骤? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮焕妙,結(jié)果婚禮上蒋伦,老公的妹妹穿的比我還像新娘。我一直安慰自己焚鹊,他們只是感情好凉敲,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般爷抓。 火紅的嫁衣襯著肌膚如雪势决。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天蓝撇,我揣著相機(jī)與錄音果复,去河邊找鬼。 笑死渤昌,一個胖子當(dāng)著我的面吹牛虽抄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播独柑,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼迈窟,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了忌栅?” 一聲冷哼從身側(cè)響起车酣,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎索绪,沒想到半個月后湖员,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瑞驱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年娘摔,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片唤反。...
    茶點(diǎn)故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡凳寺,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出彤侍,到底是詐尸還是另有隱情读第,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布拥刻,位于F島的核電站,受9級特大地震影響父泳,放射性物質(zhì)發(fā)生泄漏般哼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一惠窄、第九天 我趴在偏房一處隱蔽的房頂上張望蒸眠。 院中可真熱鬧,春花似錦杆融、人聲如沸楞卡。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蒋腮。三九已至淘捡,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間池摧,已是汗流浹背焦除。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留作彤,地道東北人膘魄。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像竭讳,于是被迫代替她去往敵國和親创葡。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評論 2 348

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

  • 由于現(xiàn)在前端涉及的東西越來越多绢慢,也越來越復(fù)雜灿渴,就對我們前端工程化能力提出了更高的要求。好的前端工程化一般包括三個大...
    風(fēng)刃社區(qū)閱讀 3,909評論 2 2
  • vue3中單元測試主要是通過腳手架@vue/cli-plugin-unit-jest[https://github...
    慕斯面包閱讀 495評論 0 0
  • # mocha 單元測試 ## 前言 **單元測試** 是用來對 **一個模塊**呐芥、 **一個函數(shù)** 或 **一...
    buffonme閱讀 1,511評論 0 0
  • 前言:公司團(tuán)隊(duì)希望前端做單元測試逻杖,說起來干前端這么長時間以來還從來沒寫過單元測試,網(wǎng)上找了些資料思瘟,what荸百?這都是...
    w晚風(fēng)閱讀 6,865評論 0 5
  • 在團(tuán)隊(duì)合作中,你寫好了一個函數(shù)滨攻,供隊(duì)友使用够话,跑去跟你的隊(duì)友說,你傳個A值進(jìn)去光绕,他就會返回B結(jié)果了女嘲。過了一會,你隊(duì)友...
    JC_Huang閱讀 5,291評論 1 29