@based/schema 1.3.2 → 2.1.0

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 (71) hide show
  1. package/dist/set/fields/string.d.ts.map +1 -1
  2. package/dist/set/fields/string.js +3 -1
  3. package/dist/set/fields/string.js.map +1 -1
  4. package/dist/set/index.d.ts.map +1 -1
  5. package/dist/set/index.js +3 -1
  6. package/dist/set/index.js.map +1 -1
  7. package/dist/types.d.ts +5 -2
  8. package/dist/types.d.ts.map +1 -1
  9. package/dist/types.js +17 -1
  10. package/dist/types.js.map +1 -1
  11. package/dist/updateSchema.js +1 -1
  12. package/dist/updateSchema.js.map +1 -1
  13. package/dist/validateSchema.d.ts.map +1 -1
  14. package/dist/validateSchema.js +5 -2
  15. package/dist/validateSchema.js.map +1 -1
  16. package/package.json +1 -1
  17. package/dist/set/collections.d.ts +0 -5
  18. package/dist/set/collections.js +0 -211
  19. package/dist/set/collections.js.map +0 -1
  20. package/dist/set/error.d.ts +0 -15
  21. package/dist/set/error.js +0 -24
  22. package/dist/set/error.js.map +0 -1
  23. package/dist/set/number.d.ts +0 -4
  24. package/dist/set/number.js +0 -111
  25. package/dist/set/number.js.map +0 -1
  26. package/dist/set/parseDefaultAndValue.d.ts +0 -3
  27. package/dist/set/parseDefaultAndValue.js +0 -33
  28. package/dist/set/parseDefaultAndValue.js.map +0 -1
  29. package/dist/set/parsers.d.ts +0 -3
  30. package/dist/set/parsers.js +0 -42
  31. package/dist/set/parsers.js.map +0 -1
  32. package/dist/set/references.d.ts +0 -3
  33. package/dist/set/references.js +0 -77
  34. package/dist/set/references.js.map +0 -1
  35. package/dist/set/rest.d.ts +0 -5
  36. package/dist/set/rest.js +0 -76
  37. package/dist/set/rest.js.map +0 -1
  38. package/dist/set/string.d.ts +0 -3
  39. package/dist/set/string.js +0 -173
  40. package/dist/set/string.js.map +0 -1
  41. package/src/error.ts +0 -19
  42. package/src/index.ts +0 -7
  43. package/src/languages.ts +0 -188
  44. package/src/set/fields/array.ts +0 -155
  45. package/src/set/fields/index.ts +0 -70
  46. package/src/set/fields/number.ts +0 -144
  47. package/src/set/fields/object.ts +0 -31
  48. package/src/set/fields/references.ts +0 -140
  49. package/src/set/fields/set.ts +0 -63
  50. package/src/set/fields/string.ts +0 -287
  51. package/src/set/index.ts +0 -182
  52. package/src/set/isValidId.ts +0 -23
  53. package/src/set/types.ts +0 -0
  54. package/src/types.ts +0 -361
  55. package/src/updateSchema.ts +0 -18
  56. package/src/validateSchema.ts +0 -61
  57. package/src/walker/args.ts +0 -209
  58. package/src/walker/index.ts +0 -48
  59. package/src/walker/parse.ts +0 -233
  60. package/src/walker/types.ts +0 -81
  61. package/test/array.ts +0 -388
  62. package/test/number.ts +0 -435
  63. package/test/reference.ts +0 -218
  64. package/test/rest.ts +0 -184
  65. package/test/set.ts +0 -103
  66. package/test/string.ts +0 -118
  67. package/test/text.ts +0 -342
  68. package/test/utils/index.ts +0 -23
  69. package/test/validateSchema.ts +0 -41
  70. package/test/walker.ts +0 -318
  71. package/tsconfig.json +0 -9
