亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue-Jest 自動化測試基礎(chǔ)配置詳解

 更新時間:2021年07月19日 10:28:14   作者:Hughes  
目前開發(fā)大型應(yīng)用,測試是一個非常重要的環(huán)節(jié),而在 Vue 項(xiàng)目中做單元測試可以用 Jest,本文主要介紹了Vue-Jest 自動化測試,感興趣的可以了解一下

目前開發(fā)大型應(yīng)用,測試是一個非常重要的環(huán)節(jié),而在 Vue 項(xiàng)目中做單元測試可以用 Jest,Jest 是 facebook 推出的一款測試框架,集成了 Mocha, chai, jsdom, sinon 等功能,而且在 Vue 的腳手架中已經(jīng)集成了 Jest,所以在 Vue 項(xiàng)目中使用 Jest 做單元測試是不二的選擇,從提供的例子上看都很簡單地配置并測試成功,然而在實(shí)際項(xiàng)目中有很多差異,我在測試自己的某個業(yè)務(wù)組件就報(bào)出很多錯誤,本文就總結(jié)一下自己的踩坑經(jīng)歷,并幫助讀者快速解決配置中出現(xiàn)的問題。

安裝

可以通過官方提供的 @vue/cli 直接創(chuàng)建 Vue 項(xiàng)目,然后選中 Unit Testing 這個選項(xiàng)

? Check the features needed for your project:
 ◉ Choose Vue version
 ◉ Babel
❯◉ TypeScript
 ◯ Progressive Web App (PWA) Support
 ◉ Router
 ◉ Vuex
 ◯ CSS Pre-processors
 ◯ Linter / Formatter
 ◉ Unit Testing
 ◯ E2E Testing

然后在測試框架中選擇 Jest

? Pick a unit testing solution: Jest
? Where do you prefer placing config for Babel, ESLint, etc.? In dedicated con
fig files

Vue + Ts 的項(xiàng)目最終生成的 jest.config.js 配置文件長這樣,好像在告訴我們,我都給你們設(shè)置好了,直接用吧,然而針對項(xiàng)目,還需要手動去配置兼容,要不然會報(bào)出很多錯誤,無法進(jìn)行下去。

module.exports = {
  preset: '@vue/cli-plugin-unit-jest/presets/typescript-and-babel'
}

配置

先看看這個預(yù)設(shè)配置到底寫了什么,找到 @vue/cli-plugin-unit-jest/presets/typescript-and-babel 這個包,實(shí)際上這個輸出的配置如下:

module.exports = {
  moduleFileExtensions: [ // 測試的文件類型
    'js',
    'jsx',
    'json',
    // tell Jest to handle *.vue files
    'vue',
    'ts',
    'tsx'
  ],
  transform: { // 轉(zhuǎn)化方式
    // process *.vue files with vue-jest
    '^.+\\.vue$': require.resolve('vue-jest'),
    '.+\\.(css|styl|less|sass|scss|svg|png|jpg|ttf|woff|woff2)$':
    require.resolve('jest-transform-stub'),
    '^.+\\.jsx?$': require.resolve('babel-jest'),
    '^.+\\.tsx?$': require.resolve('ts-jest'),
  },
  transformIgnorePatterns: ['/node_modules/'],  // 轉(zhuǎn)化時忽略 node_modules
  // support the same @ -> src alias mapping in source code
  moduleNameMapper: { // @符號 表示當(dāng)前項(xiàng)目下的src
    '^@/(.*)$': '<rootDir>/src/$1'
  },
  testEnvironment: 'jest-environment-jsdom-fifteen',
  // serializer for snapshots
  snapshotSerializers: [ // 快照的配置
    'jest-serializer-vue'
  ],
  testMatch: [ // 默認(rèn)測試文件
    '**/tests/unit/**/*.spec.[jt]s?(x)',
    '**/__tests__/*.[jt]s?(x)'
  ],
  // https://github.com/facebook/jest/issues/6766
  testURL: 'http://localhost/',
  watchPlugins: [
    require.resolve('jest-watch-typeahead/filename'),
    require.resolve('jest-watch-typeahead/testname')
  ],
  globals: {
    'ts-jest': {
      babelConfig: true
    }
  }
}

其中比較重要的配置,也是我們比較多用來解決問題的配置:

  • moduleFileExtensions : 測試的文件類型,這里默認(rèn)的配置基本涵蓋了文件類型,所以這里一般不需要改
  • transform : 轉(zhuǎn)化方式,匹配的文件要經(jīng)過轉(zhuǎn)譯才能被識別,否則會報(bào)錯。
  • transformIgnorePatterns : 轉(zhuǎn)化忽略配置
  • moduleNameMapper : 模塊別名,如果有用到都要填寫進(jìn)去

常見錯誤

SyntaxError : 語法錯誤,很可能是因?yàn)闆]有進(jìn)行轉(zhuǎn)化,比如下面的提示:

 /Users/zhuangbing.cai/Documents/workspace/projects/wms-ui/node_modules/vue-runtime-helpers/dist/normalize-component.mjs:76
    export default normalizeComponent;
    ^^^^^^

    SyntaxError: Unexpected token 'export'

