mirror of
https://github.com/podman-desktop/podman-desktop
synced 2026-04-21 17:47:22 +00:00
* refactor(Preferences): extracted checks of lifecycle methods to sepparate file Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> Signed-off-by: Evzen Gasta <evzen.ml@seznam.cz> * test: fixed tests Signed-off-by: Evzen Gasta <evzen.ml@seznam.cz> * chore: removed optional Signed-off-by: Evzen Gasta <evzen.ml@seznam.cz> * chore: updated related files Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> Signed-off-by: Evzen Gasta <evzen.ml@seznam.cz> --------- Signed-off-by: Evzen Gasta <evzen.ml@seznam.cz> Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com>
153 lines
5.6 KiB
TypeScript
153 lines
5.6 KiB
TypeScript
/**********************************************************************
|
|
* Copyright (C) 2024-2025 Red Hat, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
***********************************************************************/
|
|
|
|
import '@testing-library/jest-dom/vitest';
|
|
|
|
import type { ProviderStatus } from '@podman-desktop/api';
|
|
import type { ProviderContainerConnectionInfo, ProviderInfo } from '@podman-desktop/core-api';
|
|
import { render, screen } from '@testing-library/svelte';
|
|
import userEvent from '@testing-library/user-event';
|
|
import { router } from 'tinro';
|
|
import { beforeEach, expect, test, vi } from 'vitest';
|
|
|
|
import { providerInfos } from '/@/stores/providers';
|
|
|
|
import ImportContainersImages from './ImportContainersImages.svelte';
|
|
|
|
const pStatus: ProviderStatus = 'started';
|
|
const pInfo: ProviderContainerConnectionInfo = {
|
|
connectionType: 'container',
|
|
name: 'test',
|
|
displayName: 'test',
|
|
status: 'started',
|
|
endpoint: {
|
|
socketPath: '',
|
|
},
|
|
canStart: false,
|
|
canStop: false,
|
|
canEdit: false,
|
|
canDelete: false,
|
|
type: 'podman',
|
|
};
|
|
const providerInfo = {
|
|
id: 'test',
|
|
internalId: 'id',
|
|
name: '',
|
|
containerConnections: [pInfo],
|
|
kubernetesConnections: undefined,
|
|
status: pStatus,
|
|
containerProviderConnectionCreation: false,
|
|
containerProviderConnectionInitialization: false,
|
|
kubernetesProviderConnectionCreation: false,
|
|
kubernetesProviderConnectionInitialization: false,
|
|
links: undefined,
|
|
detectionChecks: undefined,
|
|
warnings: undefined,
|
|
images: undefined,
|
|
installationSupport: undefined,
|
|
} as unknown as ProviderInfo;
|
|
|
|
beforeEach(() => {
|
|
vi.clearAllMocks();
|
|
});
|
|
|
|
test('Expect import button to be disabled', async () => {
|
|
render(ImportContainersImages);
|
|
const btnImportContainer = screen.getByRole('button', { name: 'Import containers' });
|
|
expect(btnImportContainer).toBeInTheDocument();
|
|
expect(btnImportContainer).toBeDisabled();
|
|
});
|
|
|
|
test('Expect import button to be enabled when atleast one container image is selected', async () => {
|
|
providerInfos.set([providerInfo]);
|
|
vi.mocked(window.openDialog).mockResolvedValue(['path/file.tar']);
|
|
render(ImportContainersImages);
|
|
const btnAddImages = screen.getByRole('button', { name: 'Add images to import' });
|
|
expect(btnAddImages).toBeInTheDocument();
|
|
await userEvent.click(btnAddImages);
|
|
|
|
const btnImportContainer = screen.getByRole('button', { name: 'Import containers' });
|
|
expect(btnImportContainer).toBeInTheDocument();
|
|
expect(btnImportContainer).toBeEnabled();
|
|
|
|
expect(vi.mocked(window.openDialog)).toBeCalledWith({
|
|
selectors: ['multiSelections', 'openFile'],
|
|
title: 'Select Containers Images to import',
|
|
});
|
|
});
|
|
|
|
test('Expect import button to be enabled when atleast one container image is selected but there is no provider', async () => {
|
|
providerInfos.set([]);
|
|
vi.mocked(window.openDialog).mockResolvedValue(['path/file.tar']);
|
|
render(ImportContainersImages);
|
|
const btnAddImages = screen.getByRole('button', { name: 'Add images to import' });
|
|
expect(btnAddImages).toBeInTheDocument();
|
|
await userEvent.click(btnAddImages);
|
|
|
|
const btnImportContainer = screen.getByRole('button', { name: 'Import containers' });
|
|
expect(btnImportContainer).toBeInTheDocument();
|
|
expect(btnImportContainer).toBeDisabled();
|
|
});
|
|
|
|
test('Expect import call importContainer func', async () => {
|
|
providerInfos.set([providerInfo]);
|
|
vi.mocked(window.openDialog).mockResolvedValue(['path/file.tar']);
|
|
vi.mocked(window.importContainer).mockResolvedValue();
|
|
const goToMock = vi.spyOn(router, 'goto');
|
|
render(ImportContainersImages);
|
|
const btnAddImages = screen.getByRole('button', { name: 'Add images to import' });
|
|
expect(btnAddImages).toBeInTheDocument();
|
|
await userEvent.click(btnAddImages);
|
|
|
|
const btnImportContainer = screen.getByRole('button', { name: 'Import containers' });
|
|
expect(btnImportContainer).toBeInTheDocument();
|
|
expect(btnImportContainer).toBeEnabled();
|
|
await userEvent.click(btnImportContainer);
|
|
|
|
expect(vi.mocked(window.importContainer)).toBeCalledWith({
|
|
provider: pInfo,
|
|
archivePath: 'path/file.tar',
|
|
imageTag: 'file',
|
|
});
|
|
expect(goToMock).toBeCalledWith('/images');
|
|
});
|
|
|
|
test('Expect error shown if import function fails', async () => {
|
|
providerInfos.set([providerInfo]);
|
|
vi.mocked(window.openDialog).mockResolvedValue(['path/file.tar']);
|
|
vi.mocked(window.importContainer).mockRejectedValue('import failed');
|
|
render(ImportContainersImages);
|
|
const btnAddImages = screen.getByRole('button', { name: 'Add images to import' });
|
|
expect(btnAddImages).toBeInTheDocument();
|
|
await userEvent.click(btnAddImages);
|
|
|
|
const btnImportContainer = screen.getByRole('button', { name: 'Import containers' });
|
|
expect(btnImportContainer).toBeInTheDocument();
|
|
expect(btnImportContainer).toBeEnabled();
|
|
await userEvent.click(btnImportContainer);
|
|
|
|
expect(vi.mocked(window.importContainer)).toBeCalledWith({
|
|
provider: pInfo,
|
|
archivePath: 'path/file.tar',
|
|
imageTag: 'file',
|
|
});
|
|
|
|
const errorDiv = screen.getByLabelText('Error Message Content');
|
|
expect(errorDiv).toBeInTheDocument();
|
|
expect((errorDiv as HTMLDivElement).innerHTML).toContain('import failed');
|
|
});
|