// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { textToHtml, debouncedQuery, findChangedIndex } from '../helpers.ts' describe('textToHtml', () => { it('adds links to URL-like text', () => { const input = 'Some Text\n\nhttp://example.com' const output = '
Some Text

http://example.com
' expect(textToHtml(input)).toBe(output) }) it('escapes HTML-like text to make sure it is presented as-is', () => { const input = '

&It;div>hello world</div>

' const output = '
<p>&It;div&gt;hello world&lt;/div&gt;</p>
' expect(textToHtml(input)).toBe(output) }) }) describe('debouncedQuery', () => { it('returns values correctly', async () => { let i = 0 const fn = debouncedQuery(async () => { i += 1 return i }, 0) const res1 = fn() const res2 = fn() const res3 = fn() // cancels the first two calls, and returns default value in that case expect(await res1).toBe(0) expect(await res2).toBe(0) expect(await res3).toBe(1) const res4 = fn() const res5 = fn() // cancels the first call, and returns the last value in that case expect(await res4).toBe(1) expect(await res5).toBe(2) }) }) describe('findChangedIndex', () => { it('returns the index of the first changed item', () => { const a = [1, 2, 3, 4, 5] const b = [1, 2, 3, 5, 5] expect(findChangedIndex(a, b)).toBe(3) const c = [{ id: 1 }, { id: 2 }, { id: 3 }, { id: 4 }, { id: 5 }] const d = [{ id: 1 }, { id: 2 }, { id: 3 }, { id: 5 }, { id: 5 }] expect(findChangedIndex(c, d)).toBe(3) const e = [[1], [2], [3], [4], [5]] const f = [[1], [2], [3], [5], [5]] expect(findChangedIndex(e, f)).toBe(3) }) it('returns -1 if no item changed', () => { const a = [1, 2, 3, 4, 5] const b = [1, 2, 3, 4, 5] expect(findChangedIndex(a, b)).toBe(-1) }) })