由于我們沒有對 .mjs 文件進(jìn)行轉(zhuǎn)換導(dǎo)致了報(bào)錯,最快的解決方式就是在 transform 補(bǔ)充 .mjs 的轉(zhuǎn)化

transform: {
     '^.+\\.mjs$': 'babel-jest'
}

只需要在對 .mjs 的文件,提供轉(zhuǎn)化方式即可。

另一種語法錯誤,是node_module 內(nèi)的某些文件需要轉(zhuǎn)化,然而被 transformIgnorePatterns 配置忽略了。

    Here's what you can do:
     • To have some of your "node_modules" files transformed, you can specify a custom "transformIgnorePatterns" in your config.
     • If you need a custom transformation specify a "transform" option in your config.
     • If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the "moduleNameMapper" config option.

    You'll find more details and examples of these config options in the docs:
    https://jestjs.io/docs/en/configuration.html

    Details:

    /Users/zhuangbing.cai/Documents/workspace/projects/wms-ui/node_modules/vue-runtime-helpers/dist/normalize-component.mjs:76
    export default normalizeComponent;
    ^^^^^^

    SyntaxError: Unexpected token 'export'

圖中 vue-runtime-helpers 被用到了,然而因?yàn)?transformIgnorePatterns  的配置忽略了轉(zhuǎn)化,從而導(dǎo)致語法錯誤。解決方法就是改變 transformIgnorePatterns  的配置,如下:

transformIgnorePatterns: [
    // 轉(zhuǎn)化時忽略 node_modules,但不包括 vue-runtime-helpers
    '/node_modules/(?!(vue-runtime-helpers)/)',
  ],

將 vue-runtime-helpers 排除后,轉(zhuǎn)化的時候就不會忽略它,從而解決語法報(bào)錯的問題。

