model-text.spec.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. import Vue from 'vue'
  2. import { isIE9, isAndroid } from 'web/util/index'
  3. describe('Directive v-model text', () => {
  4. it('should update value both ways', done => {
  5. const vm = new Vue({
  6. data: {
  7. test: 'b'
  8. },
  9. template: '<input v-model="test">'
  10. }).$mount()
  11. expect(vm.$el.value).toBe('b')
  12. vm.test = 'a'
  13. waitForUpdate(() => {
  14. expect(vm.$el.value).toBe('a')
  15. vm.$el.value = 'c'
  16. triggerEvent(vm.$el, 'input')
  17. expect(vm.test).toBe('c')
  18. }).then(done)
  19. })
  20. it('.lazy modifier', () => {
  21. const vm = new Vue({
  22. data: {
  23. test: 'b'
  24. },
  25. template: '<input v-model.lazy="test">'
  26. }).$mount()
  27. expect(vm.$el.value).toBe('b')
  28. expect(vm.test).toBe('b')
  29. vm.$el.value = 'c'
  30. triggerEvent(vm.$el, 'input')
  31. expect(vm.test).toBe('b')
  32. triggerEvent(vm.$el, 'change')
  33. expect(vm.test).toBe('c')
  34. })
  35. it('.number modifier', () => {
  36. const vm = new Vue({
  37. data: {
  38. test: 1
  39. },
  40. template: '<input v-model.number="test">'
  41. }).$mount()
  42. expect(vm.test).toBe(1)
  43. vm.$el.value = '2'
  44. triggerEvent(vm.$el, 'input')
  45. // should let strings pass through
  46. vm.$el.value = 'f'
  47. triggerEvent(vm.$el, 'input')
  48. expect(vm.test).toBe('f')
  49. })
  50. it('.trim modifier', () => {
  51. const vm = new Vue({
  52. data: {
  53. test: 'hi'
  54. },
  55. template: '<input v-model.trim="test">'
  56. }).$mount()
  57. expect(vm.test).toBe('hi')
  58. vm.$el.value = ' what '
  59. triggerEvent(vm.$el, 'input')
  60. expect(vm.test).toBe('what')
  61. })
  62. if (isIE9) {
  63. it('IE9 selectionchange', done => {
  64. const vm = new Vue({
  65. data: {
  66. test: 'foo'
  67. },
  68. template: '<input v-model="test">'
  69. }).$mount()
  70. const input = vm.$el
  71. input.value = 'bar'
  72. document.body.appendChild(input)
  73. input.focus()
  74. triggerEvent(input, 'selectionchange')
  75. waitForUpdate(() => {
  76. expect(vm.test).toBe('bar')
  77. input.value = 'a'
  78. triggerEvent(input, 'selectionchange')
  79. expect(vm.test).toBe('a')
  80. }).then(done)
  81. })
  82. }
  83. if (!isAndroid) {
  84. it('compositionevents', function (done) {
  85. const vm = new Vue({
  86. data: {
  87. test: 'foo'
  88. },
  89. template: '<input v-model="test">'
  90. }).$mount()
  91. const input = vm.$el
  92. triggerEvent(input, 'compositionstart')
  93. input.value = 'baz'
  94. // input before composition unlock should not call set
  95. triggerEvent(input, 'input')
  96. expect(vm.test).toBe('foo')
  97. // after composition unlock it should work
  98. triggerEvent(input, 'compositionend')
  99. triggerEvent(input, 'input')
  100. expect(vm.test).toBe('baz')
  101. done()
  102. })
  103. }
  104. it('warn inline value attribute', () => {
  105. const vm = new Vue({
  106. data: {
  107. test: 'foo'
  108. },
  109. template: '<input v-model="test" value="bar">'
  110. }).$mount()
  111. expect(vm.test).toBe('foo')
  112. expect(vm.$el.value).toBe('foo')
  113. expect('inline value attributes will be ignored').toHaveBeenWarned()
  114. })
  115. it('warn textarea inline content', function () {
  116. const vm = new Vue({
  117. data: {
  118. test: 'foo'
  119. },
  120. template: '<textarea v-model="test">bar</textarea>'
  121. }).$mount()
  122. expect(vm.test).toBe('foo')
  123. expect(vm.$el.value).toBe('foo')
  124. expect('inline content inside <textarea> will be ignored').toHaveBeenWarned()
  125. })
  126. it('warn invalid tag', () => {
  127. new Vue({
  128. data: {
  129. test: 'foo'
  130. },
  131. template: '<div v-model="test"></div>'
  132. }).$mount()
  133. expect('v-model is not supported on element type: <div>').toHaveBeenWarned()
  134. })
  135. })