欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue如何添加jest測(cè)試

 更新時(shí)間:2023年07月06日 09:48:28   作者:鶸者為何戰(zhàn)斗  
這篇文章主要介紹了vue如何添加jest測(cè)試問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue添加jest測(cè)試

用vuecli搭建了vue框架,想弄個(gè)單元測(cè)試,但是不是SecurityError: localStorage is not available for opaque origins,就是找不到包。

這里分為兩種情況解決。

第一、如果是終端敲npm run unit,那么需要修改jest.conf.js文件添加一行testURL

const path = require('path')
module.exports = {
? rootDir: path.resolve(__dirname, '../../'),
? moduleFileExtensions: [
? ? 'js',
? ? 'json',
? ? 'vue'
? ],
? moduleNameMapper: {
? ? '^@/(.*)$': '<rootDir>/src/$1'
? },
? transform: {
? ? '^.+\\.js$': '<rootDir>/node_modules/babel-jest',
? ? '.*\\.(vue)$': '<rootDir>/node_modules/vue-jest'
? },
? testPathIgnorePatterns: [
? ? '<rootDir>/test/e2e'
? ],
? snapshotSerializers: ['<rootDir>/node_modules/jest-serializer-vue'],
? setupFiles: ['<rootDir>/test/unit/setup'],
? mapCoverage: true,
? coverageDirectory: '<rootDir>/test/unit/coverage',
? collectCoverageFrom: [
? ? 'src/**/*.{js,vue}',
? ? '!src/main.js',
? ? '!src/router/index.js',
? ? '!**/node_modules/**'
? ],
? 'testURL': 'http://localhost'
}

第二、如果想在webstorm里面直接點(diǎn)擊*.test.js或者*.spec.js兩種文件運(yùn)行

那么你需要修改package.json里面的

