Vue-Test-Utils + Jest 单元测试入门与实践

2020-02-25  本文已影响0人  joeal

Vue-Test-Utils + Jest 单元测试入门与实践

创建Vue项目

在终端用vue-cli创建一个项目

$vue create vue-test

选择Manually select features进行手动选择功能配置:

vue-test 1.png

勾选 BabelTypeScriptRouterUnit Testing

vue-test 2.png

选择Jest:

vue-test 3.png

选择In dedicated config files将各配置信息配置在对应的 config文件里:

? Where do you prefer placing config for Babel, PostCSS, ESLint, etc.? (Use arrow keys)
❯ In dedicated config files
  In package.json

输入n,不保存预设:

? Save this as a preset for future projects? (y/N) n

创建成功

vue-test 4.png

查看部分配置文件

jest.config.js

默认如下:

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

我们可以按实际需求添加其它配置项:

module.exports = {
  preset: "@vue/cli-plugin-unit-jest/presets/typescript-and-babel",
  testMatch: ["**/tests/unit/**/*.spec.[jt]s?(x)"],
  transformIgnorePatterns: ["<rootDir>/node_modules/"],
  moduleFileExtensions: [
        'js',
        'vue'
    ],
    transform: {
        '^.+\\.vue$': '<rootDir>/node_modules/vue-jest',
        '^.+\\.js$': '<rootDir>/node_modules/babel-jest'
    },
    moduleNameMapper: {
        '^@/(.*)$': '<rootDir>/src/$1'
    },
    snapshotSerializers: [
        'jest-serializer-vue'
    ]
};

测试用例

vs code打开项目你会发现根目录下有一目录test/unit,里面就有一个已经生成的测试用例。

vue-test 5.png

新建终端:运行单元测试。这里会根据jest.config.jstestMatch配置的条件进行运行。当前匹配的是所有tests/unit下的测试文件

$yarn test:unit
vue test 6.png

指定运行某个测试文件

新建一个couter.vue文件简单的界面,点击按钮数目加1。在tests/unit目录下新建一个测试文件couter.spec.ts

//couter.vue
<template>
  <div>
    <span class="count">{{ count }}</span>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      count: 0
    };
  },
  methods: {
    increment() {
      this.count++;
    }
  }
};
</script>

//couter.spec.ts
import { mount } from "@vue/test-utils";
import Couter from "@/views/Couter.vue";

describe("Couter.vue", () => {
  const wrapper = mount(Couter);
  it("测试累加", () => {
    wrapper.setData({ count: 13 });
    const button = wrapper.find("button");
    button.trigger("click");
    expect((wrapper.vm as any).count).toBe(14);
  });
});

所有目前tests/unit目录下有两个测试文件,如果还用yarn test:unit命令的话就会跑所有测试文件。那么我们怎么指定运行一个文件呢,看下面命令:

$yarn  jest  -- **/tests/unit/**/couter.spec.ts
vue test 7.png

测试用例一些API介绍

更多用法vue-test-utils官方文档

参考原文

上一篇 下一篇

猜你喜欢

热点阅读