@gitlab/ui 114.0.1 → 114.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/package.json +9 -28
  2. package/CHANGELOG.md +0 -13132
  3. package/src/vendor/bootstrap/LICENSE +0 -11
  4. package/src/vendor/bootstrap-vue/LICENSE +0 -11
  5. package/src/vendor/bootstrap-vue/package.json +0 -144
  6. package/src/vendor/bootstrap-vue/src/components/button/MODIFICATIONS.md +0 -16
  7. package/src/vendor/bootstrap-vue/src/components/button/README.md +0 -240
  8. package/src/vendor/bootstrap-vue/src/components/button/button-close.spec.js +0 -210
  9. package/src/vendor/bootstrap-vue/src/components/button/button.spec.js +0 -349
  10. package/src/vendor/bootstrap-vue/src/components/button/package.json +0 -105
  11. package/src/vendor/bootstrap-vue/src/components/dropdown/README.md +0 -730
  12. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.spec.js +0 -58
  13. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.spec.js +0 -110
  14. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.spec.js +0 -94
  15. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.spec.js +0 -73
  16. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.spec.js +0 -117
  17. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.spec.js +0 -147
  18. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.spec.js +0 -59
  19. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.spec.js +0 -1121
  20. package/src/vendor/bootstrap-vue/src/components/dropdown/package.json +0 -368
  21. package/src/vendor/bootstrap-vue/src/components/form/README.md +0 -365
  22. package/src/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.spec.js +0 -170
  23. package/src/vendor/bootstrap-vue/src/components/form/form-text.spec.js +0 -93
  24. package/src/vendor/bootstrap-vue/src/components/form/form-valid-feedback.spec.js +0 -157
  25. package/src/vendor/bootstrap-vue/src/components/form/form.spec.js +0 -97
  26. package/src/vendor/bootstrap-vue/src/components/form/package.json +0 -112
  27. package/src/vendor/bootstrap-vue/src/components/form-checkbox/README.md +0 -691
  28. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox-group.spec.js +0 -525
  29. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox.spec.js +0 -922
  30. package/src/vendor/bootstrap-vue/src/components/form-checkbox/package.json +0 -172
  31. package/src/vendor/bootstrap-vue/src/components/form-group/README.md +0 -339
  32. package/src/vendor/bootstrap-vue/src/components/form-group/form-group.spec.js +0 -477
  33. package/src/vendor/bootstrap-vue/src/components/form-group/package.json +0 -183
  34. package/src/vendor/bootstrap-vue/src/components/form-radio/README.md +0 -437
  35. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio-group.spec.js +0 -357
  36. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio.spec.js +0 -587
  37. package/src/vendor/bootstrap-vue/src/components/form-radio/package.json +0 -162
  38. package/src/vendor/bootstrap-vue/src/components/form-select/README.md +0 -504
  39. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.spec.js +0 -138
  40. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option.spec.js +0 -75
  41. package/src/vendor/bootstrap-vue/src/components/form-select/form-select.spec.js +0 -723
  42. package/src/vendor/bootstrap-vue/src/components/form-select/package.json +0 -132
  43. package/src/vendor/bootstrap-vue/src/components/form-textarea/README.md +0 -453
  44. package/src/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.spec.js +0 -1000
  45. package/src/vendor/bootstrap-vue/src/components/form-textarea/package.json +0 -122
  46. package/src/vendor/bootstrap-vue/src/components/layout/README.md +0 -791
  47. package/src/vendor/bootstrap-vue/src/components/layout/col.spec.js +0 -192
  48. package/src/vendor/bootstrap-vue/src/components/layout/form-row.spec.js +0 -45
  49. package/src/vendor/bootstrap-vue/src/components/layout/package.json +0 -99
  50. package/src/vendor/bootstrap-vue/src/components/link/README.md +0 -76
  51. package/src/vendor/bootstrap-vue/src/components/link/link.spec.js +0 -434
  52. package/src/vendor/bootstrap-vue/src/components/link/package.json +0 -57
  53. package/src/vendor/bootstrap-vue/src/components/modal/MODIFICATIONS.md +0 -30
  54. package/src/vendor/bootstrap-vue/src/components/modal/README.md +0 -1067
  55. package/src/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.spec.js +0 -82
  56. package/src/vendor/bootstrap-vue/src/components/modal/modal.spec.js +0 -1418
  57. package/src/vendor/bootstrap-vue/src/components/modal/package.json +0 -544
  58. package/src/vendor/bootstrap-vue/src/components/nav/README.md +0 -362
  59. package/src/vendor/bootstrap-vue/src/components/nav/nav-item.spec.js +0 -127
  60. package/src/vendor/bootstrap-vue/src/components/nav/nav.spec.js +0 -177
  61. package/src/vendor/bootstrap-vue/src/components/nav/package.json +0 -73
  62. package/src/vendor/bootstrap-vue/src/components/popover/README.md +0 -919
  63. package/src/vendor/bootstrap-vue/src/components/popover/package.json +0 -261
  64. package/src/vendor/bootstrap-vue/src/components/popover/popover.spec.js +0 -198
  65. package/src/vendor/bootstrap-vue/src/components/table/README.md +0 -3157
  66. package/src/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.spec.js +0 -112
  67. package/src/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.spec.js +0 -93
  68. package/src/vendor/bootstrap-vue/src/components/table/package.json +0 -1763
  69. package/src/vendor/bootstrap-vue/src/components/table/table-busy.spec.js +0 -150
  70. package/src/vendor/bootstrap-vue/src/components/table/table-caption.spec.js +0 -176
  71. package/src/vendor/bootstrap-vue/src/components/table/table-colgroup.spec.js +0 -81
  72. package/src/vendor/bootstrap-vue/src/components/table/table-filtering.spec.js +0 -409
  73. package/src/vendor/bootstrap-vue/src/components/table/table-item-formatter.spec.js +0 -56
  74. package/src/vendor/bootstrap-vue/src/components/table/table-lite.spec.js +0 -682
  75. package/src/vendor/bootstrap-vue/src/components/table/table-pagination.spec.js +0 -133
  76. package/src/vendor/bootstrap-vue/src/components/table/table-primarykey.spec.js +0 -83
  77. package/src/vendor/bootstrap-vue/src/components/table/table-provider.spec.js +0 -411
  78. package/src/vendor/bootstrap-vue/src/components/table/table-row-details.spec.js +0 -459
  79. package/src/vendor/bootstrap-vue/src/components/table/table-selectable.spec.js +0 -1182
  80. package/src/vendor/bootstrap-vue/src/components/table/table-simple.spec.js +0 -206
  81. package/src/vendor/bootstrap-vue/src/components/table/table-sorting.spec.js +0 -858
  82. package/src/vendor/bootstrap-vue/src/components/table/table-sticky-column.spec.js +0 -377
  83. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-bottom-row.spec.js +0 -94
  84. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-row-events.spec.js +0 -529
  85. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-top-row.spec.js +0 -88
  86. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-transition.spec.js +0 -83
  87. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-custom.spec.js +0 -91
  88. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-events.spec.js +0 -137
  89. package/src/vendor/bootstrap-vue/src/components/table/table-thead-events.spec.js +0 -155
  90. package/src/vendor/bootstrap-vue/src/components/table/table-thead-top.spec.js +0 -96
  91. package/src/vendor/bootstrap-vue/src/components/table/table.spec.js +0 -692
  92. package/src/vendor/bootstrap-vue/src/components/tabs/README.md +0 -433
  93. package/src/vendor/bootstrap-vue/src/components/tabs/package.json +0 -205
  94. package/src/vendor/bootstrap-vue/src/components/tabs/tab.spec.js +0 -330
  95. package/src/vendor/bootstrap-vue/src/components/tabs/tabs.spec.js +0 -778
  96. package/src/vendor/bootstrap-vue/src/components/toast/README.md +0 -655
  97. package/src/vendor/bootstrap-vue/src/components/toast/helpers/bv-toast.spec.js +0 -117
  98. package/src/vendor/bootstrap-vue/src/components/toast/package.json +0 -184
  99. package/src/vendor/bootstrap-vue/src/components/toast/toast.spec.js +0 -294
  100. package/src/vendor/bootstrap-vue/src/components/toast/toaster.spec.js +0 -77
  101. package/src/vendor/bootstrap-vue/src/components/tooltip/README.md +0 -559
  102. package/src/vendor/bootstrap-vue/src/components/tooltip/package.json +0 -258
  103. package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.spec.js +0 -1240
  104. package/src/vendor/bootstrap-vue/src/components/transition/package.json +0 -5
  105. package/src/vendor/bootstrap-vue/src/components/transporter/package.json +0 -5
  106. package/src/vendor/bootstrap-vue/src/components/transporter/transporter.spec.js +0 -85
  107. package/src/vendor/bootstrap-vue/src/directives/modal/modal.spec.js +0 -191
  108. package/src/vendor/bootstrap-vue/src/directives/tooltip/README.md +0 -521
  109. package/src/vendor/bootstrap-vue/src/directives/tooltip/package.json +0 -131
  110. package/src/vendor/bootstrap-vue/src/directives/tooltip/tooltip.spec.js +0 -190
  111. package/src/vendor/bootstrap-vue/src/directives/visible/README.md +0 -244
  112. package/src/vendor/bootstrap-vue/src/directives/visible/package.json +0 -24
  113. package/src/vendor/bootstrap-vue/src/mixins/attrs.spec.js +0 -194
  114. package/src/vendor/bootstrap-vue/src/mixins/click-out.spec.js +0 -52
  115. package/src/vendor/bootstrap-vue/src/mixins/focus-in.spec.js +0 -53
  116. package/src/vendor/bootstrap-vue/src/mixins/listen-on-document.spec.js +0 -117
  117. package/src/vendor/bootstrap-vue/src/mixins/listen-on-root.spec.js +0 -77
  118. package/src/vendor/bootstrap-vue/src/mixins/listen-on-window.spec.js +0 -115
  119. package/src/vendor/bootstrap-vue/src/mixins/listeners.spec.js +0 -245
  120. package/src/vendor/bootstrap-vue/src/utils/bv-event.class.spec.js +0 -66
  121. package/src/vendor/bootstrap-vue/src/utils/clone-deep.spec.js +0 -70
  122. package/src/vendor/bootstrap-vue/src/utils/config.spec.js +0 -169
  123. package/src/vendor/bootstrap-vue/src/utils/css-escape.spec.js +0 -82
  124. package/src/vendor/bootstrap-vue/src/utils/dom.spec.js +0 -291
  125. package/src/vendor/bootstrap-vue/src/utils/events.spec.js +0 -41
  126. package/src/vendor/bootstrap-vue/src/utils/get.spec.js +0 -109
  127. package/src/vendor/bootstrap-vue/src/utils/inspect.spec.js +0 -251
  128. package/src/vendor/bootstrap-vue/src/utils/loose-equal.spec.js +0 -203
  129. package/src/vendor/bootstrap-vue/src/utils/normalize-slot.spec.js +0 -63
  130. package/src/vendor/bootstrap-vue/src/utils/number.spec.js +0 -72
  131. package/src/vendor/bootstrap-vue/src/utils/object.spec.js +0 -61
  132. package/src/vendor/bootstrap-vue/src/utils/props.spec.js +0 -112
  133. package/src/vendor/bootstrap-vue/src/utils/router.spec.js +0 -248
  134. package/src/vendor/bootstrap-vue/src/utils/string.spec.js +0 -65
  135. package/src/vendor/bootstrap-vue/src/utils/stringify-object-values.spec.js +0 -47
  136. package/src/vendor/bootstrap-vue/src/utils/warn.spec.js +0 -54