{
? "name": "frontlearn",
? "version": "1.0.0",
? "description": "A Vue.js project",
? "author": "ruvikvan",
? "private": true,
? "scripts": {
? ? "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
? ? "start": "npm run dev",
? ? "unit": "jest --config test/unit/jest.conf.js --coverage",
? ? "e2e": "node test/e2e/runner.js",
? ? "test": "npm run unit && npm run e2e",
? ? "lint": "eslint --ext .js,.vue src test/unit test/e2e/specs",
? ? "build": "node build/build.js"
? },
? "dependencies": {
? ? "axios": "^0.18.0",
? ? "better-scroll": "^1.15.1",
? ? "vue": "^2.5.2",
? ? "vue-router": "^3.0.1",
? ? "vue-test-utils": "^1.0.0-beta.11"
? },
? "devDependencies": {
? ? "autoprefixer": "^7.1.2",
? ? "babel-core": "^6.22.1",
? ? "babel-eslint": "^8.2.1",
? ? "babel-helper-vue-jsx-merge-props": "^2.0.3",
? ? "babel-jest": "^21.0.2",
? ? "babel-loader": "^7.1.1",
? ? "babel-plugin-dynamic-import-node": "^1.2.0",
? ? "babel-plugin-syntax-jsx": "^6.18.0",
? ? "babel-plugin-transform-es2015-modules-commonjs": "^6.26.0",
? ? "babel-plugin-transform-runtime": "^6.22.0",
? ? "babel-plugin-transform-vue-jsx": "^3.5.0",
? ? "babel-preset-env": "^1.3.2",
? ? "babel-preset-stage-2": "^6.22.0",
? ? "babel-register": "^6.22.0",
? ? "chalk": "^2.0.1",
? ? "chromedriver": "^2.27.2",
? ? "copy-webpack-plugin": "^4.0.1",
? ? "cross-spawn": "^5.0.1",
? ? "css-loader": "^0.28.0",
? ? "eslint": "^4.15.0",
? ? "eslint-config-standard": "^10.2.1",
? ? "eslint-friendly-formatter": "^3.0.0",
? ? "eslint-loader": "^1.7.1",
? ? "eslint-plugin-import": "^2.7.0",
? ? "eslint-plugin-node": "^5.2.0",
? ? "eslint-plugin-promise": "^3.4.0",
? ? "eslint-plugin-standard": "^3.0.1",
? ? "eslint-plugin-vue": "^4.0.0",
? ? "extract-text-webpack-plugin": "^3.0.0",
? ? "file-loader": "^1.1.4",
? ? "friendly-errors-webpack-plugin": "^1.6.1",
? ? "html-webpack-plugin": "^2.30.1",
? ? "jest": "^22.0.4",
? ? "jest-serializer-vue": "^0.3.0",
? ? "nightwatch": "^0.9.12",
? ? "node-notifier": "^5.1.2",
? ? "optimize-css-assets-webpack-plugin": "^3.2.0",
? ? "ora": "^1.2.0",
? ? "portfinder": "^1.0.13",
? ? "postcss-import": "^11.0.0",
? ? "postcss-loader": "^2.0.8",
? ? "postcss-url": "^7.2.1",
? ? "rimraf": "^2.6.0",
? ? "selenium-server": "^3.0.1",
? ? "semver": "^5.3.0",
? ? "shelljs": "^0.7.6",
? ? "uglifyjs-webpack-plugin": "^1.1.1",
? ? "url-loader": "^0.5.8",
? ? "vue-jest": "^1.0.2",
? ? "vue-loader": "^13.3.0",
? ? "vue-style-loader": "^3.0.1",
? ? "vue-template-compiler": "^2.5.2",
? ? "webpack": "^3.6.0",
? ? "webpack-bundle-analyzer": "^2.9.0",
? ? "webpack-dev-server": "^2.9.1",
? ? "webpack-merge": "^4.1.0"
? },
? "engines": {
? ? "node": ">= 6.0.0",
? ? "npm": ">= 3.0.0"
? },
? "browserslist": [
? ? "> 1%",
? ? "last 2 versions",
? ? "not ie <= 8"
? ],
? "jest": {
? ? "moduleFileExtensions": [
? ? ? "js",
? ? ? "json",
? ? ? "vue"
? ? ],
? ? "transform": {
? ? ? "^.+\\.js$": "<rootDir>/node_modules/babel-jest",
? ? ? ".*\\.(vue)$": "<rootDir>/node_modules/vue-jest"
? ? },
? ? "moduleNameMapper": {
? ? ? "^@/(.*)$": "<rootDir>/src/$1"
? ? },
? ? "snapshotSerializers": [
? ? ? "<rootDir>/node_modules/jest-serializer-vue"
? ? ],
? ? "testURL": "http://localhost"
? }
}

vue項(xiàng)目中添加單元測(cè)試

Vue項(xiàng)目的單元測(cè)試用的是Vue Test Utils,這是Vue.js 官方的單元測(cè)試實(shí)用工具庫(kù),在Vue和Jest之間提供了一個(gè)橋梁,暴露出一些接口,讓我們更加方便的通過(guò)Jest為Vue應(yīng)用編寫單元測(cè)試

官網(wǎng)鏈接:介紹 | Vue Test Utils

新建Vue項(xiàng)目并使用Jest

1、運(yùn)行命令vue create ,選擇自定義配置

2、按需選擇配置,單元測(cè)試選擇Unit Testing,端到端測(cè)試選擇B2B Testing

3、接下來(lái)按需選擇Vue版本以及其他配置,選擇Jest,一路回車確定即可,最后需不需要保存配置由你決定

4、項(xiàng)目創(chuàng)建好后,可以看到自動(dòng)創(chuàng)建的tests文件夾和其下的一個(gè)測(cè)試文件,以及jest.config.js配置文件

5、運(yùn)行package.json中的腳本命令 npm run test:unit,即可執(zhí)行tests文件夾下所有的測(cè)試文件(默認(rèn)后綴為spec.js/spec.ts)以及所有的js/ts文件

已有Vue項(xiàng)目集成Jest