Ts 類型錯誤

 TypeScript diagnostics (customize using `[jest-config].globals.ts-jest.diagnostics` option):
    src/views/inventory-map/__tests__/available.spec.ts:15:1 - error TS2304: Cannot find name 'beforeEach'.

    15 beforeEach(() => {
       ~~~~~~~~~~
    src/views/inventory-map/__tests__/available.spec.ts:19:1 - error TS2593: Cannot find name 'describe'. Do you need to install type definitions for a test runner? Try `npm i @types/jest` or `npm i @types/mocha` and then add `jest` or `mocha` to the types field in your tsconfig.

    19 describe('available-inventory-map', () => {
       ~~~~~~~~
    src/views/inventory-map/__tests__/available.spec.ts:20:3 - error TS2593: Cannot find name 'it'. Do you need to install type definitions for a test runner? Try `npm i @types/jest` or `npm i @types/mocha` and then add `jest` or `mocha` to the types field in your tsconfig.

根據(jù)提示需要在 tscofig.json 中添加

{
    "compilerOptions": {
    "types": [
      "webpack-env",
      "jest"
    ],
  }
}

測試前的工作

在編寫測試用例前,我們需要 Jest 提供組件實(shí)例 vm 和渲染的 DOM 結(jié)構(gòu)。對代碼邏輯、頁面效果的雙重測試保障,那么如何獲取到這個業(yè)務(wù)組件?

直接引用組件是不行的,因?yàn)槟愕臉I(yè)務(wù)組件需要的依賴很多,比如 UI 組件庫、工具函數(shù)、Vuex 的狀態(tài)等,所以首先我們需要處理好這些依賴。

處理依賴

首先要知道要測試的這個業(yè)務(wù)組件依賴了哪些東西,全局的依賴可以參照 main.ts 或 main.js 入口文件處,其他可根據(jù)組件中的引用來判斷。有了依賴后如何在 Jest 中獲得組件實(shí)例?

Vue 提供了一個單元測試實(shí)用工具庫 - Vue Test Utils,編寫測試用例的時候可以用到它,首先利用 createLocalVue 創(chuàng)建一個 Vue 的類供你添加組件、混入和安裝插件而不會污染全局的 Vue 類, 接著將依賴引用進(jìn)去。

const _localVue = createLocalVue();
_localVue.use(Vuex);
_localVue.use(UI);
_localVue.use(i18nInstall);
_localVue.component('s-filter', SFilter);
_localVue.component('w-table', WTable);
_localVue.directive('xxx', {
  inserted: (el, binding) => {
    ....
  },
});
export const localVue = _localVue;

這樣就拿到了一個包含依賴的 Vue 類,接著處理 Vuex,比如我們需要枚舉值

import enums from './enums';
export const systemStore = new Vuex.Store({
  actions: {},
  state: {
    enums: {
      systemEnums: enums,
    },
  },
});

生成實(shí)例和 DOM

在得到 localVue 和 store 之后,我們要用它去生成結(jié)果,通過 mount 將組件渲染出來。

import { localVue, systemStore } from '@/utils/unit-test/common';
import { mount } from '@vue/test-utils';
require('intersection-observer'); // 兼容jsdom不支持IntersectionObserver
import TaskList from '../available-inventory-map/index.vue'; // 引用要測試的業(yè)務(wù)
let store: any;
beforeEach(() => {
  store = systemStore;
});

describe('available-inventory-map', () => {
  it('篩選項(xiàng)測試', () => {
    const renderer = createRenderer();
    const wrapper = mount(TaskList, {
      localVue,
      store,
      attachToDocument: true,
    });
    const html = wrapper.html(); // 得到完整的 html 結(jié)構(gòu)
    const vm = wrapper.vm; // 組件實(shí)例
    console.log(html, vm);
  })
}

將 localVue 和 store,通過 mount 最終得到實(shí)例和它的 DOM 結(jié)構(gòu)。接下來就可以根據(jù)實(shí)例和 DOM 去編寫自己的測試用例啦。

總結(jié)

本文主要介紹了在 Vue + Ts 項(xiàng)目中配置 Jest 自動化測試中遇到的問題總結(jié),介紹基本配置和常見錯誤的解決方法,以及如何在開始編寫測試用例前得到完整的組件信息和 DOM。為接下來的用例編寫打下基礎(chǔ)。

引用

Vue Test Utils

到此這篇關(guān)于Vue-Jest 自動化測試基礎(chǔ)配置詳解的文章就介紹到這了,更多相關(guān)Vue-Jest 自動化測試內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue路由傳參刷新后數(shù)據(jù)丟失問題及解決

    vue路由傳參刷新后數(shù)據(jù)丟失問題及解決

    這篇文章主要介紹了vue路由傳參刷新后數(shù)據(jù)丟失問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3 setup中defineEmits與defineProps的使用案例詳解

    vue3 setup中defineEmits與defineProps的使用案例詳解

    在父組件中定義String、Number、Boolean、Array、Object、Date、Function、Symbol這些類型的數(shù)據(jù),使用defineEmits會返回一個方法,使用一個變量emits(變量名隨意)去接收,本文給大家介紹vue3 setup中defineEmits與defineProps的使用案例,感興趣的朋友一起看看吧
    2023-10-10
  • Vue.js如何監(jiān)聽window窗口尺寸變化

    Vue.js如何監(jiān)聽window窗口尺寸變化

    使用VUE開發(fā)后臺項(xiàng)目,后臺項(xiàng)目需要進(jìn)行后臺根據(jù)瀏覽器窗口進(jìn)行變化,需要使用vue來監(jiān)聽瀏覽器的窗口變化,這篇文章主要給大家介紹了關(guān)于Vue.js如何監(jiān)聽window窗口尺寸變化的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • vue從后臺渲染文章列表以及根據(jù)id跳轉(zhuǎn)文章詳情詳解

    vue從后臺渲染文章列表以及根據(jù)id跳轉(zhuǎn)文章詳情詳解

    這篇文章主要給大家介紹了關(guān)于vue從后臺渲染文章列表以及根據(jù)id跳轉(zhuǎn)文章詳情的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • vue中watch監(jiān)聽器用法之deep、immediate、flush

    vue中watch監(jiān)聽器用法之deep、immediate、flush

    Vue是可以監(jiān)聽到多層級數(shù)據(jù)改變的,且可以在頁面上做出對應(yīng)展示,下面這篇文章主要給大家介紹了關(guān)于vue中watch監(jiān)聽器用法之deep、immediate、flush的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • Vue打包程序部署到Nginx 點(diǎn)擊跳轉(zhuǎn)404問題

    Vue打包程序部署到Nginx 點(diǎn)擊跳轉(zhuǎn)404問題

    這篇文章主要介紹了Vue打包程序部署到Nginx 點(diǎn)擊跳轉(zhuǎn)404問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • VUE2.0自定義指令與v-if沖突導(dǎo)致元素屬性修改錯位問題及解決方法

    VUE2.0自定義指令與v-if沖突導(dǎo)致元素屬性修改錯位問題及解決方法

    這篇文章主要介紹了VUE2.0自定義指令與v-if沖突導(dǎo)致元素屬性修改錯位問題及解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • Vue自定義指令詳解

    Vue自定義指令詳解

    這篇文章主要介紹了Vue自定義指令詳解,需要的朋友可以參考下
    2022-12-12
  • Vue中失去焦點(diǎn)時所觸發(fā)的事件問題

    Vue中失去焦點(diǎn)時所觸發(fā)的事件問題

    這篇文章主要介紹了Vue中失去焦點(diǎn)時所觸發(fā)的事件問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue-cli腳手架引入彈出層layer插件的幾種方法

    vue-cli腳手架引入彈出層layer插件的幾種方法

    layer.js(mobile)是一個小巧方便的彈出層插件,在之前的apicloud項(xiàng)目中被大量使用,但最近對apicloud的IDE、非常不友好的文檔和極低的開發(fā)效率深感厭煩,決定棄用然后轉(zhuǎn)向Vue開發(fā)。這篇文章主要介紹了vue-cli腳手架引入彈出層layer插件的幾種方法,需要的朋友可以參考下
    2019-06-06

最新評論