package/test/rest.ts DELETED
@@ -1,184 +0,0 @@
1
- import test from 'ava'
2
- import { BasedSchema, setWalker } from '../src/index'
3
- import { errorCollect, resultCollect } from './utils'
4
-
5
- const schema: BasedSchema = {
6
- types: {
7
- thing: {
8
- prefix: 'ti',
9
- fields: {
10
- priority: { type: 'number' },
11
- something: { type: 'string', format: 'strongPassword' },
12
- },
13
- },
14
- bla: {
15
- prefix: 'bl',
16
- fields: {
17
- enum: {
18
- enum: ['tony', 'jim'],
19
- },
20
- setOfNumbers: {
21
- type: 'set',
22
- items: {
23
- type: 'number',
24
- },
25
- },
26
- object: {
27
- type: 'object',
28
- properties: {
29
- flap: { type: 'boolean' },
30
- },
31
- },
32
- flap: {
33
- type: 'boolean',
34
- },
35
- x: {
36
- type: 'object',
37
- properties: {
38
- flap: {
39
- type: 'boolean',
40
- },
41
- },
42
- },
43
- record: {
44
- type: 'record',
45
- values: {
46
- type: 'object',
47
- properties: {
48
- bla: {
49
- type: 'array',
50
- values: {
51
- type: 'object',
52
- properties: {
53
- snux: {
54
- type: 'object',
55
- properties: {
56
- x: {
57
- type: 'number',
58
- },
59
- },
60
- },
61
- flap: { type: 'number' },
62
- },
63
- },
64
- },
65
- },
66
- },
67
- },
68
- bla: {
69
- type: 'set',
70
- items: { type: 'string', minLength: 3, maxLength: 6 },
71
- },
72
- },
73
- },
74
- },
75
- $defs: {},
76
- languages: ['en', 'de', 'nl', 'ro', 'za', 'ae'],
77
- root: {
78
- fields: {},
79
- },
80
- prefixToTypeMapping: {
81
- bl: 'bla',
82
- ti: 'thing',
83
- },
84
- }
85
-
86
- let r
87
-
88
- test('enum simple', async (t) => {
89
- r = await setWalker(schema, {
90
- $id: 'bl120',
91
- enum: 'tony',
92
- })
93
-
94
- t.true(r.errors.length === 0)
95
- t.deepEqual(resultCollect(r), [{ path: ['enum'], value: 0 }])
96
- })
97
-
98
- test('enum not exist error', async (t) => {
99
- r = await setWalker(schema, {
100
- $id: 'bl120',
101
- enum: 'kyle',
102
- })
103
- t.true(r.errors.length === 1)
104
- })
105
-
106
- test('default enum', async (t) => {
107
- r = await setWalker(schema, {
108
- $id: 'bl120',
109
- enum: { $default: 'tony' },
110
- })
111
- t.true(r.errors.length === 0)
112
- t.deepEqual(resultCollect(r), [{ path: ['enum'], value: { $default: 0 } }])
113
- })
114
-
115
- test('value enum ', async (t) => {
116
- r = await setWalker(schema, {
117
- $id: 'bl120',
118
- enum: { $value: 'tony' },
119
- })
120
-
121
- t.true(r.errors.length === 0)
122
- t.deepEqual(resultCollect(r), [{ path: ['enum'], value: 0 }])
123
- })
124
-
125
- test('value & default enum ', async (t) => {
126
- r = await setWalker(schema, {
127
- $id: 'bl120',
128
- enum: { $default: 'jim', $value: 'tony' },
129
- })
130
-
131
- t.true(r.errors.length === 2)
132
- })
133
-
134
- test('$value & $default enum ', async (t) => {
135
- r = await setWalker(schema, {
136
- $id: 'bl120',
137
- enum: { $value: { $default: 'tony' } },
138
- })
139
- t.true(r.errors.length === 0)
140
- t.deepEqual(resultCollect(r), [{ path: ['enum'], value: { $default: 0 } }])
141
- })
142
-
143
- test('default: value enum ', async (t) => {
144
- r = await setWalker(schema, {
145
- $id: 'bl120',
146
- enum: { $default: { $value: 'tony' } },
147
- })
148
- t.true(r.errors.length === 0)
149
- t.deepEqual(resultCollect(r), [{ path: ['enum'], value: { $default: 0 } }])
150
- })
151
-
152
- // ask about alias
153
- test('$alias ', async (t) => {
154
- r = await setWalker(schema, {
155
- $id: 'bl120',
156
- $alias: 'bla',
157
- })
158
-
159
- t.true(r.errors.length === 0)
160
- })
161
-
162
- test('$alias array', async (t) => {
163
- r = await setWalker(schema, {
164
- $id: 'bl120',
165
- $alias: ['bla'],
166
- })
167
-
168
- t.true(r.errors.length === 0)
169
- })
170
-
171
- test('object: boolean', async (t) => {
172
- r = await setWalker(schema, {
173
- $id: 'bl120',
174
- object: {
175
- flap: true,
176
- },
177
- })
178
-
179
- t.true(r.errors.length === 0)
180
- t.deepEqual(resultCollect(r), [
181
- { path: ['object', 'flap'], value: true },
182
- { path: ['object'], value: { flap: true } },
183
- ])
184
- })
package/test/set.ts DELETED
@@ -1,103 +0,0 @@
1
- import test from 'ava'
2
- import { BasedSchema, setWalker, walk } from '../src/index'
3
- import { wait } from '@saulx/utils'
4
- import { resultCollect } from './utils'
5
- let r
6
- const schema: BasedSchema = {
7
- types: {
8
- thing: {
9
- prefix: 'ti',
10
- fields: {
11
- something: { type: 'string', format: 'strongPassword' },
12
- },
13
- },
14
- bla: {
15
- prefix: 'bl',
16
- fields: {
17
- x: {
18
- type: 'object',
19
- properties: {
20
- bla: { type: 'string' },
21
- },
22
- },
23
- setOfNumbers: {
24
- type: 'set',
25
- items: {
26
- type: 'number',
27
- },
28
- },
29
- bla: {
30
- type: 'set',
31
- items: { type: 'string', minLength: 3, maxLength: 6 },
32
- },
33
- },
34
- },
35
- },
36
- $defs: {},
37
- languages: ['en', 'de', 'nl', 'ro', 'za', 'ae'],
38
- root: {
39
- fields: {},
40
- },
41
- prefixToTypeMapping: {
42
- bl: 'bla',
43
- ti: 'thing',
44
- },
45
- }
46
-
47
- test('simple setNum', async (t) => {
48
- r = await setWalker(schema, {
49
- $id: 'bl120',
50
- setOfNumbers: [1, 2, 3, 4, 5],
51
- })
52
-
53
- t.true(r.errors.length === 0)
54
- t.deepEqual(resultCollect(r), [
55
- { path: ['setOfNumbers'], value: { $value: [1, 2, 3, 4, 5] } },
56
- ])
57
- })
58
-
59
- test('default arr', async (t) => {
60
- r = await setWalker(schema, {
61
- $id: 'bl120',
62
- setOfNumbers: { $add: 20 },
63
- })
64
-
65
- t.true(r.errors.length === 0)
66
- t.deepEqual(resultCollect(r), [
67
- { path: ['setOfNumbers'], value: { $add: [20] } },
68
- ])
69
- })
70
-
71
- test('$merge on object', async (t) => {
72
- r = await setWalker(schema, {
73
- $id: 'bl120',
74
- x: {
75
- $merge: false,
76
- bla: 'x',
77
- },
78
- })
79
-
80
- t.true(r.errors.length === 0)
81
- t.deepEqual(resultCollect(r), [
82
- { path: ['x'], value: { $delete: true } },
83
-
84
- { path: ['x', 'bla'], value: 'x' },
85
-
86
- { path: ['x'], value: { $merge: false, bla: 'x' } },
87
- ])
88
- })
89
-
90
- test('$merge on set', async (t) => {
91
- r = await setWalker(schema, {
92
- $id: 'bl120',
93
- $merge: false,
94
- x: {
95
- bla: 'x',
96
- },
97
- })
98
- t.true(r.errors.length === 0)
99
- t.deepEqual(resultCollect(r), [
100
- { path: ['x', 'bla'], value: 'x' },
101
- { path: ['x'], value: { bla: 'x' } },
102
- ])
103
- })
package/test/string.ts DELETED
@@ -1,118 +0,0 @@
1
- import test from 'ava'
2
- import { BasedSchema, setWalker } from '../src/index'
3
- import { errorCollect, resultCollect } from './utils'
4
-
5
- const schema: BasedSchema = {
6
- types: {
7
- bla: {
8
- prefix: 'bl',
9
- fields: {
10
- name: {
11
- minLength: 3,
12
- maxLength: 6,
13
- type: 'string',
14
- },
15
- phonkName: {
16
- type: 'string',
17
- pattern: '\\${1,4}',
18
- },
19
- bla: {
20
- type: 'set',
21
- items: { type: 'string', minLength: 3, maxLength: 6 },
22
- },
23
- },
24
- },
25
- },
26
- $defs: {},
27
- languages: ['en'],
28
- root: {
29
- fields: {},
30
- },
31
- prefixToTypeMapping: {
32
- bl: 'bla',
33
- },
34
- }
35
-
36
- test('string max length', async (t) => {
37
- const err1 = await setWalker(schema, {
38
- $id: 'bl1',
39
- name: 'ax',
40
- })
41
-
42
- const err2 = await setWalker(schema, {
43
- $id: 'bl1',
44
- name: 'axaxaxax',
45
- })
46
- const res1 = await setWalker(schema, {
47
- $id: 'bl1',
48
- name: 'xaxx',
49
- })
50
-
51
- t.assert(errorCollect(err1, err2).length > 0)
52
- t.deepEqual(resultCollect(res1), [{ path: ['name'], value: 'xaxx' }])
53
- })
54
-
55
- //set parser
56
- test('set with strings', async (t) => {
57
- const err1 = await setWalker(schema, {
58
- $id: 'bl1',
59
- bla: ['ax', 'axa', 'axxxxa'],
60
- })
61
-
62
- const res1 = await setWalker(schema, {
63
- $id: 'bl1',
64
- bla: ['axx', 'axxxx', 'blaaa'],
65
- })
66
-
67
- t.assert(errorCollect(err1).length > 0)
68
- t.deepEqual(resultCollect(res1), [
69
- { path: ['bla'], value: { $value: ['axx', 'axxxx', 'blaaa'] } },
70
- ])
71
- })
72
-
73
- // this one causes weird array lenght issue in string max length test
74
- test('string pattern', async (t) => {
75
- const err1 = await setWalker(schema, {
76
- $id: 'bl1',
77
- phonkName: 'blabla',
78
- })
79
-
80
- const res1 = await setWalker(schema, {
81
- $id: 'bl1',
82
- phonkName: 'bla$',
83
- })
84
-
85
- t.assert(errorCollect(err1).length > 0)
86
- t.deepEqual(resultCollect(res1), [{ path: ['phonkName'], value: 'bla$' }])
87
- })
88
-
89
- test('setting $default', async (t) => {
90
- const err = await setWalker(schema, {
91
- $id: 'bl1',
92
- phonkName: { $default: 'blabla' },
93
- })
94
-
95
- t.assert(err.errors.length > 0)
96
-
97
- const res1 = await setWalker(schema, {
98
- $id: 'bl1',
99
- phonkName: { $default: 'bla$' },
100
- })
101
-
102
- t.deepEqual(resultCollect(res1), [
103
- { path: ['phonkName'], value: { $default: 'bla$' } },
104
- ])
105
- })
106
-
107
- test('setting $value', async (t) => {
108
- const err = await setWalker(schema, {
109
- $id: 'bl1',
110
- phonkName: { $value: 'blabla' },
111
- })
112
- t.is(err.errors.length, 1)
113
- const res1 = await setWalker(schema, {
114
- $id: 'bl1',
115
- phonkName: { $value: 'bla$' },
116
- })
117
- t.deepEqual(resultCollect(res1), [{ path: ['phonkName'], value: 'bla$' }])
118
- })