dify/web/app/components/base/param-item/__tests__/index-slider.spec.tsx
yyh a8e1ff85db
feat(web): base-ui slider (#34064)
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
2026-03-25 16:03:49 +08:00

43 lines
1.2 KiB
TypeScript

import { render, screen } from '@testing-library/react'
import userEvent from '@testing-library/user-event'
import ParamItem from '..'
describe('ParamItem Slider onChange', () => {
const defaultProps = {
id: 'test_param',
name: 'Test Param',
enable: true,
onChange: vi.fn(),
}
beforeEach(() => {
vi.clearAllMocks()
})
const getSlider = () => screen.getByLabelText('Test Param')
it('should divide slider value by 100 when max < 5', async () => {
const user = userEvent.setup()
render(<ParamItem {...defaultProps} value={0.5} min={0} max={1} />)
const slider = getSlider()
slider.focus()
await user.keyboard('{ArrowRight}')
// max=1 < 5, so slider value change (50->51) becomes 0.51
expect(defaultProps.onChange).toHaveBeenLastCalledWith('test_param', 0.51)
})
it('should not divide slider value when max >= 5', async () => {
const user = userEvent.setup()
render(<ParamItem {...defaultProps} value={5} min={1} max={10} />)
const slider = getSlider()
slider.focus()
await user.keyboard('{ArrowRight}')
// max=10 >= 5, so value remains raw (5->6)
expect(defaultProps.onChange).toHaveBeenLastCalledWith('test_param', 6)
})
})