- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Vitest 测试 Vue 组件,但为了做到这一点,我需要模拟 auth0
下面是我的 Navbar.test.ts 文件,但是当我运行测试时,我不断收到以下错误 Cannot read properties of undefined (reading 'mockReturnValue'
as useAuth0
似乎未定义,即使我将其导入到页面顶部。也许我只是不太了解它的模拟方面,但我们将不胜感激。
import { vi } from 'vitest'
import { ref } from "vue";
import { shallowMount } from '@vue/test-utils'
import { useAuth0 } from '@auth0/auth0-vue';
import NavBar from "@/components/NavBar.vue";
const user = {
email: "user@test.com",
email_verified: true,
sub: ""
};
vi.mock("@auth0/auth0-vue");
const mockedUseAuth0 = vi.mocked(useAuth0, true);
describe("NavBar.vue", () => {
beforeEach(() => {
mockedUseAuth0.mockReturnValue({
isAuthenticated: ref(true),
user: ref(user),
logout: vi.fn(),
loginWithRedirect: vi.fn(),
...
isLoading: ref(false),
});
});
it("mounts", () => {
const wrapper = shallowMount(NavBar, {
props: { },
});
expect(wrapper).toBeTruthy();
});
afterEach(() => vi.clearAllMocks());
});
最佳答案
auth0.useAuth0
要访问模拟模块,请使用通配符导入导入整个模块,并避免命名导入。另外,vi.mocked()
只是 TypeScript 支持的 helper 。它不会 mock 任何东西。
所以不是这个:
import { useAuth0 } from '@auth0/auth0-vue' ❌
vi.mock('@auth0/auth0-vue')
const mockedUseAuth0 = vi.mocked(useAuth0, true) ❌
...这样做:
import * as auth0 from '@auth0/auth0-vue' ✅
vi.mock('@auth0/auth0-vue')
然后,通过将属性直接附加到模拟的 auth0
导入来模拟 useAuth0
:
describe('NavBar.vue', () => {
it('does something', async () => {
👇
(auth0 as any).useAuth0 = vi.fn().mockReturnValue({
// relevant fields for test
});
})
})
useAuth0
的值应该是 vi.fn()
的模拟函数 ( returns )与测试相关的字段。假设被测组件是 NavBar.vue
from Auth0's sample app ,可以编写一个测试来验证登录按钮是否调用了 loginWithRedirect
。该按钮仅可用 when isAuthenticated
and isLoading
are false .请注意,这些字段不需要是 Vue ref
。
所以这样的测试看起来像这样:
describe('NavBar.vue', () => {
it('login button invokes useAuth.loginWithRedirect', async () => {
const loginWithRedirect = vi.fn();
(auth0 as any).useAuth0 = vi.fn().mockReturnValue({
isAuthenticated: false,
isLoading: false,
loginWithRedirect,
});
const wrapper = shallowMount(NavBar);
await wrapper.find('button#qsLoginBtn').trigger('click');
expect(auth0.useAuth0).toHaveBeenCalled();
expect(loginWithRedirect).toHaveBeenCalled();
})
})
useAuth().user
还可以编写一个测试来验证经过身份验证的用户的详细信息是否显示在组件中。具体来说,user's name is shown in .user-info
, 和 user's picture is shown in .user-info img
当 isAuthenticated
为真时。因此,模拟的 useAuth0
应该返回 isAuthenticated
和 user
,如下所示:
describe('NavBar', () => {
it('authenticated user details are shown', async () => {
const user = {
name: 'john@gmail.com',
picture: 'https://s.gravatar.com/avatar/1f9d9a9efc2f523b2f09629444632b5c?s=480&r=pg&d=https%3A%2F%2Fcdn.auth0.com%2Favatars%2Fjo.png',
};
(auth0 as any).useAuth0 = vi.fn().mockReturnValue({
isAuthenticated: true,
user,
});
const wrapper = shallowMount(NavBar);
expect(wrapper.find('.user-info').text()).toBe(user.name);
expect(wrapper.find('.user-info img').attributes('src')).toBe(user.picture);
})
})
关于javascript - 视觉 : How to mock Auth0 for testing with Vitest,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72732768/
当我尝试以非整数的步长(例如,每帧 0.5 像素)在屏幕上移动图形对象时,这会导致移动不稳定和“滞后”;因为对象只会每两帧移动 1 个像素。 我理解为什么会发生这种情况,因为对象的 x/y 值必须是整
市面上有大量的家谱应用程序,但出于某种原因,我找不到一个示例来说明如何为 Android 应用程序创建一个。我是否使用 Canvas ,是否有图表库? 我的基本要求是画一个三层的树(节点)图/图表,其
[ {name: 'John'}, {name: 'Plasmody'}, {name: 'Kugelschreiber'}, {name: 'Sarrah'}, ] 如果我在 J并做
我试图定位所有没有 www 的链接。在数据库中。 https://launchhousing.org.au 并替换为 https://www.launchhousing.org.au 我使用了“搜索和
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我需要排除具有以下模式的文件: ProjectFoo.Data[0-9]{14}.lgp 如何将 RegEx 用于 (Visual)SVN 忽略列表? 最佳答案 subversion 忽略列表不支持正
我正在寻找在处理中创建该项目的方法,但是,我发现该术语有点困难。我不确定如何调用在整个歌曲中线条永久保持的效果来“绘制”音乐数据。 对于我可以查看哪些教程或某人的回答,我将不胜感激。 我的目标是创建尽
我正在尝试为 android 制作游戏。我目前已将所有美术资源加载到 drawables 文件夹中,但我的问题是如何实际引用特定资源来渲染它? 我知道每个文件都有一个唯一的@id,我可能必须在onDr
Closed. This question is off-topic。它当前不接受答案。
只是一个简单的问题。 有一个简单的可视化工具可以生成iOS/QuartzCore的源代码吗? 例如,我会制作一个带有路径和a的CAKeyframeAnimation(例如CGPathMoveToPoi
编辑 3:我想这已经解决了。我刚刚启用了古腾堡编辑器并发现了它的“经典编辑器”部分,即代码编辑器。我唯一需要习惯的是我无法轻易修改的编辑器行高,这还不错。这对我有用,它超过了修改 functions.
我想在具有背景 slider 的可视 Composer 行内创建一个下拉菜单,最重要的是我要切换的链接。我在编辑自定义 css 时面临的问题是链接没有设置为 bottom:0;已设置position:
我正在学习 C++,并且了解一点 Visual Basic 和 Delphi。 但我想知道,有没有像 Delphi 这样的程序,但适用于 C++。您可以将按钮拖到窗体上,双击它,就像在 Delphi
我正在努力使用 pygame 初始化 OpenGL 显示。和pyopengl . import pygame pygame.init() pygame.display.set_mode((1920,
不确定我做错了什么。我创建了一个主题,除了我在可视化编辑器中创建帖子外,一切都很好。对我来说,这很好,但大多数用户不了解 HTML,因此无法真正进入并编辑代码。 在元素检查器(Chrome)中,文章是
我正在编写一个 C# 程序,它接受一堆参数并对数据点进行一些转换,然后将它们绘制到屏幕上。 在我的一个表单上,我有一堆文本框,我都想执行相同的 KeyPress 事件。在我只做一个 switch 语句
我正在创建 UML 事件图,我需要使用发送和接受信号,但我似乎找不到它。我试图用谷歌搜索它,但我似乎找不到任何东西。有谁知道我在哪里可以找到它们,或者它们在 Visio 中不存在? 最佳答案 想知道为
是 Haskell for Visual Studio 2005兼容VS2008 SP1 ? 最佳答案 您最初问题的答案是否定的。visual haskell 的代码是用 Haskell 编写的,并通
我正在使用 Visual Composer 开发我的 WordPress 网站。 我需要包含一个可分页的容器,但如果它可以像幻灯片一样就更好了。 This is my pageable contain
有哪些 Web 应用程序可以让我直观地(通过单击)使用任何 REST API 并生成一些代码(以任何语言)来捕捉我所描述的视觉内容? 与 Swagger 或 Google API Playground
我是一名优秀的程序员,十分优秀!