@@ -1,109 +0,0 @@
1
- import { get } from './get'
2
-
3
- describe('get', () => {
4
- it('handles invalid values gracefully', async () => {
5
- expect(get(null, '')).toBe(null)
6
- expect(get({}, null)).toBe(null)
7
- expect(get({}, '')).toBe(null)
8
- expect(get({}, 'a')).toBe(null)
9
- expect(get({}, [])).toBe(null)
10
- expect(get({ a: 'b' }, 'b')).toBe(null)
11
- expect(get({ a: { c: 'd' } }, 'a.d')).toBe(null)
12
- })
13
-
14
- it('returns expected default value', async () => {
15
- expect(get(null, '')).toBe(null)
16
- expect(get({}, null, undefined)).toBe(null)
17
- expect(get({}, '', true)).toBe(true)
18
- expect(get({}, 'a', '')).toBe('')
19
- expect(get({}, [], 0)).toBe(0)
20
- expect(get({ a: 'b' }, 'b', {})).toEqual({})
21
- expect(get({ a: { c: 'd' } }, 'a.d', [])).toEqual([])
22
- expect(get({ a: { c: undefined } }, 'a.c')).toBe(null)
23
- expect(get({ a: 0, b: false }, 'c')).toBe(null)
24
- })
25
-
26
- it('returns expected value', async () => {
27
- const obj1 = { a: 'b' }
28
- const obj2 = { a: { b: { c: { d: 'e' } } } }
29
- const obj3 = { a: [{ b: 'c' }] }
30
- const obj4 = { a: [[{ b: 'c' }], [{ d: { e: ['f'] } }]] }
31
- const obj5 = { a: { b: 0, c: '', d: false } }
32
- const obj6 = { a: 0, b: false }
33
-
34
- expect(get(obj1, 'a')).toBe('b')
35
- expect(get(obj1, ['a'])).toBe('b')
36
- expect(get(obj2, 'a.b.c.d')).toBe('e')
37
- expect(get(obj2, ['a', 'b', 'c', 'd'])).toBe('e')
38
- expect(get(obj3, 'a[0].b')).toBe('c')
39
- expect(get(obj3, ['a', 0, 'b'])).toBe('c')
40
- expect(get(obj4, 'a[1][0].d.e[0]')).toBe('f')
41
- expect(get(obj4, ['a', 1, 0, 'd', 'e', 0])).toBe('f')
42
- expect(get(obj4, ['a[1]', 0, 'd', 'e[0]'])).toBe('f')
43
- expect(get(obj5, 'a.b')).toBe(0)
44
- expect(get(obj5, 'a.c')).toBe('')
45
- expect(get(obj5, 'a.d')).toBe(false)
46
- expect(get(obj6, 'a')).toBe(0)
47
- expect(get(obj6, 'b')).toBe(false)
48
- })
49
-
50
- it('handles when field name has dot', async () => {
51
- // https://github.com/bootstrap-vue/bootstrap-vue/issues/2762
52
- const obj1 = {
53
- 'a.b': 'foo',
54
- a: { b: 'fiz' },
55
- c: 'bar',
56
- d: { e: 'baz' },
57
- f: { 'g.h': 'faz' },
58
- 'i.j.k': 'fuz'
59
- }
60
- const obj2 = {
61
- a: { b: 'fiz' },
62
- c: 'bar',
63
- d: { e: 'baz' }
64
- }
65
-
66
- expect(get(obj1, 'a.b')).toBe('foo')
67
- expect(get(obj1, 'c')).toBe('bar')
68
- expect(get(obj1, 'd.e')).toBe('baz')
69
- expect(get(obj1, 'f.g.h', 'zzz')).toBe('zzz')
70
- expect(get(obj1, 'f.g.h')).toBe(null)
71
- expect(get(obj1, 'f.g', 'zzz')).toBe('zzz')
72
- expect(get(obj1, 'f.g')).toBe(null)
73
- expect(get(obj1, 'i.j.k')).toBe('fuz')
74
- expect(get(obj1, 'i.j', 'zzz')).toBe('zzz')
75
- expect(get(obj1, 'i.j')).toBe(null)
76
-
77
- expect(get({ a: 'b' }, '...', true)).toBe(true)
78
- expect(get({ a: 'b' }, '...')).toBe(null)
79
-
80
- expect(get(obj2, 'a.b')).toBe('fiz')
81
- expect(get(obj2, 'c')).toBe('bar')
82
- expect(get(obj2, 'd.e')).toBe('baz')
83
- })
84
-
85
- it('handles when field value is not array or object', async () => {
86
- // https://github.com/bootstrap-vue/bootstrap-vue/issues/2807
87
- const obj1 = {
88
- a: { b: 'c' },
89
- b: [{ c: 'd' }],
90
- c: { d: { e: 'f' } },
91
- d: [{ e: [{ f: 'g' }] }]
92
- }
93
- const obj2 = {
94
- a: null,
95
- b: undefined,
96
- c: 0,
97
- d: [null]
98
- }
99
-
100
- expect(get(obj1, 'a.b')).toBe('c')
101
- expect(get(obj2, 'a.b')).toBe(null)
102
- expect(get(obj1, 'b[0].c')).toBe('d')
103
- expect(get(obj2, 'b[0].c')).toBe(null)
104
- expect(get(obj1, 'c.d.e')).toBe('f')
105
- expect(get(obj2, 'c.d.e')).toBe(null)
106
- expect(get(obj1, 'd[0].e[0].f')).toBe('g')
107
- expect(get(obj2, 'd[0].e[0].f')).toBe(null)
108
- })
109
- })
@@ -1,251 +0,0 @@
1
- import {
2
- toType,
3
- toRawType,
4
- toRawTypeLC,
5
- isUndefined,
6
- isNull,
7
- isUndefinedOrNull,
8
- isFunction,
9
- isBoolean,
10
- isString,
11
- isNumber,
12
- isNumeric,
13
- isPrimitive,
14
- isDate,
15
- isEvent,
16
- isRegExp,
17
- isPromise
18
- } from './inspect'
19
-
20
- describe('utils/inspect', () => {
21
- it('toType()', async () => {
22
- expect(toType(123)).toEqual('number')
23
- expect(toType('123')).toEqual('string')
24
- expect(toType(true)).toEqual('boolean')
25
- expect(toType({})).toEqual('object')
26
- expect(toType([])).toEqual('object')
27
- expect(toType(/abc/)).toEqual('object')
28
- expect(toType(() => {})).toEqual('function')
29
- expect(toType(Date)).toEqual('function')
30
- expect(toType(new Date())).toEqual('object')
31
- expect(toType(undefined)).toEqual('undefined')
32
- expect(toType(null)).toEqual('object')
33
- })
34
-
35
- it('toRawType()', async () => {
36
- expect(toRawType(123)).toEqual('Number')
37
- expect(toRawType('123')).toEqual('String')
38
- expect(toRawType(true)).toEqual('Boolean')
39
- expect(toRawType({})).toEqual('Object')
40
- expect(toRawType([])).toEqual('Array')
41
- expect(toRawType(/abc/)).toEqual('RegExp')
42
- expect(toRawType(() => {})).toEqual('Function')
43
- expect(toRawType(Date)).toEqual('Function')
44
- expect(toRawType(new Date())).toEqual('Date')
45
- expect(toRawType(undefined)).toEqual('Undefined')
46
- expect(toRawType(null)).toEqual('Null')
47
- })
48
-
49
- it('toRawTypeLC()', async () => {
50
- expect(toRawTypeLC(123)).toEqual('number')
51
- expect(toRawTypeLC('123')).toEqual('string')
52
- expect(toRawTypeLC(true)).toEqual('boolean')
53
- expect(toRawTypeLC({})).toEqual('object')
54
- expect(toRawTypeLC([])).toEqual('array')
55
- expect(toRawTypeLC(/abc/)).toEqual('regexp')
56
- expect(toRawTypeLC(() => {})).toEqual('function')
57
- expect(toRawTypeLC(Date)).toEqual('function')
58
- expect(toRawTypeLC(new Date())).toEqual('date')
59
- expect(toRawTypeLC(undefined)).toEqual('undefined')
60
- expect(toRawTypeLC(null)).toEqual('null')
61
- })
62
-
63
- it('isUndefined()', async () => {
64
- expect(isUndefined(123)).toEqual(false)
65
- expect(isUndefined('123')).toEqual(false)
66
- expect(isUndefined(true)).toEqual(false)
67
- expect(isUndefined({})).toEqual(false)
68
- expect(isUndefined([])).toEqual(false)
69
- expect(isUndefined(/abc/)).toEqual(false)
70
- expect(isUndefined(() => {})).toEqual(false)
71
- expect(isUndefined(Date)).toEqual(false)
72
- expect(isUndefined(new Date())).toEqual(false)
73
- expect(isUndefined(undefined)).toEqual(true)
74
- expect(isUndefined(null)).toEqual(false)
75
- })
76
-
77
- it('isNull()', async () => {
78
- expect(isNull(123)).toEqual(false)
79
- expect(isNull('123')).toEqual(false)
80
- expect(isNull(true)).toEqual(false)
81
- expect(isNull({})).toEqual(false)
82
- expect(isNull([])).toEqual(false)
83
- expect(isNull(/abc/)).toEqual(false)
84
- expect(isNull(() => {})).toEqual(false)
85
- expect(isNull(Date)).toEqual(false)
86
- expect(isNull(new Date())).toEqual(false)
87
- expect(isNull(undefined)).toEqual(false)
88
- expect(isNull(null)).toEqual(true)
89
- })
90
-
91
- it('isUndefinedOrNull()', async () => {
92
- expect(isUndefinedOrNull(123)).toEqual(false)
93
- expect(isUndefinedOrNull('123')).toEqual(false)
94
- expect(isUndefinedOrNull(true)).toEqual(false)
95
- expect(isUndefinedOrNull({})).toEqual(false)
96
- expect(isUndefinedOrNull([])).toEqual(false)
97
- expect(isUndefinedOrNull(/abc/)).toEqual(false)
98
- expect(isUndefinedOrNull(() => {})).toEqual(false)
99
- expect(isUndefinedOrNull(Date)).toEqual(false)
100
- expect(isUndefinedOrNull(new Date())).toEqual(false)
101
- expect(isUndefinedOrNull(undefined)).toEqual(true)
102
- expect(isUndefinedOrNull(null)).toEqual(true)
103
- })
104
-
105
- it('isFunction()', async () => {
106
- expect(isFunction(123)).toEqual(false)
107
- expect(isFunction('123')).toEqual(false)
108
- expect(isFunction(true)).toEqual(false)
109
- expect(isFunction({})).toEqual(false)
110
- expect(isFunction([])).toEqual(false)
111
- expect(isFunction(/abc/)).toEqual(false)
112
- expect(isFunction(() => {})).toEqual(true)
113
- expect(isFunction(Date)).toEqual(true)
114
- expect(isFunction(new Date())).toEqual(false)
115
- expect(isFunction(undefined)).toEqual(false)
116
- expect(isFunction(null)).toEqual(false)
117
- })
118
-
119
- it('isBoolean()', async () => {
120
- expect(isBoolean(123)).toEqual(false)
121
- expect(isBoolean('123')).toEqual(false)
122
- expect(isBoolean(true)).toEqual(true)
123
- expect(isBoolean({})).toEqual(false)
124
- expect(isBoolean([])).toEqual(false)
125
- expect(isBoolean(/abc/)).toEqual(false)
126
- expect(isBoolean(() => {})).toEqual(false)
127
- expect(isBoolean(Date)).toEqual(false)
128
- expect(isBoolean(new Date())).toEqual(false)
129
- expect(isBoolean(undefined)).toEqual(false)
130
- expect(isBoolean(null)).toEqual(false)
131
- })
132
-
133
- it('isString()', async () => {
134
- expect(isString(123)).toEqual(false)
135
- expect(isString('123')).toEqual(true)
136
- expect(isString(true)).toEqual(false)
137
- expect(isString({})).toEqual(false)
138
- expect(isString([])).toEqual(false)
139
- expect(isString(/abc/)).toEqual(false)
140
- expect(isString(() => {})).toEqual(false)
141
- expect(isString(Date)).toEqual(false)
142
- expect(isString(new Date())).toEqual(false)
143
- expect(isString(undefined)).toEqual(false)
144
- expect(isString(null)).toEqual(false)
145
- })
146
-
147
- it('isNumber()', async () => {
148
- expect(isNumber(123)).toEqual(true)
149
- expect(isNumber(123.5)).toEqual(true)
150
- expect(isNumber('123')).toEqual(false)
151
- expect(isNumber(true)).toEqual(false)
152
- expect(isNumber({})).toEqual(false)
153
- expect(isNumber([])).toEqual(false)
154
- expect(isNumber(/abc/)).toEqual(false)
155
- expect(isNumber(() => {})).toEqual(false)
156
- expect(isNumber(Date)).toEqual(false)
157
- expect(isNumber(new Date())).toEqual(false)
158
- expect(isNumber(undefined)).toEqual(false)
159
- expect(isNumber(null)).toEqual(false)
160
- })
161
-
162
- it('isNumeric()', async () => {
163
- expect(isNumeric(123)).toEqual(true)
164
- expect(isNumeric(123.5)).toEqual(true)
165
- expect(isNumeric('123')).toEqual(true)
166
- expect(isNumeric('123.5')).toEqual(true)
167
- expect(isNumeric('123,5')).toEqual(false)
168
- expect(isNumeric(true)).toEqual(false)
169
- expect(isNumeric({})).toEqual(false)
170
- expect(isNumeric([])).toEqual(false)
171
- expect(isNumeric(/abc/)).toEqual(false)
172
- expect(isNumeric(() => {})).toEqual(false)
173
- expect(isNumeric(Date)).toEqual(false)
174
- expect(isNumeric(new Date())).toEqual(false)
175
- expect(isNumeric(undefined)).toEqual(false)
176
- expect(isNumeric(null)).toEqual(false)
177
- })
178
-
179
- it('isPrimitive()', async () => {
180
- expect(isPrimitive(123)).toEqual(true)
181
- expect(isPrimitive('123')).toEqual(true)
182
- expect(isPrimitive(true)).toEqual(true)
183
- expect(isPrimitive({})).toEqual(false)
184
- expect(isPrimitive([])).toEqual(false)
185
- expect(isPrimitive(/abc/)).toEqual(false)
186
- expect(isPrimitive(() => {})).toEqual(false)
187
- expect(isPrimitive(Date)).toEqual(false)
188
- expect(isPrimitive(new Date())).toEqual(false)
189
- expect(isPrimitive(undefined)).toEqual(false)
190
- expect(isPrimitive(null)).toEqual(false)
191
- })
192
-
193
- it('isDate()', async () => {
194
- expect(isDate(123)).toEqual(false)
195
- expect(isDate('123')).toEqual(false)
196
- expect(isDate(true)).toEqual(false)
197
- expect(isDate({})).toEqual(false)
198
- expect(isDate([])).toEqual(false)
199
- expect(isDate(/abc/)).toEqual(false)
200
- expect(isDate(() => {})).toEqual(false)
201
- expect(isDate(Date)).toEqual(false)
202
- expect(isDate(new Date())).toEqual(true)
203
- expect(isDate(undefined)).toEqual(false)
204
- expect(isDate(null)).toEqual(false)
205
- })
206
-
207
- it('isEvent()', async () => {
208
- expect(isEvent(123)).toEqual(false)
209
- expect(isEvent('123')).toEqual(false)
210
- expect(isEvent(true)).toEqual(false)
211
- expect(isEvent({})).toEqual(false)
212
- expect(isEvent([])).toEqual(false)
213
- expect(isEvent(/abc/)).toEqual(false)
214
- expect(isEvent(() => {})).toEqual(false)
215
- expect(isEvent(Date)).toEqual(false)
216
- expect(isEvent(new Date())).toEqual(false)
217
- expect(isEvent(Event)).toEqual(false)
218
- expect(isEvent(new Event('click'))).toEqual(true)
219
- expect(isEvent(undefined)).toEqual(false)
220
- expect(isEvent(null)).toEqual(false)
221
- })
222
-
223
- it('isRegExp()', async () => {
224
- expect(isRegExp(123)).toEqual(false)
225
- expect(isRegExp('123')).toEqual(false)
226
- expect(isRegExp(true)).toEqual(false)
227
- expect(isRegExp({})).toEqual(false)
228
- expect(isRegExp([])).toEqual(false)
229
- expect(isRegExp(/abc/)).toEqual(true)
230
- expect(isRegExp(() => {})).toEqual(false)
231
- expect(isRegExp(Date)).toEqual(false)
232
- expect(isRegExp(new Date())).toEqual(false)
233
- expect(isRegExp(undefined)).toEqual(false)
234
- expect(isRegExp(null)).toEqual(false)
235
- })
236
-
237
- it('isPromise()', async () => {
238
- expect(isPromise(123)).toEqual(false)
239
- expect(isPromise('123')).toEqual(false)
240
- expect(isPromise(true)).toEqual(false)
241
- expect(isPromise({})).toEqual(false)
242
- expect(isPromise([])).toEqual(false)
243
- expect(isPromise(/abc/)).toEqual(false)
244
- expect(isPromise(() => {})).toEqual(false)
245
- expect(isPromise(Date)).toEqual(false)
246
- expect(isPromise(new Date())).toEqual(false)
247
- expect(isPromise(undefined)).toEqual(false)
248
- expect(isPromise(null)).toEqual(false)
249
- expect(isPromise({ then() {}, catch() {} })).toEqual(true)
250
- })
251
- })
@@ -1,203 +0,0 @@
1
- import { looseEqual } from './loose-equal'
2
-
3
- describe('utils/looseEqual', () => {
4
- it('compares booleans correctly', () => {
5
- expect(looseEqual(true, true)).toBe(true)
6
- expect(looseEqual(false, false)).toBe(true)
7
- expect(looseEqual(true, false)).toBe(false)
8
- expect(looseEqual(true, true)).toBe(true)
9
- expect(looseEqual(true, 1)).toBe(false)
10
- expect(looseEqual(false, 0)).toBe(false)
11
- })
12
-
13
- it('compares strings correctly', () => {
14
- const text = 'Lorem ipsum'
15
- const number = 1
16
- const bool = true
17
-
18
- expect(looseEqual(text, text)).toBe(true)
19
- expect(looseEqual(text, text.slice(0, -1))).toBe(false)
20
- expect(looseEqual(String(number), number)).toBe(true)
21
- expect(looseEqual(String(bool), bool)).toBe(true)
22
- })
23
-
24
- it('compares numbers correctly', () => {
25
- const number = 100
26
- const decimal = 2.5
27
- const multiplier = 1.0000001
28
-
29
- expect(looseEqual(number, number)).toBe(true)
30
- expect(looseEqual(number, number - 1)).toBe(false)
31
- expect(looseEqual(decimal, decimal)).toBe(true)
32
- expect(looseEqual(decimal, decimal * multiplier)).toBe(false)
33
- expect(looseEqual(number, number * multiplier)).toBe(false)
34
- expect(looseEqual(multiplier, multiplier)).toBe(true)
35
- })
36
-
37
- it('compares dates correctly', () => {
38
- const date1 = new Date(2020, 1, 2, 3, 4, 5, 6)
39
- const date2 = new Date(2020, 1, 2, 3, 4, 5, 6)
40
- const date3 = new Date(2020, 1, 2, 3, 4, 5, 7)
41
- const date4 = new Date(2219, 1, 2, 3, 4, 5, 6)
42
-
43
- // Identical date object references
44
- expect(looseEqual(date1, date1)).toBe(true)
45
- // Different date references with identical values
46
- expect(looseEqual(date1, date2)).toBe(true)
47
- // Dates with slightly different time (ms)
48
- expect(looseEqual(date1, date3)).toBe(false)
49
- // Dates with different year
50
- expect(looseEqual(date1, date4)).toBe(false)
51
- })
52
-
53
- it('compares files correctly', () => {
54
- const date1 = new Date(2020, 1, 2, 3, 4, 5, 6)
55
- const date2 = new Date(2020, 1, 2, 3, 4, 5, 7)
56
- const file1 = new File([''], 'filename.txt', { type: 'text/plain', lastModified: date1 })
57
- const file2 = new File([''], 'filename.txt', { type: 'text/plain', lastModified: date1 })
58
- const file3 = new File([''], 'filename.txt', { type: 'text/plain', lastModified: date2 })
59
- const file4 = new File([''], 'filename.csv', { type: 'text/csv', lastModified: date1 })
60
- const file5 = new File(['abcdef'], 'filename.txt', { type: 'text/plain', lastModified: date1 })
61
- const file6 = new File(['12345'], 'filename.txt', { type: 'text/plain', lastModified: date1 })
62
-
63
- // Identical file object references
64
- expect(looseEqual(file1, file1)).toBe(true)
65
- // Different file references with identical values
66
- expect(looseEqual(file1, file2)).toBe(true)
67
- // Files with slightly different dates
68
- expect(looseEqual(file1, file3)).toBe(false)
69
- // Two different file types
70
- expect(looseEqual(file1, file4)).toBe(false)
71
- // Two files with same name, modified date, but different content
72
- expect(looseEqual(file5, file6)).toBe(false)
73
- })
74
-
75
- it('compares arrays correctly', () => {
76
- const arr1 = [1, 2, 3, 4]
77
- const arr2 = [1, 2, 3, '4']
78
- const arr3 = [1, 2, 3, 4, 5]
79
- const arr4 = [1, 2, 3, 4, { a: 5 }]
80
-
81
- // Identical array references
82
- expect(looseEqual(arr1, arr1)).toBe(true)
83
- // Different array references with identical values
84
- expect(looseEqual(arr1, arr1.slice())).toBe(true)
85
- expect(looseEqual(arr4, arr4.slice())).toBe(true)
86
- // Array with one value different (loose)
87
- expect(looseEqual(arr1, arr2)).toBe(true)
88
- // Array with one value different
89
- expect(looseEqual(arr3, arr4)).toBe(false)
90
- // Arrays with different lengths
91
- expect(looseEqual(arr1, arr3)).toBe(false)
92
- // Arrays with values in different order
93
- expect(looseEqual(arr1, arr1.slice().reverse())).toBe(false)
94
- })
95
-
96
- it('compares RegExp correctly', () => {
97
- const rx1 = /^foo$/
98
- const rx2 = /^foo$/
99
- const rx3 = /^bar$/
100
- const rx4 = /^bar$/i
101
-
102
- // Identical regex references
103
- expect(looseEqual(rx1, rx1)).toBe(true)
104
- // Different regex references with identical values
105
- expect(looseEqual(rx1, rx2)).toBe(true)
106
- // Different regex
107
- expect(looseEqual(rx1, rx3)).toBe(false)
108
- // Same regex with different options
109
- expect(looseEqual(rx3, rx4)).toBe(false)
110
- })
111
-
112
- it('compares objects correctly', () => {
113
- const obj1 = { foo: 'bar' }
114
- const obj2 = { foo: 'bar1' }
115
- const obj3 = { a: 1, b: 2, c: 3 }
116
- const obj4 = { b: 2, c: 3, a: 1 }
117
- const obj5 = { ...obj4, z: 999 }
118
- const nestedObj1 = { ...obj1, bar: [{ ...obj1 }, { ...obj1 }] }
119
- const nestedObj2 = { ...obj1, bar: [{ ...obj1 }, { ...obj2 }] }
120
-
121
- // Identical object references
122
- expect(looseEqual(obj1, obj1)).toBe(true)
123
- // Two objects with identical keys/values
124
- expect(looseEqual(obj1, { ...obj1 })).toBe(true)
125
- // Different key values
126
- expect(looseEqual(obj1, obj2)).toBe(false)
127
- // Keys in different orders
128
- expect(looseEqual(obj3, obj4)).toBe(true)
129
- // One object has additional key
130
- expect(looseEqual(obj4, obj5)).toBe(false)
131
- // Identical object references with nested array
132
- expect(looseEqual(nestedObj1, nestedObj1)).toBe(true)
133
- // Identical object definitions with nested array
134
- expect(looseEqual(nestedObj1, { ...nestedObj1 })).toBe(true)
135
- // Object definitions with nested array (which has different order)
136
- expect(looseEqual(nestedObj1, nestedObj2)).toBe(false)
137
- })
138
-
139
- it('compares different types correctly', () => {
140
- const obj1 = {}
141
- const obj2 = { a: 1 }
142
- const obj3 = { 0: 0, 1: 1, 2: 2 }
143
- const arr1 = []
144
- const arr2 = [1]
145
- const arr3 = [0, 1, 2]
146
- const date1 = new Date(2020, 1, 2, 3, 4, 5, 6)
147
- const file1 = new File([''], 'filename.txt', { type: 'text/plain', lastModified: date1 })
148
-
149
- expect(looseEqual(123, '123')).toBe(true)
150
- expect(looseEqual(123, new Date(123))).toBe(false)
151
- expect(looseEqual(`123`, new Date(123))).toBe(false)
152
- expect(looseEqual([1, 2, 3], '1,2,3')).toBe(false)
153
- expect(looseEqual(obj1, arr1)).toBe(false)
154
- expect(looseEqual(obj2, arr2)).toBe(false)
155
- expect(looseEqual(obj1, '[object Object]')).toBe(false)
156
- expect(looseEqual(arr1, '[object Array]')).toBe(false)
157
- expect(looseEqual(obj1, date1)).toBe(false)
158
- expect(looseEqual(obj2, date1)).toBe(false)
159
- expect(looseEqual(arr1, date1)).toBe(false)
160
- expect(looseEqual(arr2, date1)).toBe(false)
161
- expect(looseEqual(obj2, file1)).toBe(false)
162
- expect(looseEqual(arr2, file1)).toBe(false)
163
- expect(looseEqual(date1, file1)).toBe(false)
164
- // Special case where an object's keys are the same as keys (indexes) of an array
165
- expect(looseEqual(obj3, arr3)).toBe(false)
166
- })
167
-
168
- it('compares null and undefined values correctly', () => {
169
- expect(looseEqual(null, null)).toBe(true)
170
- expect(looseEqual(undefined, undefined)).toBe(true)
171
- // eslint-disable-next-line no-void
172
- expect(looseEqual(void 0, undefined)).toBe(true)
173
- expect(looseEqual(null, undefined)).toBe(false)
174
- // eslint-disable-next-line no-void
175
- expect(looseEqual(null, void 0)).toBe(false)
176
- expect(looseEqual(null, '')).toBe(false)
177
- expect(looseEqual(null, false)).toBe(false)
178
- expect(looseEqual(undefined, false)).toBe(false)
179
- })
180
-
181
- it('compares sparse arrays correctly', () => {
182
- // The following arrays all have a length of 3
183
- // But the first two are "sparse"
184
- const arr1 = []
185
- arr1[2] = true
186
- const arr2 = []
187
- arr2[2] = true
188
- const arr3 = [false, false, true]
189
- const arr4 = [undefined, undefined, true]
190
- // This one is also sparse (missing index 1)
191
- const arr5 = []
192
- arr5[0] = arr5[2] = true
193
-
194
- expect(looseEqual(arr1, arr2)).toBe(true)
195
- expect(looseEqual(arr2, arr1)).toBe(true)
196
- expect(looseEqual(arr1, arr3)).toBe(false)
197
- expect(looseEqual(arr3, arr1)).toBe(false)
198
- expect(looseEqual(arr1, arr4)).toBe(true)
199
- expect(looseEqual(arr4, arr1)).toBe(true)
200
- expect(looseEqual(arr1, arr5)).toBe(false)
201
- expect(looseEqual(arr5, arr1)).toBe(false)
202
- })
203
- })
@@ -1,63 +0,0 @@
1
- import { normalizeSlot } from './normalize-slot'
2
-
3
- describe('utils/normalizeSlot', () => {
4
- it('works', async () => {
5
- const $scoped = {
6
- default(slotScope) {
7
- return 'foo' + (slotScope.a || '')
8
- }
9
- }
10
- const $slots = {
11
- default: 'bar'
12
- }
13
- expect(typeof normalizeSlot).toBe('function')
14
-
15
- // Prefers scopedSlots over slots
16
- let result = normalizeSlot('default', {}, $scoped, $slots)
17
- expect(result).toBe('foo')
18
-
19
- // Passes slot scope to scopedSlot
20
- result = normalizeSlot('default', { a: ' foo' }, $scoped, $slots)
21
- expect(result).toBe('foo foo')
22
-
23
- // Uses named slot if scopedSlot not found
24
- result = normalizeSlot('default', {}, {}, $slots)
25
- expect(result).toBe('bar')
26
-
27
- // Works if only named slot found
28
- result = normalizeSlot('default', { a: ' foo' }, {}, $slots)
29
- expect(result).toBe('bar')
30
-
31
- // Works if only named slot found and scopedSlots is undef
32
- result = normalizeSlot('default', { a: ' foo' }, undefined, $slots)
33
- expect(result).toBe('bar')
34
-
35
- // Works if only scoped slot found
36
- result = normalizeSlot('default', { a: ' bar' }, $scoped, {})
37
- expect(result).toBe('foo bar')
38
-
39
- // Works if only scoped slot found and scoped is undef
40
- result = normalizeSlot('default', { a: ' bar' }, $scoped, undefined)
41
- expect(result).toBe('foo bar')
42
-
43
- // Returns undefined if slot name not found
44
- result = normalizeSlot('default', {}, {}, {})
45
- expect(result).toBeUndefined()
46
-
47
- // Returns undefined if slot name not found
48
- result = normalizeSlot('baz', {}, $scoped, $slots)
49
- expect(result).toBeUndefined()
50
-
51
- // Works with array (named slot)
52
- result = normalizeSlot(['none', 'default'], { a: ' foo' }, undefined, $slots)
53
- expect(result).toBe('bar')
54
-
55
- // Works with arrays (scoped slot)
56
- result = normalizeSlot(['none', 'default'], { a: ' bar' }, $scoped, {})
57
- expect(result).toBe('foo bar')
58
-
59
- // Returns undefined if slot name not found with array
60
- result = normalizeSlot(['baz', 'bar'], {}, $scoped, $slots)
61
- expect(result).toBeUndefined()
62
- })
63
- })