import { triggerEvent, isFocusable } from '../aria'

const CE = (tag: string) => document.createElement(tag)

describe('Aria Utils', () => {
  describe('Trigger Event', () => {
    it('Util trigger event to trigger event correctly', () => {
      const div = document.createElement('div')
      jest.spyOn(div, 'dispatchEvent')
      const eventName = 'click'
      triggerEvent(div, eventName)
      expect(div.dispatchEvent).toHaveBeenCalled()
    })
  })

  describe('isFocusable', () => {
    it('should be focusable when element has tabindex attr, and it\'s value is greater than 0', () => {
      const $el = CE('div')
      $el.tabIndex = 1
      expect(isFocusable($el)).toBe(true)
    })

    it('should not be focusable when element has tabindex attr, and it\'s value is smaller than 0', () => {
      const $el = CE('div')
      $el.tabIndex = -1
      expect(isFocusable($el)).toBe(false)
    })

    it('should not be focusable when disbaled', () => {
      const $el = CE('div')
      $el.setAttribute('disabled', 'true')
      expect(isFocusable($el)).toBe(false)
    })
    it('should be focusable when target is anchor and rel is not set to ignore', () => {
      const $el = CE('a') as HTMLAnchorElement
      $el.href = '#anchor'
      $el.rel = 'noreferrer'
      expect(isFocusable($el)).toBe(true)
    })
    it('should not be focusable when target is anchor and rel is set to ignore', () => {
      const $el = CE('a') as HTMLAnchorElement
      $el.href = '#anchor'
      $el.rel = 'ignore'
      expect(isFocusable($el)).toBe(false)
    })
    it('should be focusable when target is input and type is not hidden or is not file', () => {
      const $el = CE('input') as HTMLInputElement
      $el.type = 'hidden'
      expect(isFocusable($el)).toBe(false)
      $el.type = 'file'
      expect(isFocusable($el)).toBe(false)
      $el.type = 'number'
      expect(isFocusable($el)).toBe(true)
    })
    it('should be focusable when the target is button/select/textarea', () => {
      let $el = CE('button')
      expect(isFocusable($el)).toBe(true)
      $el = CE('select')
      expect(isFocusable($el)).toBe(true)
      $el = CE('textarea')
      expect(isFocusable($el)).toBe(true)
    })
  })
})
