如何在 Nuxt 3 中使用 vitest 编写组件单元测试?

mo3*_*o3n 7 unit-testing vue.js nuxt.js nuxtjs3 vitest

我正在尝试从 Vue 3 迁移到Nuxt 3。我已经使用 vitest 为我的组件编写了单元测试,这些测试在我的Vue应用程序中运行良好,但是 Nuxt 应用程序中的相同测试给出了以下错误:

错误:无法解析源以进行导入分析,因为内容包含无效的 JS 语法。
安装 @vitejs/plugin-vue 来处理 .vue 文件。

我已@vitejs/plugin-vue作为开发依赖项安装,但什么也没发生。

这是我的测试文件的示例:

import { describe, it, expect } from "vitest";

import { mount } from "@vue/test-utils";
import AtomsButton from "./AtomsButton.vue";

describe("AtomsButton", () => {
  it("button renders properly", () => {
    const wrapper = mount(AtomsButton, { slots: { default: "Button" } });
    expect(wrapper.html()).toContain("Button");
  });
});
Run Code Online (Sandbox Code Playgroud)

这是我的package.json文件:

{
  "private": true,
  "scripts": {
    "build": "nuxt build",
    "dev": "nuxt dev",
    "generate": "nuxt generate",
    "preview": "nuxt preview",
    "test:unit": "vitest --environment jsdom"
  },
  "devDependencies": {
    "@nuxt/test-utils-edge": "^3.0.0-rc.3-27571095.9379606",
    "@vitejs/plugin-vue": "^2.3.3",
    "@vue/test-utils": "^2.0.0",
    "jsdom": "^19.0.0",
    "nuxt": "3.0.0-rc.3",
    "vitest": "^0.13.1"
  }
}
Run Code Online (Sandbox Code Playgroud)

我不知道我做错了什么。任何帮助,将不胜感激。

这是复制链接

小智 11

我也遇到了这个问题,并且能够通过仅使用 Vitest 的自定义 Vite 配置文件来使其工作。

package.json文件 :

{
  "scripts": {
    "build": "nuxt build",
    "dev": "nuxt dev",
    "generate": "nuxt generate",
    "test:unit": "vitest --config ./vitest.config.js",
    "preview": "nuxt preview"
  },
  "devDependencies": {
    "@nuxtjs/tailwindcss": "^5.1.2",
    "@vitejs/plugin-vue": "^2.3.3",
    "@vue/test-utils": "^2.0.0",
    "jsdom": "^19.0.0",
    "nuxt": "3.0.0-rc.4",
    "vitest": "^0.14.2"
  }
}
Run Code Online (Sandbox Code Playgroud)

vitest.config.js文件 :

import vue from '@vitejs/plugin-vue';

export default {
  plugins: [vue()],
  test: {
    globals: true,
    environment: 'jsdom',
  },
}
Run Code Online (Sandbox Code Playgroud)

  • 以及如何处理 Nuxt 3 自动导入?因为通过此配置,我需要导入所有组件或 Vue 依赖项,例如 ref 或 React。 (4认同)