@creator.co/wapi 1.7.1-alpha3 → 1.7.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 (114) hide show
  1. package/.eslintignore +3 -0
  2. package/.eslintrc.cjs +60 -0
  3. package/.github/workflows/npmpublish.yml +11 -0
  4. package/.github/workflows/prs.yml +13 -0
  5. package/dist/package-lock.json +2 -2
  6. package/dist/package.json +1 -1
  7. package/jest.config.ts +33 -0
  8. package/jest.smoke.config.ts +35 -0
  9. package/package.json +1 -1
  10. package/tests/API/Request.test.ts +273 -0
  11. package/tests/API/Response.test.ts +367 -0
  12. package/tests/API/Utils.test.ts +167 -0
  13. package/tests/BaseEvent/EventProcessor.test.ts +261 -0
  14. package/tests/BaseEvent/Process.test.ts +49 -0
  15. package/tests/BaseEvent/Transaction.test.ts +408 -0
  16. package/tests/Cache/Redis-client.test.ts +90 -0
  17. package/tests/Cache/Redis-cluster.test.ts +100 -0
  18. package/tests/Config/Config.test.ts +205 -0
  19. package/tests/Config/EnvironmentVar.test.ts +250 -0
  20. package/tests/Crypto/Crypto.test.ts +88 -0
  21. package/tests/Crypto/JWT.test.ts +92 -0
  22. package/tests/Database/DatabaseManager.test.ts +71 -0
  23. package/tests/Database/integrations/knex/KnexDatabase.test.ts +76 -0
  24. package/tests/Database/integrations/knex/KnexTransaction.test.ts +149 -0
  25. package/tests/Database/integrations/kysely/KyselyDatabase.test.ts +113 -0
  26. package/tests/Database/integrations/kysely/KyselyTransaction.test.ts +119 -0
  27. package/tests/Database/integrations/pg/PostgresDatabase.test.ts +76 -0
  28. package/tests/Database/integrations/pg/PostgresTransaction.test.ts +118 -0
  29. package/tests/Logger/Logger.test.ts +219 -0
  30. package/tests/Mailer/Mailer.test.ts +59 -0
  31. package/tests/Publisher/Publisher.test.ts +94 -0
  32. package/tests/Server/RouteResolver.test.ts +102 -0
  33. package/tests/Server/Router.test.ts +39 -0
  34. package/tests/Server/lib/ContainerServer.test.ts +531 -0
  35. package/tests/Server/lib/Server.test.ts +12 -0
  36. package/tests/Server/lib/container/GenericHandler.test.ts +131 -0
  37. package/tests/Server/lib/container/GenericHandlerEvent.test.ts +103 -0
  38. package/tests/Server/lib/container/HealthHandler.test.ts +30 -0
  39. package/tests/Server/lib/container/Proxy.test.ts +268 -0
  40. package/tests/Server/lib/container/Utils.test.ts +47 -0
  41. package/tests/Test.utils.ts +74 -0
  42. package/tests/Validation/Validator.test.ts +76 -0
  43. package/tsconfig.json +26 -0
  44. package/tsconfig.smoke.json +26 -0
  45. package/coverage/clover.xml +0 -1088
  46. package/coverage/coverage/coverage.txt +0 -40
  47. package/coverage/coverage-final.json +0 -37
  48. package/coverage/coverage-summary.json +0 -38
  49. package/coverage/coverage.txt +0 -59
  50. package/coverage/lcov-report/base.css +0 -224
  51. package/coverage/lcov-report/block-navigation.js +0 -87
  52. package/coverage/lcov-report/favicon.png +0 -0
  53. package/coverage/lcov-report/index.html +0 -371
  54. package/coverage/lcov-report/prettify.css +0 -1
  55. package/coverage/lcov-report/prettify.js +0 -2
  56. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  57. package/coverage/lcov-report/sorter.js +0 -196
  58. package/coverage/lcov-report/src/API/Request.ts.html +0 -727
  59. package/coverage/lcov-report/src/API/Response.ts.html +0 -1189
  60. package/coverage/lcov-report/src/API/Utils.ts.html +0 -313
  61. package/coverage/lcov-report/src/API/index.html +0 -131
  62. package/coverage/lcov-report/src/BaseEvent/EventProcessor.ts.html +0 -496
  63. package/coverage/lcov-report/src/BaseEvent/Process.ts.html +0 -346
  64. package/coverage/lcov-report/src/BaseEvent/Transaction.ts.html +0 -1015
  65. package/coverage/lcov-report/src/BaseEvent/index.html +0 -146
  66. package/coverage/lcov-report/src/Cache/Redis.ts.html +0 -367
  67. package/coverage/lcov-report/src/Cache/index.html +0 -116
  68. package/coverage/lcov-report/src/Config/Configuration.ts.html +0 -700
  69. package/coverage/lcov-report/src/Config/EnvironmentVar.ts.html +0 -526
  70. package/coverage/lcov-report/src/Config/index.html +0 -131
  71. package/coverage/lcov-report/src/Crypto/Crypto.ts.html +0 -352
  72. package/coverage/lcov-report/src/Crypto/JWT.ts.html +0 -337
  73. package/coverage/lcov-report/src/Crypto/index.html +0 -131
  74. package/coverage/lcov-report/src/Database/Database.ts.html +0 -151
  75. package/coverage/lcov-report/src/Database/DatabaseManager.ts.html +0 -289
  76. package/coverage/lcov-report/src/Database/DatabaseTransaction.ts.html +0 -595
  77. package/coverage/lcov-report/src/Database/index.html +0 -161
  78. package/coverage/lcov-report/src/Database/index.ts.html +0 -169
  79. package/coverage/lcov-report/src/Database/integrations/knex/KnexDatabase.ts.html +0 -283
  80. package/coverage/lcov-report/src/Database/integrations/knex/KnexTransaction.ts.html +0 -337
  81. package/coverage/lcov-report/src/Database/integrations/knex/index.html +0 -131
  82. package/coverage/lcov-report/src/Database/integrations/kysely/KyselyDatabase.ts.html +0 -376
  83. package/coverage/lcov-report/src/Database/integrations/kysely/KyselyTransaction.ts.html +0 -601
  84. package/coverage/lcov-report/src/Database/integrations/kysely/index.html +0 -131
  85. package/coverage/lcov-report/src/Database/integrations/pgsql/PostgresDatabase.ts.html +0 -250
  86. package/coverage/lcov-report/src/Database/integrations/pgsql/PostgresTransaction.ts.html +0 -346
  87. package/coverage/lcov-report/src/Database/integrations/pgsql/index.html +0 -131
  88. package/coverage/lcov-report/src/Database/types.d.ts.html +0 -232
  89. package/coverage/lcov-report/src/Globals.ts.html +0 -394
  90. package/coverage/lcov-report/src/Logger/Logger.ts.html +0 -1138
  91. package/coverage/lcov-report/src/Logger/index.html +0 -116
  92. package/coverage/lcov-report/src/Mailer/Mailer.ts.html +0 -754
  93. package/coverage/lcov-report/src/Mailer/index.html +0 -116
  94. package/coverage/lcov-report/src/Publisher/Publisher.ts.html +0 -460
  95. package/coverage/lcov-report/src/Publisher/index.html +0 -116
  96. package/coverage/lcov-report/src/Server/RouteResolver.ts.html +0 -442
  97. package/coverage/lcov-report/src/Server/Router.ts.html +0 -616
  98. package/coverage/lcov-report/src/Server/index.html +0 -131
  99. package/coverage/lcov-report/src/Server/lib/ContainerServer.ts.html +0 -280
  100. package/coverage/lcov-report/src/Server/lib/Server.ts.html +0 -403
  101. package/coverage/lcov-report/src/Server/lib/container/GenericHandler.ts.html +0 -331
  102. package/coverage/lcov-report/src/Server/lib/container/GenericHandlerEvent.ts.html +0 -547
  103. package/coverage/lcov-report/src/Server/lib/container/HealthHandler.ts.html +0 -118
  104. package/coverage/lcov-report/src/Server/lib/container/Proxy.ts.html +0 -619
  105. package/coverage/lcov-report/src/Server/lib/container/Utils.ts.html +0 -184
  106. package/coverage/lcov-report/src/Server/lib/container/index.html +0 -176
  107. package/coverage/lcov-report/src/Server/lib/index.html +0 -131
  108. package/coverage/lcov-report/src/Util/AsyncSingleton.ts.html +0 -343
  109. package/coverage/lcov-report/src/Util/Utils.ts.html +0 -313
  110. package/coverage/lcov-report/src/Util/index.html +0 -131
  111. package/coverage/lcov-report/src/Validation/Validator.ts.html +0 -217
  112. package/coverage/lcov-report/src/Validation/index.html +0 -116
  113. package/coverage/lcov-report/src/index.html +0 -116
  114. package/coverage/lcov.info +0 -2326
