React jest 和 MSAL 获取 BrowserAuthError
React jest and MSAL getting BrowserAuthError
我正在尝试测试一些使用 MSAL 进行身份验证的组件。
到目前为止,我有一个简单的测试,测试我的组件是否可以渲染,如下:
let container;
beforeEach(() => {
container = render(<NavBar/>)
});
test('Component renders', () => {
expect(container).not.toBeNull()
})
当我 运行 测试时,出现以下错误:
BrowserAuthError: crypto_nonexistent: The crypto object or function is not available. Detail:Browser crypto or msCrypto object not available.
at BrowserAuthError.AuthError [as constructor] (node_modules/@azure/msal-browser/dist/index.cjs.js:545:24)
at new BrowserAuthError (node_modules/@azure/msal-browser/dist/index.cjs.js:7096:28)
at Function.Object.<anonymous>.BrowserAuthError.createCryptoNotAvailableError (node_modules/@azure/msal-browser/dist/index.cjs.js:7113:16)
at new BrowserCrypto (node_modules/@azure/msal-browser/dist/index.cjs.js:7413:36)
at new CryptoOps (node_modules/@azure/msal-browser/dist/index.cjs.js:7782:30)
at PublicClientApplication.ClientApplication (node_modules/@azure/msal-browser/dist/index.cjs.js:10027:58)
at new PublicClientApplication (node_modules/@azure/msal-browser/dist/index.cjs.js:11307:23)
我不确定以上是什么意思,但据我所知,发生此错误是因为会话未通过身份验证。
因此我的问题可以分为以下几种:
- 这个错误是什么意思?
- 如何解决这个错误? (我们可以出于测试目的绕过 MSAL 吗?)
基本上,我发现我的 <NavBar/>
组件依赖于两个 MS Graph API 调用,即 getAccountData()
和 setAccountData()
,这显然需要一个令牌无法运行,并导致了上面的严重错误。
因此,我决定通过简单地模拟它们来绕过这两个函数,如下所示:
jest.mock('../msGraph', () => ({ setAccountData: jest.fn() }))
jest.mock('../msGraph', () => ({ getAccountData: jest.fn() }))
我不依赖于从 Graph 获取数据来执行我的测试 - 所以这两个模拟函数不 return 任何数据。 (不过,我可以通过将其添加到 jest.fn()
的括号内来做到这一点)
我正在尝试测试一些使用 MSAL 进行身份验证的组件。
到目前为止,我有一个简单的测试,测试我的组件是否可以渲染,如下:
let container;
beforeEach(() => {
container = render(<NavBar/>)
});
test('Component renders', () => {
expect(container).not.toBeNull()
})
当我 运行 测试时,出现以下错误:
BrowserAuthError: crypto_nonexistent: The crypto object or function is not available. Detail:Browser crypto or msCrypto object not available.
at BrowserAuthError.AuthError [as constructor] (node_modules/@azure/msal-browser/dist/index.cjs.js:545:24)
at new BrowserAuthError (node_modules/@azure/msal-browser/dist/index.cjs.js:7096:28)
at Function.Object.<anonymous>.BrowserAuthError.createCryptoNotAvailableError (node_modules/@azure/msal-browser/dist/index.cjs.js:7113:16)
at new BrowserCrypto (node_modules/@azure/msal-browser/dist/index.cjs.js:7413:36)
at new CryptoOps (node_modules/@azure/msal-browser/dist/index.cjs.js:7782:30)
at PublicClientApplication.ClientApplication (node_modules/@azure/msal-browser/dist/index.cjs.js:10027:58)
at new PublicClientApplication (node_modules/@azure/msal-browser/dist/index.cjs.js:11307:23)
我不确定以上是什么意思,但据我所知,发生此错误是因为会话未通过身份验证。
因此我的问题可以分为以下几种:
- 这个错误是什么意思?
- 如何解决这个错误? (我们可以出于测试目的绕过 MSAL 吗?)
基本上,我发现我的 <NavBar/>
组件依赖于两个 MS Graph API 调用,即 getAccountData()
和 setAccountData()
,这显然需要一个令牌无法运行,并导致了上面的严重错误。
因此,我决定通过简单地模拟它们来绕过这两个函数,如下所示:
jest.mock('../msGraph', () => ({ setAccountData: jest.fn() }))
jest.mock('../msGraph', () => ({ getAccountData: jest.fn() }))
我不依赖于从 Graph 获取数据来执行我的测试 - 所以这两个模拟函数不 return 任何数据。 (不过,我可以通过将其添加到 jest.fn()
的括号内来做到这一点)