dify/web/app/components/base/file-uploader/__tests__/audio-preview.spec.tsx

67 lines
2.4 KiB
TypeScript

import { fireEvent, render, screen } from '@testing-library/react'
import AudioPreview from '../audio-preview'
describe('AudioPreview', () => {
beforeEach(() => {
vi.clearAllMocks()
})
it('should render audio element with correct source', () => {
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={vi.fn()} />)
const audio = document.querySelector('audio')
expect(audio).toBeInTheDocument()
expect(audio).toHaveAttribute('title', 'Test Audio')
})
it('should render source element with correct src and type', () => {
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={vi.fn()} />)
const source = document.querySelector('source')
expect(source).toHaveAttribute('src', 'https://example.com/audio.mp3')
expect(source).toHaveAttribute('type', 'audio/mpeg')
})
it('should render close button with icon', () => {
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={vi.fn()} />)
expect(screen.getByRole('button', { name: 'common.operation.close' })).toBeInTheDocument()
})
it('should call onCancel when close button is clicked', () => {
const onCancel = vi.fn()
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={onCancel} />)
fireEvent.click(screen.getByRole('button', { name: 'common.operation.close' }))
expect(onCancel).toHaveBeenCalled()
})
it('should not close when backdrop is clicked', () => {
const onCancel = vi.fn()
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={onCancel} />)
const dialog = screen.getByRole('dialog')
fireEvent.click(dialog)
expect(onCancel).not.toHaveBeenCalled()
})
it('should call onCancel when Escape key is pressed', () => {
const onCancel = vi.fn()
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={onCancel} />)
fireEvent.keyDown(document, { key: 'Escape', code: 'Escape' })
expect(onCancel).toHaveBeenCalled()
})
it('should render in a portal attached to document.body', () => {
render(<AudioPreview url="https://example.com/audio.mp3" title="Test Audio" onCancel={vi.fn()} />)
const audio = document.querySelector('audio')
expect(audio?.closest('[data-base-ui-portal]')?.parentElement).toBe(document.body)
})
})