diff --git a/applications/launchpad_v2/__tests__/mocks/mockTauriIPC.ts b/applications/launchpad_v2/__tests__/mocks/mockTauriIPC.ts new file mode 100644 index 0000000000..b643131460 --- /dev/null +++ b/applications/launchpad_v2/__tests__/mocks/mockTauriIPC.ts @@ -0,0 +1,70 @@ +import { mockIPC } from '@tauri-apps/api/mocks' + +/** + * Set of default values returned by `tauriIPCMock()` + */ +export const defaultTauriMockValues: Record = { + os: { + arch: 'x86_64', + platform: 'darwin', + ostype: 'Darwin', + }, +} + +/** + * The Tauri IPC mock. + * + * It uses Tauri's mockIPC and returns the value set in the `props`. + * If nothing found in `props`, it will return a value from `defaultTauriMockValues`. + * + * @param {Record} props - pass the value you expect in tests + * + * @example + * // Use default values: + * tauriIPCMock() + * + * // Get given value from specific API module (ie. 'platform' from 'os' module) + * tauriIPCMock({ + * os: { + * platform: 'darwin', + * }, + * }) + */ +export const tauriIPCMock = (props: Record = undefined) => { + return mockIPC((cmd, args) => { + switch (cmd) { + case 'tauri': + return tauriCmdMock(cmd, args, props) + case 'invoke': + return + default: + return + } + }) +} + +const tauriCmdMock = ( + cmd: string, + args: Record, + props: Record, +) => { + const tauriModule = (args?.__tauriModule as string)?.toLowerCase() + const messageCmd = (args?.message as { cmd?: string })?.cmd?.toLowerCase() + + if (tauriModule && messageCmd) { + if ( + props && + Object.keys(props).includes(tauriModule) && + Object.keys(props[tauriModule]).includes(messageCmd) + ) { + return props[tauriModule][messageCmd] + } else if ( + Object.keys(defaultTauriMockValues).includes(tauriModule) && + Object.keys(defaultTauriMockValues[tauriModule]).includes(messageCmd) + ) { + return defaultTauriMockValues[tauriModule][messageCmd] + } + } + + return +} diff --git a/applications/launchpad_v2/src/App.test.tsx b/applications/launchpad_v2/src/App.test.tsx index 75b2281bb0..89a6155347 100644 --- a/applications/launchpad_v2/src/App.test.tsx +++ b/applications/launchpad_v2/src/App.test.tsx @@ -1,11 +1,12 @@ -import React from 'react' -import { render } from '@testing-library/react' +import { act, render } from '@testing-library/react' import { randomFillSync } from 'crypto' import { clearMocks } from '@tauri-apps/api/mocks' import { ThemeProvider } from 'styled-components' +import { Provider } from 'react-redux' import App from './App' -import { Provider } from 'react-redux' + +import { tauriIPCMock } from '../__tests__/mocks/mockTauriIPC' import { store } from './store' import themes from './styles/themes' @@ -23,11 +24,14 @@ afterEach(() => { }) test('renders without crashing', async () => { - render( - - - - - , - ) + tauriIPCMock() + await act(async () => { + render( + + + + + , + ) + }) }) diff --git a/applications/launchpad_v2/src/components/Footer/Footer.test.tsx b/applications/launchpad_v2/src/components/Footer/Footer.test.tsx index 8a36eb3333..66804a85dd 100644 --- a/applications/launchpad_v2/src/components/Footer/Footer.test.tsx +++ b/applications/launchpad_v2/src/components/Footer/Footer.test.tsx @@ -1,12 +1,65 @@ -import { render, screen } from '@testing-library/react' +import { clearMocks } from '@tauri-apps/api/mocks' +import { act, render, screen } from '@testing-library/react' +import { randomFillSync } from 'crypto' import Footer from '.' +import { tauriIPCMock } from '../../../__tests__/mocks/mockTauriIPC' + +beforeAll(() => { + window.crypto = { + getRandomValues: function (buffer) { + return randomFillSync(buffer) + }, + } +}) + +afterEach(() => { + clearMocks() +}) describe('Footer', () => { - it('should render without crash', () => { - render(