Vue项目中添加单元测试

Vue项目的单元测试用的是Vue Test Utils,这是Vue.js 官方的单元测试实用工具库,在Vue和Jest之间提供了一个桥梁,暴露出一些接口,让我们更加方便的通过Jest为Vue应用编写单元测试

官网链接:介绍 | Vue Test Utils

一、新建Vue项目并使用Jest

1、运行命令vue create ,选择自定义配置

2、按需选择配置,单元测试选择Unit Testing,端到端测试选择B2B Testing

3、接下来按需选择Vue版本以及其他配置,选择Jest,一路回车确定即可,最后需不需要保存配置由你决定

4、项目创建好后,可以看到自动创建的tests文件夹和其下的一个测试文件,以及jest.config.js配置文件

5、运行package.json中的脚本命令 npm run test:unit,即可执行tests文件夹下所有的测试文件(默认后缀为spec.js/spec.ts)以及所有的js/ts文件

二、已有Vue项目集成Jest

1、在vue项目目录下运行 vue add @vue/cli-plugin-unit-jest 命令,这个命令会帮我们把相关的配置都配好,相关的依赖都装好,并生成jest.config.js文件和一个tests文件夹,目录结构同上面新建的Vue项目的目录结构相同

2、npm run test:unit 运行测试命令

三、package.json中的测试脚本命令

"scripts": {
    "test:unit": "vue-cli-service test:unit --coverage test --reporters=jest-junit",
 }
--coverage:全量覆盖率报告,会生成一个coverage文件夹,打开里面的index.html 里面会有详细的信息展示

test jest --reporters=default --reporters=jest-junit:测试报告,执行这个命令,会生成一个junit.xml文件,但要成功执行这条命令,必须执行 npm i jest-junit --save-dev,安装jest-junit依赖

更多配置可参考:https://jestjs.io/zh-Hans/docs/

四、jest.config.js文件配置

module.exports = {
  preset: "@vue/cli-plugin-unit-jest",
  verbose: true, // 多于一个测试文件运行时展示每个测试用例测试通过情况
  bail: true, // 参数指定只要有一个测试用例没有通过,就停止执行后面的测试用例
  testEnvironment: 'jsdom', // 测试环境,jsdom可以在Node虚拟浏览器环境运行测试
  moduleFileExtensions: [ // 需要检测测的文件类型
    'js',
    'jsx',
    'json',
    // tell Jest to handle *.vue files
    'vue'
  ],
  transform: { // 预处理器配置,匹配的文件要经过转译才能被识别,否则会报错
    '.+\\.(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/'], // 转译时忽略 node_modules
  moduleNameMapper: { // 从正则表达式到模块名称的映射,和webpack的alisa类似
    '^@/(.*)$': '<rootDir>/src/$1'
  },
  snapshotSerializers: [ // Jest在快照测试中使用的快照序列化程序模块的路径列表
    'jest-serializer-vue'
  ],
  testMatch: [ // Jest用于检测测试的文件,可以用正则去匹配
    '**/tests/unit/**/*.spec.[jt]s?(x)',
    '**/__tests__/*.[jt]s?(x)'
  ],
  collectCoverage: true, // 覆盖率报告,运行测试命令后终端会展示报告结果
  collectCoverageFrom: [ // 需要进行收集覆盖率的文件,会依次进行执行符合的文件
    'src/**/*.{js,vue}',
  ],
  coverageReporters: ['html', 'lcov', 'text-summary'], // Jest在编写覆盖率报告的配置,添加"text"或"text-summary"在控制台输出中查看覆盖率摘要
  coveragePathIgnorePatterns: ['/node_modules/'], // 需要跳过覆盖率信息收集的文件目录
  coverageDirectory: "<rootDir>/tests/unit/coverage", // Jest输出覆盖信息文件的目录,运行测试命令会自动生成如下路径的coverage文件
  coverageThreshold: { // 覆盖结果的最低阈值设置,如果未达到阈值,jest将返回失败
    global: {
      branches: 60,
      functions: 80,
      lines: 80,
      statements: 80,
    },
  },
  testURL: 'http://localhost/', // 官网没有解释,经过尝试可以随意配置ip,如果识别不出是ip则会报错
  watchPlugins: [ // jest监视插件
    require.resolve('jest-watch-typeahead/filename'),
    require.resolve('jest-watch-typeahead/testname')
  ]
};

具体可参考官方文档:介绍 | Vue Test Utils 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue项目日历开发日程的项目主要包括以下几方面的工作: 1. 界面设计:首先需要设计一个日历的界面,包括日期显示区域、日历视图切换、时间轴等功能。可以使用Vue的组件化开发方式,将日历划分为多个子组件进行开发。 2. 数据处理:日历主要展示日期和相关的任务或事件,因此需要对日期和任务数据进行处理。可以使用Vue的数据绑定功能,将日期和任务数据关联起来,实现实时展示。 3. 事件处理:日历功能包括添加、删除、修改任务或事件等操作,需要进行相应的事件处理。可以利用Vue的事件绑定功能,监听用户的操作,并更新相应的数据。 4. 功能实现:除了基本的日期展示和任务管理功能外,还可以考虑实现一些高级功能,如任务提醒、事件分享等。这些功能可以利用Vue的插件机制或第三方组件进行实现。 5. 响应式布局:为了适应不同屏幕大小的设备,需要对日历界面进行响应式布局。可以利用Vue的样式绑定功能,根据不同屏幕大小添加相应的样式规则。 6. 测试和优化:开发完成后,需要进行充分的测试和优化工作。可以利用Vue单元测试工具对核心功能进行测试,并使用性能分析工具进行性能优化。 总之,Vue项目日历开发日程的项目需要进行界面设计、数据处理、事件处理、功能实现、响应式布局、测试和优化等工作,通过合理的分工和有序的开发流程,能够开发出稳定、高效、用户友好的日历应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值