zoukankan      html  css  js  c++  java
  • 前端vue项目添加单元测试及sonar配置

    安装

    npm install --save-dev jest @vue/test-utils

    详情查看:https://vue-test-utils.vuejs.org/zh/

    安装依赖:

    "@vue/cli-plugin-babel": "~4.3.0",
    "@vue/cli-plugin-eslint": "~4.3.0",
    "@vue/cli-plugin-router": "~4.3.0",
    "@vue/cli-plugin-unit-jest": "~4.3.0",
     "babel-jest": "23.6.0",
     "jest": "^26.6.3",
     "jest-sonar-reporter": "^2.0.0",
     "jest-watch-typeahead": "^0.6.1",
     

    安装后查看本地文件夹:

     .eslintrc.js文件内容:

    module.exports = {
      env: {
        jest: true
      }
    }

    setup.js文件内容:

    import Vue from 'vue'
    import ElementUI from 'element-ui'
    Vue.use(ElementUI)

    jest.config.js文件内容:配置jest.config.js使用https://jestjs.io/docs/configuration

    module.exports = {
      moduleFileExtensions: ['js', 'jsx', 'json', 'vue'],
      transform: {
        '^.+\\.vue$': 'vue-jest',
        '.+\\.(css|styl|less|sass|scss|svg|png|jpg|ttf|woff|woff2)$':
          'jest-transform-stub',
        '.*\\.(js)$': 'babel-jest'
      },
      moduleNameMapper: {
        '^@/(.*)$': '<rootDir>/src/$1',
        '\\.(css|less)$': 'identity-obj-proxy'// 解析css文件异常处理方式
      },
      snapshotSerializers: ['jest-serializer-vue'],
      testMatch: [
        '**/tests/unit/**/*.spec.(js|jsx|ts|tsx)|**/__tests__/*.(js|jsx|ts|tsx)'
      ],
      collectCoverageFrom: [
        'src/utils/**/*.{js,vue}',
        '!src/utils/auth.js',
        '!src/utils/request.js',
        'src/components/**/*.{js,vue}',
        'src/views/**/*.{js,vue}',
        '!src/views/login/**/*.{js,vue}',
        '!src/views/iframe/**/*.{js,vue}'
      ],
      coverageDirectory: '<rootDir>/tests/unit/coverage',
      'collectCoverage': true,
      'coverageReporters': [
        'lcov',
        'text-summary'
      ],
      testURL: 'http://localhost/',
      testResultsProcessor: 'jest-sonar-reporter',
      setupFiles: ['./tests/setup.js'],
      watchPlugins: [
        'jest-watch-typeahead/filename',
        'jest-watch-typeahead/testname'
      ]
    }

     项目根目录下新增文件sonar-project.properties,内容如下。可以将测试结果上报给sonar

    #根据具体项目修改
    sonar.projectKey= **查看jenkins中配置**
    #根据具体项目修改
    sonar.projectName=  **查看jenkins中配置**
    # Source
    sonar.sources=src
    # Where to find tests file, also src
    sonar.tests=tests
    # But we get specific here
    # We don't need to exclude it in sonar.sources because it is automatically taken care of
    # sonar.test.inclusions=src/**/*.spec.js,src/**/*.spec.jsx,src/**/*.test.js,src/**/*.test.jsx
    sonar.test.inclusions=**/*tests*/**
    sonar.exclusions=**/*tests*/**
    sonar.javascript.file.suffixes=.js,.jsx,.vue
    # Now specify path of lcov and testlog
    sonar.javascript.lcov.reportPaths=tests/unit/coverage/lcov.info
    转发请备注出处
    【公众号:缃言的调调】
  • 相关阅读:
    webpack入门
    Javascript隐式转换
    一个最小手势库的实现
    运用JS设置cookie、读取cookie、删除cookie
    不同浏览器下兼容文本两端对齐
    使用CSS3实现一个3D相册
    JavaScript 火的有点过头了,但又能火多久呢?
    强大的css3
    CSS3与页面布局学习总结
    红米手机真机调试问题记录
  • 原文地址:https://www.cnblogs.com/zuojiayi/p/15587226.html
Copyright © 2011-2022 走看看