import Vue from 'vue'

describe('Directive v-html', () => {
  it('should render html', () => {
    const vm = new Vue({
      template: '<div v-html="a"></div>',
      data: { a: 'hello' }
    }).$mount()
    expect(vm.$el.innerHTML).toBe('hello')
  })

  it('should encode html entities', () => {
    const vm = new Vue({
      template: '<div v-html="a"></div>',
      data: { a: '<span>&lt;</span>' }
    }).$mount()
    expect(vm.$el.innerHTML).toBe('<span>&lt;</span>')
  })

  it('should work inline', () => {
    const vm = new Vue({
      template: `<div v-html="'<span>&lt;</span>'"></div>`
    }).$mount()
    expect(vm.$el.innerHTML).toBe('<span>&lt;</span>')
  })

  it('should work inline in DOM', () => {
    const el = document.createElement('div')
    el.innerHTML = `<div v-html="'<span>&lt;</span>'"></div>`
    const vm = new Vue({ el })
    expect(vm.$el.children[0].innerHTML).toBe('<span>&lt;</span>')
  })

  it('should support all value types', done => {
    const vm = new Vue({
      template: '<div v-html="a"></div>',
      data: { a: false }
    }).$mount()
    waitForUpdate(() => {
      expect(vm.$el.innerHTML).toBe('false')
      vm.a = []
    })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('[]')
        vm.a = {}
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('{}')
        vm.a = {
          toString() {
            return 'foo'
          }
        }
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('foo')
        vm.a = {
          toJSON() {
            return { foo: 'bar' }
          }
        }
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('{\n  "foo": "bar"\n}')
        vm.a = 123
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('123')
        vm.a = 0
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('0')
        vm.a = ' '
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe(' ')
        vm.a = '    '
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('    ')
        vm.a = null
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('')
        vm.a = undefined
      })
      .then(() => {
        expect(vm.$el.innerHTML).toBe('')
      })
      .then(done)
  })
})