1、在vue項(xiàng)目目錄下運(yùn)行 vue add @vue/cli-plugin-unit-jest 命令,這個(gè)命令會(huì)幫我們把相關(guān)的配置都配好,相關(guān)的依賴都裝好,并生成jest.config.js文件和一個(gè)tests文件夾,目錄結(jié)構(gòu)同上面新建的Vue項(xiàng)目的目錄結(jié)構(gòu)相同

2、npm run test:unit 運(yùn)行測(cè)試命令

package.json中的測(cè)試腳本命令

"scripts": {
? ? "test:unit": "vue-cli-service test:unit --coverage test --reporters=jest-junit",
?}
  • --coverage:全量覆蓋率報(bào)告,會(huì)生成一個(gè)coverage文件夾,打開里面的index.html 里面會(huì)有詳細(xì)的信息展示
  • test jest --reporters=default --reporters=jest-junit:測(cè)試報(bào)告,執(zhí)行這個(gè)命令,會(huì)生成一個(gè)junit.xml文件,但要成功執(zhí)行這條命令,必須執(zhí)行 npm i jest-junit --save-dev,安裝jest-junit依賴

jest.config.js文件配置

module.exports = {
? preset: "@vue/cli-plugin-unit-jest",
? verbose: true, // 多于一個(gè)測(cè)試文件運(yùn)行時(shí)展示每個(gè)測(cè)試用例測(cè)試通過(guò)情況
? bail: true, // 參數(shù)指定只要有一個(gè)測(cè)試用例沒(méi)有通過(guò),就停止執(zhí)行后面的測(cè)試用例
? testEnvironment: 'jsdom', // 測(cè)試環(huán)境,jsdom可以在Node虛擬瀏覽器環(huán)境運(yùn)行測(cè)試
? moduleFileExtensions: [ // 需要檢測(cè)測(cè)的文件類型
? ? 'js',
? ? 'jsx',
? ? 'json',
? ? // tell Jest to handle *.vue files
? ? 'vue'
? ],
? transform: { // 預(yù)處理器配置,匹配的文件要經(jīng)過(guò)轉(zhuǎn)譯才能被識(shí)別,否則會(huì)報(bào)錯(cuò)
? ? '.+\\.(css|styl|less|sass|scss|jpg|jpeg|png|svg|gif|eot|otf|webp|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga|avif)$':
? ? require.resolve('jest-transform-stub'),
? ? '^.+\\.jsx?$': require.resolve('babel-jest')
? },
? transformIgnorePatterns: ['/node_modules/'], // 轉(zhuǎn)譯時(shí)忽略 node_modules
? moduleNameMapper: { // 從正則表達(dá)式到模塊名稱的映射,和webpack的alisa類似
? ? '^@/(.*)$': '<rootDir>/src/$1'
? },
? snapshotSerializers: [ // Jest在快照測(cè)試中使用的快照序列化程序模塊的路徑列表
? ? 'jest-serializer-vue'
? ],
? testMatch: [ // Jest用于檢測(cè)測(cè)試的文件,可以用正則去匹配
? ? '**/tests/unit/**/*.spec.[jt]s?(x)',
? ? '**/__tests__/*.[jt]s?(x)'
? ],
? collectCoverage: true, // 覆蓋率報(bào)告,運(yùn)行測(cè)試命令后終端會(huì)展示報(bào)告結(jié)果
? collectCoverageFrom: [ // 需要進(jìn)行收集覆蓋率的文件,會(huì)依次進(jìn)行執(zhí)行符合的文件
? ? 'src/**/*.{js,vue}',
? ],
? coverageReporters: ['html', 'lcov', 'text-summary'], // Jest在編寫覆蓋率報(bào)告的配置,添加"text"或"text-summary"在控制臺(tái)輸出中查看覆蓋率摘要
? coveragePathIgnorePatterns: ['/node_modules/'], // 需要跳過(guò)覆蓋率信息收集的文件目錄
? coverageDirectory: "<rootDir>/tests/unit/coverage", // Jest輸出覆蓋信息文件的目錄,運(yùn)行測(cè)試命令會(huì)自動(dòng)生成如下路徑的coverage文件
? coverageThreshold: { // 覆蓋結(jié)果的最低閾值設(shè)置,如果未達(dá)到閾值,jest將返回失敗
? ? global: {
? ? ? branches: 60,
? ? ? functions: 80,
? ? ? lines: 80,
? ? ? statements: 80,
? ? },
? },
? testURL: 'http://localhost/', // 官網(wǎng)沒(méi)有解釋,經(jīng)過(guò)嘗試可以隨意配置ip,如果識(shí)別不出是ip則會(huì)報(bào)錯(cuò)
? watchPlugins: [ // jest監(jiān)視插件
? ? require.resolve('jest-watch-typeahead/filename'),
? ? require.resolve('jest-watch-typeahead/testname')
? ]
};

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue3+ts代理的使用

    vue3+ts代理的使用

    本文主要介紹了vue3+ts代理的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • vue3常用響應(yīng)式對(duì)象的api,你全用過(guò)了嗎

    vue3常用響應(yīng)式對(duì)象的api,你全用過(guò)了嗎

    這篇文章主要給大家介紹了關(guān)于vue3常用響應(yīng)式對(duì)象api的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue3具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-02-02
  • vue集成openlayers加載geojson并實(shí)現(xiàn)點(diǎn)擊彈窗教程

    vue集成openlayers加載geojson并實(shí)現(xiàn)點(diǎn)擊彈窗教程

    這篇文章主要為大家詳細(xì)介紹了vue集成openlayers加載geojson并實(shí)現(xiàn)點(diǎn)擊彈窗教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法

    Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法

    這篇文章主要介紹了Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • vue3頁(yè)面跳轉(zhuǎn)的兩種方式

    vue3頁(yè)面跳轉(zhuǎn)的兩種方式

    vue3的頁(yè)面跳轉(zhuǎn)有兩種方式,第一種是標(biāo)簽內(nèi)跳轉(zhuǎn),第二種是編程式路由導(dǎo)航,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-05-05
  • 深入理解vue-loader如何使用

    深入理解vue-loader如何使用

    本篇文章主要介紹了vue-loader,vue-loader是webpack下loader插件 可以把.vue文件輸出成組件,有興趣的可以了解一下
    2017-06-06
  • Vue v2.4中新增的$attrs及$listeners屬性使用教程

    Vue v2.4中新增的$attrs及$listeners屬性使用教程

    這篇文章主要給大家介紹了關(guān)于Vue v2.4中新增的$attrs及$listeners屬性的使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • 關(guān)于Vue如何清除緩存的方法詳解

    關(guān)于Vue如何清除緩存的方法詳解

    緩存清除成為克服瀏覽器緩存中過(guò)時(shí)內(nèi)容挑戰(zhàn)的關(guān)鍵技術(shù),術(shù)語(yǔ)“緩存清除”是指故意使靜態(tài)資源失效或進(jìn)行版本控制,迫使瀏覽器在發(fā)生更改時(shí)獲取新資源,本文給大家介紹了Vue如何清除緩存,需要的朋友可以參考下
    2023-12-12
  • Vue+ssh框架實(shí)現(xiàn)在線聊天

    Vue+ssh框架實(shí)現(xiàn)在線聊天

    這篇文章主要為大家詳細(xì)介紹了Vue+ssh框架實(shí)現(xiàn)在線聊天,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue實(shí)現(xiàn)多個(gè)echarts根據(jù)屏幕大小變化而變化實(shí)例

    vue實(shí)現(xiàn)多個(gè)echarts根據(jù)屏幕大小變化而變化實(shí)例

    這篇文章主要介紹了vue實(shí)現(xiàn)多個(gè)echarts根據(jù)屏幕大小變化而變化實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07

最新評(píng)論