From 969da8086342e4f1899bf6e9cd2bae71d3ff7d37 Mon Sep 17 00:00:00 2001 From: Evzen Gasta Date: Fri, 6 Dec 2024 14:35:01 +0100 Subject: [PATCH] chore: review Signed-off-by: Evzen Gasta --- .../packages/extension/src/extension.spec.ts | 71 +++++++++---------- 1 file changed, 33 insertions(+), 38 deletions(-) diff --git a/extensions/podman/packages/extension/src/extension.spec.ts b/extensions/podman/packages/extension/src/extension.spec.ts index f3dc6e3ae..ec8ac4580 100644 --- a/extensions/podman/packages/extension/src/extension.spec.ts +++ b/extensions/podman/packages/extension/src/extension.spec.ts @@ -351,13 +351,17 @@ afterEach(() => { console.error = originalConsoleError; }); -describe.each(['macos', 'windows'])('verify create on %s', os => { - const provider = os === 'macos' ? VMTYPE.APPLEHV : VMTYPE.WSL; +describe.each([ + { os: 'macos', expectedProvider: VMTYPE.APPLEHV }, + { os: 'windows-wsl', expectedProvider: VMTYPE.WSL }, + { os: 'windows-hyperv', expectedProvider: VMTYPE.HYPERV }, +])('verify create on %s', ({ os, expectedProvider }) => { + const provider = expectedProvider; beforeEach((): void => { - vi.mocked(extensionApi.env).isWindows = os === 'windows'; + vi.mocked(extensionApi.env).isWindows = os !== 'macos'; vi.mocked(util.isMac).mockReturnValue(os === 'macos'); - setWSLEnabled(true); + setWSLEnabled(provider === VMTYPE.WSL); }); test('verify create command called with correct values', async () => { @@ -644,44 +648,35 @@ describe.each(['macos', 'windows'])('verify create on %s', os => { expect.anything(), ); }); -}); - -test('verify create command called in airgap mode will try to download hyperv image', async () => { - vi.mocked(extensionApi.env).isWindows = true; - setWSLEnabled(false); - vi.mocked(isMac).mockReturnValue(false); - - const spyExecPromise = vi.spyOn(extensionApi.process, 'exec'); - spyExecPromise.mockImplementationOnce(() => { - return Promise.resolve({} as extensionApi.RunResult); - }); - vi.spyOn(extensionApi.process, 'exec').mockResolvedValueOnce({ - stdout: 'podman version 5.0.0', - } as extensionApi.RunResult); - const parameters = ['machine', 'init', '--cpus', '2', '--memory', '1000', '--disk-size', '232', '--rootful', '--now']; + test('verify create command called in airgap mode will try to create image', async () => { + vi.mocked(extensionApi.env).isWindows = os !== 'macos'; + vi.mocked(isMac).mockReturnValue(os === 'macos'); + vi.mocked(getAssetsFolder).mockReturnValue('fake'); + vi.mocked(fs.existsSync).mockReturnValue(true); - await extension.createMachine({ - 'podman.factory.machine.cpus': '2', - 'podman.factory.machine.memory': '1048000000', - 'podman.factory.machine.diskSize': '250000000000', - 'podman.factory.machine.now': true, - 'podman.factory.machine.win.provider': 'hyperv', - }); + const spyExecPromise = vi.spyOn(extensionApi.process, 'exec'); + spyExecPromise.mockImplementationOnce(() => { + return Promise.resolve({} as extensionApi.RunResult); + }); + vi.spyOn(extensionApi.process, 'exec').mockResolvedValueOnce({ + stdout: 'podman version 5.0.0', + } as extensionApi.RunResult); - await vi.waitFor(() => { - expect(telemetryLogger.logUsage).toBeCalledWith( - 'podman.machine.init', - expect.objectContaining({ imagePath: 'default' }), - ); - }); + await extension.createMachine({ + 'podman.factory.machine.cpus': '2', + 'podman.factory.machine.memory': '1048000000', + 'podman.factory.machine.diskSize': '250000000000', + 'podman.factory.machine.now': true, + 'podman.factory.machine.win.provider': provider, + }); - expect(spyExecPromise).toBeCalledWith(podmanCli.getPodmanCli(), parameters, { - logger: undefined, - env: { - CONTAINERS_MACHINE_PROVIDER: VMTYPE.HYPERV, - }, - token: undefined, + await vi.waitFor(() => { + expect(telemetryLogger.logUsage).toBeCalledWith( + 'podman.machine.init', + expect.objectContaining({ imagePath: provider === VMTYPE.HYPERV ? 'default' : 'embedded' }), + ); + }); }); });