// 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
'
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>hello world</div></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)
})
})