// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { onMounted, ref } from 'vue' import { renderComponent } from '#tests/support/components/index.ts' import CommonInputSearch, { type CommonInputSearchExpose, } from '../CommonInputSearch.vue' describe('testing input for searching', () => { it('renders input', async () => { const view = renderComponent(CommonInputSearch, { vModel: { modelValue: '', }, }) expect(view.getByIconName('search')).toBeInTheDocument() const search = view.getByRole('searchbox') expect(search).toHaveAttribute('placeholder', 'Search…') const clearButton = view.getByIconName('backspace2') expect(clearButton).toHaveClass('invisible') await view.events.type(search, 'test') expect(clearButton).not.toHaveClass('invisible') await view.events.click(clearButton) expect(search).toHaveDisplayValue('') }) it('can focus outside of the component', async () => { let focus: () => void const component = { components: { CommonInputSearch }, template: ``, setup() { const searchInput = ref() onMounted(() => { ;({ focus } = searchInput.value!) }) return { searchInput } }, } const view = renderComponent(component) focus!() expect(view.getByRole('searchbox')).toHaveFocus() }) it('provides search suggestion', async () => { const modelValue = ref('') const view = renderComponent(CommonInputSearch, { vModel: { modelValue, }, }) const search = view.getByRole('searchbox') expect(search).toHaveDisplayValue('') expect(view.queryByTestId('suggestion')).not.toBeInTheDocument() await view.events.type(search, 'foo') expect(modelValue.value).toBe('foo') await view.rerender({ suggestion: 'foobar', }) const suggestion = view.getByTestId('suggestion') expect(suggestion.firstChild).toHaveTextContent('foo') expect(suggestion.lastChild).toHaveTextContent('bar') await view.events.keyboard('{Tab}') expect(modelValue.value).toBe('foobar') expect(suggestion).not.toBeInTheDocument() }) })