import { focusFirstDescendant, obtainAllFocusableElements, getEdges, } from '../src/utils' describe('focus-trap utils', () => { const buildDOM = () => { const parser = new DOMParser() return parser.parseFromString( ` <div class="root"> <span>some val</span> <input class="focusable-input" /> <span tabindex="0" class="focusable-span">other val</span> <span hidden tabindex="0"> hidden span</span> <input disabled /> <input hidden /> </div> `, 'text/html' ) } beforeEach(() => { const dom = buildDOM() Array.from(dom.children).forEach((child) => { document.body.appendChild(child) }) }) afterEach(() => { document.body.innerHTML = '' }) it('should be able to focus', () => { const focusable = obtainAllFocusableElements(document.body) expect(focusable).toHaveLength(2) expect(focusable[0].classList).toContain('focusable-input') }) it('should be able to get focusable edge', () => { const [first, last] = getEdges(document.body) expect(first.classList).toContain('focusable-input') expect(last.classList).toContain('focusable-span') }) it('should be able to focus on the first descendant', () => { expect(document.activeElement).toBe(document.body) const focusable = obtainAllFocusableElements(document.body) focusFirstDescendant(focusable) expect(document.activeElement).toBe(focusable[0]) }) })