@@ -0,0 +1,76 @@
1
+ import { expect } from 'chai'
2
+
3
+ import Response from '../../src/API/Response'
4
+ import Globals from '../../src/Globals'
5
+ import Validator from '../../src/Validation/Validator'
6
+ import { ViewSchema } from '../Test.utils'
7
+
8
+ function expectFullFailure(validationResult, c = 4) {
9
+ expect(validationResult).to.be.an.instanceof(Response)
10
+ if (validationResult instanceof Response) {
11
+ expect(validationResult.getBody()).is.not.null
12
+ expect(validationResult.getBody()).to.have.property('err', Globals.ErrorResponseValidationFail)
13
+ expect(validationResult.getBody()).to.have.property('errCode', Globals.ErrorCode_InvalidInput)
14
+ expect(validationResult.getBody()).to.have.property('validationFailure')
15
+ expect(validationResult.getBody()['validationFailure']).to.have.lengthOf(c)
16
+ expect(validationResult.getCode()).is.equals(400)
17
+ }
18
+ }
19
+
20
+ describe('Validates unsuccessfully', () => {
21
+ test('Fails to validate async', () => {
22
+ const validationResult = Validator.validateSchema(async () => {}, ViewSchema)
23
+ expectFullFailure(validationResult, 1)
24
+ })
25
+
26
+ test('Fails to validate null', () => {
27
+ const validationResult = Validator.validateSchema(null, ViewSchema)
28
+ expectFullFailure(validationResult, 1)
29
+ })
30
+
31
+ test('Fails to validate empty string', () => {
32
+ const validationResult = Validator.validateSchema('', ViewSchema)
33
+ expectFullFailure(validationResult, 1)
34
+ })
35
+
36
+ test('Fails to validate empty object', () => {
37
+ const validationResult = Validator.validateSchema({}, ViewSchema)
38
+ expectFullFailure(validationResult)
39
+ })
40
+
41
+ test('Fails to validate object with wrong keys', () => {
42
+ const validationResult = Validator.validateSchema({ name: 'Joe' }, ViewSchema)
43
+ expectFullFailure(validationResult)
44
+ })
45
+
46
+ test('Fails to validate object with wrong key types', () => {
47
+ const validationResult = Validator.validateSchema({ id: 123 }, ViewSchema)
48
+ expectFullFailure(validationResult)
49
+ if (validationResult instanceof Response) {
50
+ console.log(validationResult.getBody()['validationFailure'])
51
+ expect(
52
+ validationResult.getBody()['validationFailure'].filter(f => {
53
+ return f.message == 'Expected string, received number'
54
+ })
55
+ ).to.have.lengthOf(1)
56
+ }
57
+ })
58
+ })
59
+
60
+ describe('Validates successfully', () => {
61
+ test('Succeeds to validate', () => {
62
+ const validationResult = Validator.validateSchema(
63
+ {
64
+ id: '123',
65
+ content: '123',
66
+ createdAt: new Date(),
67
+ updatedAt: new Date(),
68
+ },
69
+ ViewSchema
70
+ )
71
+ expect(validationResult).to.not.be.an.instanceof(Response)
72
+ expect(validationResult).to.be.true
73
+ })
74
+ })
75
+
76
+ export {}
package/tsconfig.json ADDED
@@ -0,0 +1,26 @@
1
+ {
2
+ "exclude": ["**/*.test.*", "**/__mocks__/*", "**/__tests__/*", "**/tests/*", "./dist/**/*", "./smoke-tests/**/*", "./jest*", "./node_modules"],
3
+ "include": ["./**/*", "./package.json", "./package-lock.json"],
4
+ "compilerOptions": {
5
+ "lib": [
6
+ "es5",
7
+ "es6",
8
+ "dom"
9
+ ],
10
+ "module": "esnext",
11
+ "target": "es6",
12
+ "moduleResolution": "node",
13
+ "esModuleInterop": true,
14
+ "noImplicitAny": false,
15
+ "noEmitOnError": true,
16
+ "removeComments": false,
17
+ "downlevelIteration": true,
18
+ "resolveJsonModule": true,
19
+ "sourceMap": true,
20
+ "outDir": "dist",
21
+ "declaration": true,
22
+ "skipLibCheck": true,
23
+ "strictNullChecks": true,
24
+ "noErrorTruncation": true
25
+ }
26
+ }
@@ -0,0 +1,26 @@
1
+ {
2
+ "exclude": ["./dist/**/*", "./smoke-tests/**/*", "./node_modules", "./**/Logger.test.*"],
3
+ "include": ["./**/*", "./package.json", "./package-lock.json"],
4
+ "compilerOptions": {
5
+ "lib": [
6
+ "es5",
7
+ "es6",
8
+ "dom"
9
+ ],
10
+ "module": "esnext",
11
+ "target": "es6",
12
+ "moduleResolution": "node",
13
+ "noImplicitAny": false,
14
+ "noEmitOnError": true,
15
+ "removeComments": false,
16
+ "downlevelIteration": true,
17
+ "resolveJsonModule": true,
18
+ "sourceMap": true,
19
+ "esModuleInterop": true,
20
+ "outDir": "smoke-tests",
21
+ "declaration": true,
22
+ "skipLibCheck": true,
23
+ "strictNullChecks": true,
24
+ "noErrorTruncation": true
25
+ }
26
+ }