首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >definePageMeta将如何在Vitest中被嘲笑?

definePageMeta将如何在Vitest中被嘲笑?
EN

Stack Overflow用户
提问于 2022-06-15 10:00:50
回答 1查看 345关注 0票数 3

我正在尝试Vitest为我的应用程序编写UTs,该应用程序在Vue顶部有Nuxt。

但是,当我试图模拟definePageMeta时,我得到了未定义的test.vue

这是我的组件 test.vue -

代码语言:javascript
复制
<script setup lang="ts">
definePageMeta({
  layout: 'xyz',
  title: 'test component',
});
</script>

<template>
  <div>
    <h1>Hello World</h1>
  </div>
</template>

下面是名为test.spec.ts的UT文件,如下所示-

代码语言:javascript
复制
import { describe, expect, it } from 'vitest';

import Index from '../pages/test.vue';
import { mount } from '@vue/test-utils';

describe('renders the test component', () => {
  it('renders properly', () => {
    const wrapper = mount(Index);
    expect(wrapper.text()).toContain('Hello Vitest');
  });
});

这是我要犯的错误-

EN

回答 1

Stack Overflow用户

发布于 2022-10-05 01:58:13

答案可以找到here stackoverflow question

基本上导入以下内容:从'#imports‘导入{ definePageMeta }(这将取消自动导入功能,但很好)

将此resolve.alias添加到vitest.config.js以及setupFiles中

代码语言:javascript
复制
export default defineConfig({
 test: {
    setupFiles: 'setup-tests.ts',
  },
  resolve: {
    alias: {
       '#imports': '<rootDir>/.nuxt/imports.d.ts',
    }
  }
})

最后,将其添加到set-tests.js中。

代码语言:javascript
复制
vi.mock('#imports', () => ({
  definePageMeta: (meta: any) => {},
}))

请按照上面的链接获取更多的深度信息。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72629381

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档