mirror of
https://github.com/portainer/portainer.git
synced 2025-07-25 16:29:44 +02:00
Some checks are pending
ci / build_images (map[arch:amd64 platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:amd64 platform:windows version:1809]) (push) Waiting to run
ci / build_images (map[arch:amd64 platform:windows version:ltsc2022]) (push) Waiting to run
ci / build_images (map[arch:arm platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:arm64 platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:ppc64le platform:linux version:]) (push) Waiting to run
ci / build_images (map[arch:s390x platform:linux version:]) (push) Waiting to run
ci / build_manifests (push) Blocked by required conditions
/ triage (push) Waiting to run
Lint / Run linters (push) Waiting to run
Test / test-client (push) Waiting to run
Test / test-server (map[arch:amd64 platform:linux]) (push) Waiting to run
Test / test-server (map[arch:amd64 platform:windows version:1809]) (push) Waiting to run
Test / test-server (map[arch:amd64 platform:windows version:ltsc2022]) (push) Waiting to run
Test / test-server (map[arch:arm64 platform:linux]) (push) Waiting to run
52 lines
1.4 KiB
TypeScript
52 lines
1.4 KiB
TypeScript
import { vi } from 'vitest';
|
|
import userEvent from '@testing-library/user-event';
|
|
import { render, screen } from '@testing-library/react';
|
|
|
|
import { VariableFieldItem } from './VariableFieldItem';
|
|
|
|
test('renders VariableFieldItem component', () => {
|
|
const definition = {
|
|
name: 'variableName',
|
|
label: 'Variable Label',
|
|
description: 'Variable Description',
|
|
defaultValue: 'Default Value',
|
|
};
|
|
|
|
render(<VariableFieldItem definition={definition} onChange={vi.fn()} />);
|
|
|
|
const labelElement = screen.getByText('Variable Label');
|
|
expect(labelElement).toBeInTheDocument();
|
|
|
|
const inputElement = screen.getByPlaceholderText(
|
|
'Enter value or leave blank to use default of Default Value'
|
|
);
|
|
expect(inputElement).toBeInTheDocument();
|
|
});
|
|
|
|
test('calls onChange when input value changes', async () => {
|
|
const user = userEvent.setup();
|
|
const onChange = vi.fn();
|
|
|
|
const definition = {
|
|
name: 'variableName',
|
|
label: 'Variable Label',
|
|
description: 'Variable Description',
|
|
defaultValue: 'Default Value',
|
|
};
|
|
|
|
render(
|
|
<VariableFieldItem
|
|
definition={definition}
|
|
onChange={onChange}
|
|
value="value"
|
|
/>
|
|
);
|
|
|
|
const inputElement = screen.getByLabelText(definition.label);
|
|
|
|
await user.clear(inputElement);
|
|
expect(onChange).toHaveBeenCalledWith('');
|
|
|
|
await user.type(inputElement, 'New Value');
|
|
expect(onChange).toHaveBeenCalled();
|
|
});
|