@n1k1t/mock-server 0.1.61 → 0.1.62

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 (559) hide show
  1. package/lib/package.json +1 -1
  2. package/package.json +1 -1
  3. package/bin/index.ts +0 -33
  4. package/coverage/clover.xml +0 -1372
  5. package/coverage/cobertura-coverage.xml +0 -3466
  6. package/coverage/coverage-final.json +0 -76
  7. package/coverage/lcov-report/base.css +0 -224
  8. package/coverage/lcov-report/block-navigation.js +0 -87
  9. package/coverage/lcov-report/client/errors/connection.error.ts.html +0 -106
  10. package/coverage/lcov-report/client/errors/index.html +0 -161
  11. package/coverage/lcov-report/client/errors/index.ts.html +0 -97
  12. package/coverage/lcov-report/client/errors/internal-server.error.ts.html +0 -115
  13. package/coverage/lcov-report/client/errors/validation.error.ts.html +0 -115
  14. package/coverage/lcov-report/client/helpers/expectations.ts.html +0 -766
  15. package/coverage/lcov-report/client/helpers/index.html +0 -131
  16. package/coverage/lcov-report/client/helpers/index.ts.html +0 -88
  17. package/coverage/lcov-report/client/index.html +0 -161
  18. package/coverage/lcov-report/client/index.ts.html +0 -100
  19. package/coverage/lcov-report/client/methods/expectations-group.update.method.ts.html +0 -193
  20. package/coverage/lcov-report/client/methods/expectations.create.method.ts.html +0 -202
  21. package/coverage/lcov-report/client/methods/expectations.delete.method.ts.html +0 -184
  22. package/coverage/lcov-report/client/methods/expectations.update.method.ts.html +0 -241
  23. package/coverage/lcov-report/client/methods/index.html +0 -191
  24. package/coverage/lcov-report/client/methods/index.ts.html +0 -103
  25. package/coverage/lcov-report/client/methods/ping.method.ts.html +0 -160
  26. package/coverage/lcov-report/client/models/client.ts.html +0 -340
  27. package/coverage/lcov-report/client/models/index.html +0 -146
  28. package/coverage/lcov-report/client/models/index.ts.html +0 -91
  29. package/coverage/lcov-report/client/models/method.ts.html +0 -235
  30. package/coverage/lcov-report/client/onsite.ts.html +0 -172
  31. package/coverage/lcov-report/client/remote.ts.html +0 -187
  32. package/coverage/lcov-report/client/utils.ts.html +0 -211
  33. package/coverage/lcov-report/config/index.html +0 -131
  34. package/coverage/lcov-report/config/index.ts.html +0 -97
  35. package/coverage/lcov-report/config/model.ts.html +0 -226
  36. package/coverage/lcov-report/expectations/__utils__/index.html +0 -116
  37. package/coverage/lcov-report/expectations/__utils__/index.ts.html +0 -268
  38. package/coverage/lcov-report/expectations/index.html +0 -146
  39. package/coverage/lcov-report/expectations/index.ts.html +0 -94
  40. package/coverage/lcov-report/expectations/models/expectation.ts.html +0 -373
  41. package/coverage/lcov-report/expectations/models/index.html +0 -161
  42. package/coverage/lcov-report/expectations/models/index.ts.html +0 -94
  43. package/coverage/lcov-report/expectations/models/operator.ts.html +0 -352
  44. package/coverage/lcov-report/expectations/models/storage.ts.html +0 -211
  45. package/coverage/lcov-report/expectations/operators/and.operator.ts.html +0 -196
  46. package/coverage/lcov-report/expectations/operators/exec.operator.ts.html +0 -160
  47. package/coverage/lcov-report/expectations/operators/has.operator.ts.html +0 -778
  48. package/coverage/lcov-report/expectations/operators/if.operator.ts.html +0 -316
  49. package/coverage/lcov-report/expectations/operators/index.html +0 -281
  50. package/coverage/lcov-report/expectations/operators/index.ts.html +0 -118
  51. package/coverage/lcov-report/expectations/operators/merge.operator.ts.html +0 -379
  52. package/coverage/lcov-report/expectations/operators/not.operator.ts.html +0 -199
  53. package/coverage/lcov-report/expectations/operators/or.operator.ts.html +0 -196
  54. package/coverage/lcov-report/expectations/operators/remove.operator.ts.html +0 -238
  55. package/coverage/lcov-report/expectations/operators/root.operator.ts.html +0 -238
  56. package/coverage/lcov-report/expectations/operators/set.operator.ts.html +0 -436
  57. package/coverage/lcov-report/expectations/operators/switch.operator.ts.html +0 -463
  58. package/coverage/lcov-report/expectations/types.ts.html +0 -766
  59. package/coverage/lcov-report/expectations/utils.ts.html +0 -802
  60. package/coverage/lcov-report/favicon.png +0 -0
  61. package/coverage/lcov-report/index.html +0 -431
  62. package/coverage/lcov-report/logger/index.html +0 -131
  63. package/coverage/lcov-report/logger/index.ts.html +0 -325
  64. package/coverage/lcov-report/logger/utils.ts.html +0 -160
  65. package/coverage/lcov-report/meta/index.html +0 -146
  66. package/coverage/lcov-report/meta/index.ts.html +0 -103
  67. package/coverage/lcov-report/meta/model.ts.html +0 -172
  68. package/coverage/lcov-report/meta/storage.ts.html +0 -145
  69. package/coverage/lcov-report/prettify.css +0 -1
  70. package/coverage/lcov-report/prettify.js +0 -2
  71. package/coverage/lcov-report/server/expectations/__utils__/index.html +0 -116
  72. package/coverage/lcov-report/server/expectations/__utils__/index.ts.html +0 -199
  73. package/coverage/lcov-report/server/expectations/index.html +0 -131
  74. package/coverage/lcov-report/server/expectations/operators/and.operator.ts.html +0 -103
  75. package/coverage/lcov-report/server/expectations/operators/exec.operator.ts.html +0 -139
  76. package/coverage/lcov-report/server/expectations/operators/has.operator.ts.html +0 -358
  77. package/coverage/lcov-report/server/expectations/operators/if.operator.ts.html +0 -130
  78. package/coverage/lcov-report/server/expectations/operators/index.html +0 -266
  79. package/coverage/lcov-report/server/expectations/operators/index.ts.html +0 -112
  80. package/coverage/lcov-report/server/expectations/operators/merge.operator.ts.html +0 -193
  81. package/coverage/lcov-report/server/expectations/operators/not.operator.ts.html +0 -100
  82. package/coverage/lcov-report/server/expectations/operators/or.operator.ts.html +0 -115
  83. package/coverage/lcov-report/server/expectations/operators/remove.operator.ts.html +0 -169
  84. package/coverage/lcov-report/server/expectations/operators/set.operator.ts.html +0 -208
  85. package/coverage/lcov-report/server/expectations/operators/utils.ts.html +0 -346
  86. package/coverage/lcov-report/server/expectations/types.ts.html +0 -517
  87. package/coverage/lcov-report/server/expectations/utils.ts.html +0 -358
  88. package/coverage/lcov-report/server/models/containers/index.html +0 -161
  89. package/coverage/lcov-report/server/models/containers/index.ts.html +0 -91
  90. package/coverage/lcov-report/server/models/containers/model.ts.html +0 -328
  91. package/coverage/lcov-report/server/models/containers/storage.ts.html +0 -256
  92. package/coverage/lcov-report/server/models/containers/utils.ts.html +0 -97
  93. package/coverage/lcov-report/server/models/context/index.html +0 -146
  94. package/coverage/lcov-report/server/models/context/index.ts.html +0 -514
  95. package/coverage/lcov-report/server/models/context/snapshot.ts.html +0 -529
  96. package/coverage/lcov-report/server/models/context/utils.ts.html +0 -382
  97. package/coverage/lcov-report/server/models/endpoint.ts.html +0 -304
  98. package/coverage/lcov-report/server/models/exchanges/index.html +0 -131
  99. package/coverage/lcov-report/server/models/exchanges/index.ts.html +0 -88
  100. package/coverage/lcov-report/server/models/exchanges/socket-io.ts.html +0 -154
  101. package/coverage/lcov-report/server/models/executor/errors/index.html +0 -116
  102. package/coverage/lcov-report/server/models/executor/errors/index.ts.html +0 -130
  103. package/coverage/lcov-report/server/models/executor/index.html +0 -116
  104. package/coverage/lcov-report/server/models/executor/index.ts.html +0 -1018
  105. package/coverage/lcov-report/server/models/history/index.html +0 -146
  106. package/coverage/lcov-report/server/models/history/index.ts.html +0 -91
  107. package/coverage/lcov-report/server/models/history/model.ts.html +0 -331
  108. package/coverage/lcov-report/server/models/history/storage.ts.html +0 -184
  109. package/coverage/lcov-report/server/models/index.html +0 -161
  110. package/coverage/lcov-report/server/models/index.ts.html +0 -115
  111. package/coverage/lcov-report/server/models/providers/index.html +0 -146
  112. package/coverage/lcov-report/server/models/providers/index.ts.html +0 -91
  113. package/coverage/lcov-report/server/models/providers/model.ts.html +0 -211
  114. package/coverage/lcov-report/server/models/providers/storage.ts.html +0 -172
  115. package/coverage/lcov-report/server/models/reply.ts.html +0 -115
  116. package/coverage/lcov-report/server/models/router.ts.html +0 -313
  117. package/coverage/lcov-report/server/models/transports/index.html +0 -146
  118. package/coverage/lcov-report/server/models/transports/index.ts.html +0 -91
  119. package/coverage/lcov-report/server/models/transports/model.ts.html +0 -112
  120. package/coverage/lcov-report/server/models/transports/storage.ts.html +0 -124
  121. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  122. package/coverage/lcov-report/sorter.js +0 -196
  123. package/coverage/lcov-report/utils/common.ts.html +0 -187
  124. package/coverage/lcov-report/utils/index.html +0 -176
  125. package/coverage/lcov-report/utils/index.ts.html +0 -97
  126. package/coverage/lcov-report/utils/json.ts.html +0 -193
  127. package/coverage/lcov-report/utils/regexp.ts.html +0 -97
  128. package/coverage/lcov-report/utils/validation.ts.html +0 -190
  129. package/coverage/lcov.info +0 -3012
  130. package/discardedTests.txt +0 -35606
  131. package/images/preview.png +0 -0
  132. package/images/strategy.png +0 -0
  133. package/keploy.yml +0 -64
  134. package/lib/src/client/errors/connection.error.spec.d.ts +0 -2
  135. package/lib/src/client/errors/connection.error.spec.d.ts.map +0 -1
  136. package/lib/src/client/errors/connection.error.spec.js +0 -12
  137. package/lib/src/client/errors/connection.error.spec.js.map +0 -1
  138. package/lib/src/client/errors/internal-server.error.spec.d.ts +0 -2
  139. package/lib/src/client/errors/internal-server.error.spec.d.ts.map +0 -1
  140. package/lib/src/client/errors/internal-server.error.spec.js +0 -12
  141. package/lib/src/client/errors/internal-server.error.spec.js.map +0 -1
  142. package/lib/src/client/errors/validation.error.spec.d.ts +0 -2
  143. package/lib/src/client/errors/validation.error.spec.d.ts.map +0 -1
  144. package/lib/src/client/errors/validation.error.spec.js +0 -10
  145. package/lib/src/client/errors/validation.error.spec.js.map +0 -1
  146. package/lib/src/client/models/client.spec.d.ts +0 -2
  147. package/lib/src/client/models/client.spec.d.ts.map +0 -1
  148. package/lib/src/client/models/client.spec.js +0 -244
  149. package/lib/src/client/models/client.spec.js.map +0 -1
  150. package/lib/src/client/onsite.spec.d.ts +0 -2
  151. package/lib/src/client/onsite.spec.d.ts.map +0 -1
  152. package/lib/src/client/onsite.spec.js +0 -23
  153. package/lib/src/client/onsite.spec.js.map +0 -1
  154. package/lib/src/client/remote.spec.d.ts +0 -2
  155. package/lib/src/client/remote.spec.d.ts.map +0 -1
  156. package/lib/src/client/remote.spec.js +0 -16
  157. package/lib/src/client/remote.spec.js.map +0 -1
  158. package/lib/src/client/utils.spec.d.ts +0 -2
  159. package/lib/src/client/utils.spec.d.ts.map +0 -1
  160. package/lib/src/client/utils.spec.js +0 -57
  161. package/lib/src/client/utils.spec.js.map +0 -1
  162. package/lib/src/expectations/models/storage.spec.d.ts +0 -2
  163. package/lib/src/expectations/models/storage.spec.d.ts.map +0 -1
  164. package/lib/src/expectations/models/storage.spec.js +0 -57
  165. package/lib/src/expectations/models/storage.spec.js.map +0 -1
  166. package/lib/src/expectations/operators/and.operator.spec.d.ts +0 -2
  167. package/lib/src/expectations/operators/and.operator.spec.d.ts.map +0 -1
  168. package/lib/src/expectations/operators/and.operator.spec.js +0 -83
  169. package/lib/src/expectations/operators/and.operator.spec.js.map +0 -1
  170. package/lib/src/expectations/operators/exec.operator.spec.d.ts +0 -2
  171. package/lib/src/expectations/operators/exec.operator.spec.d.ts.map +0 -1
  172. package/lib/src/expectations/operators/exec.operator.spec.js +0 -68
  173. package/lib/src/expectations/operators/exec.operator.spec.js.map +0 -1
  174. package/lib/src/expectations/operators/has.operator.spec.d.ts +0 -2
  175. package/lib/src/expectations/operators/has.operator.spec.d.ts.map +0 -1
  176. package/lib/src/expectations/operators/has.operator.spec.js +0 -444
  177. package/lib/src/expectations/operators/has.operator.spec.js.map +0 -1
  178. package/lib/src/expectations/operators/if.operator.spec.d.ts +0 -2
  179. package/lib/src/expectations/operators/if.operator.spec.d.ts.map +0 -1
  180. package/lib/src/expectations/operators/if.operator.spec.js +0 -132
  181. package/lib/src/expectations/operators/if.operator.spec.js.map +0 -1
  182. package/lib/src/expectations/operators/merge.operator.spec.d.ts +0 -2
  183. package/lib/src/expectations/operators/merge.operator.spec.d.ts.map +0 -1
  184. package/lib/src/expectations/operators/merge.operator.spec.js +0 -75
  185. package/lib/src/expectations/operators/merge.operator.spec.js.map +0 -1
  186. package/lib/src/expectations/operators/not.operator.spec.d.ts +0 -2
  187. package/lib/src/expectations/operators/not.operator.spec.d.ts.map +0 -1
  188. package/lib/src/expectations/operators/not.operator.spec.js +0 -46
  189. package/lib/src/expectations/operators/not.operator.spec.js.map +0 -1
  190. package/lib/src/expectations/operators/or.operator.spec.d.ts +0 -2
  191. package/lib/src/expectations/operators/or.operator.spec.d.ts.map +0 -1
  192. package/lib/src/expectations/operators/or.operator.spec.js +0 -84
  193. package/lib/src/expectations/operators/or.operator.spec.js.map +0 -1
  194. package/lib/src/expectations/operators/remove.operator.spec.d.ts +0 -2
  195. package/lib/src/expectations/operators/remove.operator.spec.d.ts.map +0 -1
  196. package/lib/src/expectations/operators/remove.operator.spec.js +0 -67
  197. package/lib/src/expectations/operators/remove.operator.spec.js.map +0 -1
  198. package/lib/src/expectations/operators/root.operator.spec.d.ts +0 -2
  199. package/lib/src/expectations/operators/root.operator.spec.d.ts.map +0 -1
  200. package/lib/src/expectations/operators/root.operator.spec.js +0 -29
  201. package/lib/src/expectations/operators/root.operator.spec.js.map +0 -1
  202. package/lib/src/expectations/operators/set.operator.spec.d.ts +0 -2
  203. package/lib/src/expectations/operators/set.operator.spec.d.ts.map +0 -1
  204. package/lib/src/expectations/operators/set.operator.spec.js +0 -111
  205. package/lib/src/expectations/operators/set.operator.spec.js.map +0 -1
  206. package/lib/src/expectations/operators/switch.operator.spec.d.ts +0 -2
  207. package/lib/src/expectations/operators/switch.operator.spec.d.ts.map +0 -1
  208. package/lib/src/expectations/operators/switch.operator.spec.js +0 -139
  209. package/lib/src/expectations/operators/switch.operator.spec.js.map +0 -1
  210. package/lib/src/expectations/utils/location.spec.d.ts +0 -2
  211. package/lib/src/expectations/utils/location.spec.d.ts.map +0 -1
  212. package/lib/src/expectations/utils/location.spec.js +0 -62
  213. package/lib/src/expectations/utils/location.spec.js.map +0 -1
  214. package/lib/src/expectations/utils/schema.spec.d.ts +0 -2
  215. package/lib/src/expectations/utils/schema.spec.d.ts.map +0 -1
  216. package/lib/src/expectations/utils/schema.spec.js +0 -19
  217. package/lib/src/expectations/utils/schema.spec.js.map +0 -1
  218. package/lib/src/meta/model.spec.d.ts +0 -2
  219. package/lib/src/meta/model.spec.d.ts.map +0 -1
  220. package/lib/src/meta/model.spec.js +0 -28
  221. package/lib/src/meta/model.spec.js.map +0 -1
  222. package/lib/src/meta/storage.spec.d.ts +0 -2
  223. package/lib/src/meta/storage.spec.d.ts.map +0 -1
  224. package/lib/src/meta/storage.spec.js +0 -19
  225. package/lib/src/meta/storage.spec.js.map +0 -1
  226. package/lib/src/server/models/containers/model.spec.d.ts +0 -2
  227. package/lib/src/server/models/containers/model.spec.d.ts.map +0 -1
  228. package/lib/src/server/models/containers/model.spec.js +0 -79
  229. package/lib/src/server/models/containers/model.spec.js.map +0 -1
  230. package/lib/src/server/models/containers/storage.spec.d.ts +0 -2
  231. package/lib/src/server/models/containers/storage.spec.d.ts.map +0 -1
  232. package/lib/src/server/models/containers/storage.spec.js +0 -39
  233. package/lib/src/server/models/containers/storage.spec.js.map +0 -1
  234. package/lib/src/server/models/context/index.spec.d.ts +0 -2
  235. package/lib/src/server/models/context/index.spec.d.ts.map +0 -1
  236. package/lib/src/server/models/context/index.spec.js +0 -143
  237. package/lib/src/server/models/context/index.spec.js.map +0 -1
  238. package/lib/src/server/models/context/snapshot.spec.d.ts +0 -2
  239. package/lib/src/server/models/context/snapshot.spec.d.ts.map +0 -1
  240. package/lib/src/server/models/context/snapshot.spec.js +0 -75
  241. package/lib/src/server/models/context/snapshot.spec.js.map +0 -1
  242. package/lib/src/server/models/context/utils.spec.d.ts +0 -2
  243. package/lib/src/server/models/context/utils.spec.d.ts.map +0 -1
  244. package/lib/src/server/models/context/utils.spec.js +0 -69
  245. package/lib/src/server/models/context/utils.spec.js.map +0 -1
  246. package/lib/src/server/models/endpoint.spec.d.ts +0 -2
  247. package/lib/src/server/models/endpoint.spec.d.ts.map +0 -1
  248. package/lib/src/server/models/endpoint.spec.js +0 -28
  249. package/lib/src/server/models/endpoint.spec.js.map +0 -1
  250. package/lib/src/server/models/exchanges/socket-io.spec.d.ts +0 -2
  251. package/lib/src/server/models/exchanges/socket-io.spec.d.ts.map +0 -1
  252. package/lib/src/server/models/exchanges/socket-io.spec.js +0 -12
  253. package/lib/src/server/models/exchanges/socket-io.spec.js.map +0 -1
  254. package/lib/src/server/models/executor/errors/index.spec.d.ts +0 -2
  255. package/lib/src/server/models/executor/errors/index.spec.d.ts.map +0 -1
  256. package/lib/src/server/models/executor/errors/index.spec.js +0 -23
  257. package/lib/src/server/models/executor/errors/index.spec.js.map +0 -1
  258. package/lib/src/server/models/executor/index.spec.d.ts +0 -2
  259. package/lib/src/server/models/executor/index.spec.d.ts.map +0 -1
  260. package/lib/src/server/models/executor/index.spec.js +0 -137
  261. package/lib/src/server/models/executor/index.spec.js.map +0 -1
  262. package/lib/src/server/models/history/model.spec.d.ts +0 -2
  263. package/lib/src/server/models/history/model.spec.d.ts.map +0 -1
  264. package/lib/src/server/models/history/model.spec.js +0 -30
  265. package/lib/src/server/models/history/model.spec.js.map +0 -1
  266. package/lib/src/server/models/history/storage.spec.d.ts +0 -2
  267. package/lib/src/server/models/history/storage.spec.d.ts.map +0 -1
  268. package/lib/src/server/models/history/storage.spec.js +0 -42
  269. package/lib/src/server/models/history/storage.spec.js.map +0 -1
  270. package/lib/src/server/models/providers/model.spec.d.ts +0 -2
  271. package/lib/src/server/models/providers/model.spec.d.ts.map +0 -1
  272. package/lib/src/server/models/providers/model.spec.js +0 -13
  273. package/lib/src/server/models/providers/model.spec.js.map +0 -1
  274. package/lib/src/server/models/providers/storage.spec.d.ts +0 -2
  275. package/lib/src/server/models/providers/storage.spec.d.ts.map +0 -1
  276. package/lib/src/server/models/providers/storage.spec.js +0 -19
  277. package/lib/src/server/models/providers/storage.spec.js.map +0 -1
  278. package/lib/src/server/models/reply.spec.d.ts +0 -2
  279. package/lib/src/server/models/reply.spec.d.ts.map +0 -1
  280. package/lib/src/server/models/reply.spec.js +0 -20
  281. package/lib/src/server/models/reply.spec.js.map +0 -1
  282. package/lib/src/server/models/router.spec.d.ts +0 -2
  283. package/lib/src/server/models/router.spec.d.ts.map +0 -1
  284. package/lib/src/server/models/router.spec.js +0 -46
  285. package/lib/src/server/models/router.spec.js.map +0 -1
  286. package/lib/src/server/models/transports/storage.spec.d.ts +0 -2
  287. package/lib/src/server/models/transports/storage.spec.d.ts.map +0 -1
  288. package/lib/src/server/models/transports/storage.spec.js +0 -13
  289. package/lib/src/server/models/transports/storage.spec.js.map +0 -1
  290. package/lib/src/server/services/analytics.service.spec.d.ts +0 -2
  291. package/lib/src/server/services/analytics.service.spec.d.ts.map +0 -1
  292. package/lib/src/server/services/analytics.service.spec.js +0 -35
  293. package/lib/src/server/services/analytics.service.spec.js.map +0 -1
  294. package/lib/src/server/services/metrics.service.spec.d.ts +0 -2
  295. package/lib/src/server/services/metrics.service.spec.d.ts.map +0 -1
  296. package/lib/src/server/services/metrics.service.spec.js +0 -35
  297. package/lib/src/server/services/metrics.service.spec.js.map +0 -1
  298. package/lib/src/utils/index.spec.d.ts +0 -2
  299. package/lib/src/utils/index.spec.d.ts.map +0 -1
  300. package/lib/src/utils/index.spec.js +0 -30
  301. package/lib/src/utils/index.spec.js.map +0 -1
  302. package/lib/tsconfig.tsbuildinfo +0 -1
  303. package/lib/vite.config.d.ts +0 -3
  304. package/lib/vite.config.d.ts.map +0 -1
  305. package/lib/vite.config.js +0 -57
  306. package/lib/vite.config.js.map +0 -1
  307. package/src/client/errors/connection.error.spec.ts +0 -10
  308. package/src/client/errors/connection.error.ts +0 -7
  309. package/src/client/errors/index.ts +0 -4
  310. package/src/client/errors/internal-server.error.spec.ts +0 -12
  311. package/src/client/errors/internal-server.error.ts +0 -10
  312. package/src/client/errors/types.ts +0 -3
  313. package/src/client/errors/validation.error.spec.ts +0 -9
  314. package/src/client/errors/validation.error.ts +0 -10
  315. package/src/client/helpers/expectations.ts +0 -227
  316. package/src/client/helpers/index.ts +0 -1
  317. package/src/client/index.ts +0 -5
  318. package/src/client/methods/expectations-group.update.method.ts +0 -36
  319. package/src/client/methods/expectations.create.method.ts +0 -39
  320. package/src/client/methods/expectations.delete.method.ts +0 -33
  321. package/src/client/methods/expectations.update.method.ts +0 -58
  322. package/src/client/methods/index.ts +0 -6
  323. package/src/client/methods/ping.method.ts +0 -25
  324. package/src/client/models/__snapshots__/client.spec.ts.snap +0 -1294
  325. package/src/client/models/client.spec.ts +0 -316
  326. package/src/client/models/client.ts +0 -85
  327. package/src/client/models/index.ts +0 -2
  328. package/src/client/models/method.ts +0 -50
  329. package/src/client/onsite.spec.ts +0 -23
  330. package/src/client/onsite.ts +0 -29
  331. package/src/client/remote.spec.ts +0 -15
  332. package/src/client/remote.ts +0 -34
  333. package/src/client/types.ts +0 -31
  334. package/src/client/utils.spec.ts +0 -60
  335. package/src/client/utils.ts +0 -41
  336. package/src/config/index.ts +0 -34
  337. package/src/config/model.ts +0 -24
  338. package/src/expectations/__utils__/index.ts +0 -61
  339. package/src/expectations/errors/index.ts +0 -7
  340. package/src/expectations/index.ts +0 -3
  341. package/src/expectations/models/expectation.ts +0 -96
  342. package/src/expectations/models/index.ts +0 -3
  343. package/src/expectations/models/operator.ts +0 -89
  344. package/src/expectations/models/storage.spec.ts +0 -70
  345. package/src/expectations/models/storage.ts +0 -42
  346. package/src/expectations/operators/and.operator.spec.ts +0 -59
  347. package/src/expectations/operators/and.operator.ts +0 -37
  348. package/src/expectations/operators/exec.operator.spec.ts +0 -47
  349. package/src/expectations/operators/exec.operator.ts +0 -25
  350. package/src/expectations/operators/has.operator.spec.ts +0 -514
  351. package/src/expectations/operators/has.operator.ts +0 -230
  352. package/src/expectations/operators/if.operator.spec.ts +0 -116
  353. package/src/expectations/operators/if.operator.ts +0 -77
  354. package/src/expectations/operators/index.ts +0 -11
  355. package/src/expectations/operators/merge.operator.spec.ts +0 -48
  356. package/src/expectations/operators/merge.operator.ts +0 -97
  357. package/src/expectations/operators/not.operator.spec.ts +0 -12
  358. package/src/expectations/operators/not.operator.ts +0 -38
  359. package/src/expectations/operators/or.operator.spec.ts +0 -60
  360. package/src/expectations/operators/or.operator.ts +0 -37
  361. package/src/expectations/operators/remove.operator.spec.ts +0 -40
  362. package/src/expectations/operators/remove.operator.ts +0 -50
  363. package/src/expectations/operators/root.operator.spec.ts +0 -26
  364. package/src/expectations/operators/root.operator.ts +0 -51
  365. package/src/expectations/operators/set.operator.spec.ts +0 -96
  366. package/src/expectations/operators/set.operator.ts +0 -116
  367. package/src/expectations/operators/switch.operator.spec.ts +0 -157
  368. package/src/expectations/operators/switch.operator.ts +0 -126
  369. package/src/expectations/types.ts +0 -225
  370. package/src/expectations/utils/index.ts +0 -3
  371. package/src/expectations/utils/json.ts +0 -22
  372. package/src/expectations/utils/location.spec.ts +0 -64
  373. package/src/expectations/utils/location.ts +0 -180
  374. package/src/expectations/utils/schema.spec.ts +0 -17
  375. package/src/expectations/utils/schema.ts +0 -60
  376. package/src/gui/app/components/chart.component/index.ts +0 -173
  377. package/src/gui/app/components/chart.component/style.scss +0 -4
  378. package/src/gui/app/components/checkbox-area.component/index.ts +0 -101
  379. package/src/gui/app/components/checkbox-area.component/item.component.ts +0 -72
  380. package/src/gui/app/components/checkbox-area.component/style.scss +0 -19
  381. package/src/gui/app/components/checkbox-area.component/template.hbs +0 -3
  382. package/src/gui/app/components/curtain.component/index.ts +0 -19
  383. package/src/gui/app/components/curtain.component/style.scss +0 -14
  384. package/src/gui/app/components/empty.component/index.ts +0 -10
  385. package/src/gui/app/components/empty.component/style.scss +0 -34
  386. package/src/gui/app/components/empty.component/template.hbs +0 -6
  387. package/src/gui/app/components/expectation.component/index.ts +0 -60
  388. package/src/gui/app/components/expectation.component/style.scss +0 -5
  389. package/src/gui/app/components/expectation.component/template.hbs +0 -5
  390. package/src/gui/app/components/header.component/index.ts +0 -81
  391. package/src/gui/app/components/header.component/style.scss +0 -46
  392. package/src/gui/app/components/header.component/template.hbs +0 -15
  393. package/src/gui/app/components/history.component/index.ts +0 -86
  394. package/src/gui/app/components/history.component/style.scss +0 -5
  395. package/src/gui/app/components/history.component/template.hbs +0 -62
  396. package/src/gui/app/components/index.ts +0 -11
  397. package/src/gui/app/components/loader.component/index.ts +0 -12
  398. package/src/gui/app/components/loader.component/style.scss +0 -39
  399. package/src/gui/app/components/panel.component/index.ts +0 -52
  400. package/src/gui/app/components/panel.component/style.scss +0 -60
  401. package/src/gui/app/components/panel.component/template.hbs +0 -13
  402. package/src/gui/app/components/popups.component/index.ts +0 -26
  403. package/src/gui/app/components/popups.component/style.scss +0 -51
  404. package/src/gui/app/components/popups.component/template.hbs +0 -9
  405. package/src/gui/app/components/search.component/index.ts +0 -67
  406. package/src/gui/app/components/search.component/style.scss +0 -43
  407. package/src/gui/app/components/search.component/template.hbs +0 -7
  408. package/src/gui/app/components/viewer.component/index.ts +0 -28
  409. package/src/gui/app/components/viewer.component/style.scss +0 -38
  410. package/src/gui/app/components/viewer.component/template.hbs +0 -3
  411. package/src/gui/app/context.ts +0 -76
  412. package/src/gui/app/handlebars/helpers.ts +0 -32
  413. package/src/gui/app/handlebars/index.ts +0 -11
  414. package/src/gui/app/handlebars/partials/expectation-meta.hbs +0 -53
  415. package/src/gui/app/handlebars/partials/index.ts +0 -2
  416. package/src/gui/app/handlebars/partials/truncated.hbs +0 -10
  417. package/src/gui/app/handlebars/utils.ts +0 -9
  418. package/src/gui/app/main.ts +0 -38
  419. package/src/gui/app/models/button.ts +0 -41
  420. package/src/gui/app/models/client-storage.ts +0 -21
  421. package/src/gui/app/models/component.ts +0 -79
  422. package/src/gui/app/models/context.ts +0 -14
  423. package/src/gui/app/models/dynamic-storage.ts +0 -36
  424. package/src/gui/app/models/form.ts +0 -75
  425. package/src/gui/app/models/index.ts +0 -7
  426. package/src/gui/app/models/section.ts +0 -82
  427. package/src/gui/app/sections/analytics.section/index.ts +0 -97
  428. package/src/gui/app/sections/analytics.section/style.scss +0 -1
  429. package/src/gui/app/sections/analytics.section/template.hbs +0 -6
  430. package/src/gui/app/sections/expectations.section/index.ts +0 -179
  431. package/src/gui/app/sections/expectations.section/style.scss +0 -1
  432. package/src/gui/app/sections/expectations.section/template.hbs +0 -15
  433. package/src/gui/app/sections/history.section/index.ts +0 -175
  434. package/src/gui/app/sections/history.section/style.scss +0 -10
  435. package/src/gui/app/sections/history.section/templates/actions.hbs +0 -5
  436. package/src/gui/app/sections/history.section/templates/section.hbs +0 -15
  437. package/src/gui/app/sections/index.ts +0 -4
  438. package/src/gui/app/sections/settings.section/index.ts +0 -63
  439. package/src/gui/app/sections/settings.section/style.scss +0 -24
  440. package/src/gui/app/sections/settings.section/templates/cache.hbs +0 -6
  441. package/src/gui/app/sections/settings.section/templates/section.hbs +0 -6
  442. package/src/gui/app/sections/settings.section/templates/stats.hbs +0 -6
  443. package/src/gui/app/setup.ts +0 -7
  444. package/src/gui/app/tsconfig.json +0 -20
  445. package/src/gui/app/types/dev.ts +0 -6
  446. package/src/gui/app/types/index.ts +0 -1
  447. package/src/gui/app/types/window.global.ts +0 -9
  448. package/src/gui/app/utils.ts +0 -15
  449. package/src/gui/assets/fa-all.css +0 -5
  450. package/src/gui/assets/fa-regular-400.woff2 +0 -0
  451. package/src/gui/assets/fa-solid-900.woff2 +0 -0
  452. package/src/gui/assets/favicon.png +0 -0
  453. package/src/gui/index.html +0 -18
  454. package/src/gui/styles/_constants.scss +0 -11
  455. package/src/gui/styles/_elements.scss +0 -216
  456. package/src/gui/styles/_soon.scss +0 -35
  457. package/src/gui/styles/main.scss +0 -245
  458. package/src/index.ts +0 -9
  459. package/src/logger/index.ts +0 -80
  460. package/src/logger/types.ts +0 -4
  461. package/src/logger/utils.ts +0 -25
  462. package/src/meta/index.ts +0 -6
  463. package/src/meta/model.spec.ts +0 -28
  464. package/src/meta/model.ts +0 -29
  465. package/src/meta/storage.spec.ts +0 -18
  466. package/src/meta/storage.ts +0 -20
  467. package/src/server/endpoints/cache.delete.endpoint.ts +0 -54
  468. package/src/server/endpoints/cache.usage.get.endpoint.ts +0 -12
  469. package/src/server/endpoints/config.get.endpoint.ts +0 -10
  470. package/src/server/endpoints/expectations-group.update.endpoint.ts +0 -32
  471. package/src/server/endpoints/expectations.create.endpoint.ts +0 -23
  472. package/src/server/endpoints/expectations.delete.endpoint.ts +0 -12
  473. package/src/server/endpoints/expectations.get-list.endpoint.ts +0 -15
  474. package/src/server/endpoints/expectations.update.endpoint.ts +0 -29
  475. package/src/server/endpoints/gui.endpoint.ts +0 -76
  476. package/src/server/endpoints/history.delete.endpoint.ts +0 -10
  477. package/src/server/endpoints/history.get-list.endpoint.ts +0 -15
  478. package/src/server/endpoints/index.ts +0 -18
  479. package/src/server/endpoints/metrics.endpoint.ts +0 -12
  480. package/src/server/endpoints/ping.endpoint.ts +0 -7
  481. package/src/server/endpoints/stats.endpoint.ts +0 -20
  482. package/src/server/index.ts +0 -182
  483. package/src/server/models/containers/index.ts +0 -2
  484. package/src/server/models/containers/model.spec.ts +0 -81
  485. package/src/server/models/containers/model.ts +0 -79
  486. package/src/server/models/containers/storage.spec.ts +0 -41
  487. package/src/server/models/containers/storage.ts +0 -59
  488. package/src/server/models/containers/utils.ts +0 -4
  489. package/src/server/models/context/index.spec.ts +0 -171
  490. package/src/server/models/context/index.ts +0 -136
  491. package/src/server/models/context/snapshot.spec.ts +0 -84
  492. package/src/server/models/context/snapshot.ts +0 -148
  493. package/src/server/models/context/types.ts +0 -65
  494. package/src/server/models/context/utils.spec.ts +0 -77
  495. package/src/server/models/context/utils.ts +0 -99
  496. package/src/server/models/endpoint.spec.ts +0 -28
  497. package/src/server/models/endpoint.ts +0 -69
  498. package/src/server/models/exchanges/index.ts +0 -1
  499. package/src/server/models/exchanges/socket-io.spec.ts +0 -13
  500. package/src/server/models/exchanges/socket-io.ts +0 -14
  501. package/src/server/models/executor/errors/index.spec.ts +0 -23
  502. package/src/server/models/executor/errors/index.ts +0 -15
  503. package/src/server/models/executor/index.spec.ts +0 -148
  504. package/src/server/models/executor/index.ts +0 -297
  505. package/src/server/models/history/index.ts +0 -2
  506. package/src/server/models/history/model.spec.ts +0 -35
  507. package/src/server/models/history/model.ts +0 -82
  508. package/src/server/models/history/storage.spec.ts +0 -41
  509. package/src/server/models/history/storage.ts +0 -38
  510. package/src/server/models/index.ts +0 -11
  511. package/src/server/models/providers/index.ts +0 -2
  512. package/src/server/models/providers/model.spec.ts +0 -11
  513. package/src/server/models/providers/model.ts +0 -33
  514. package/src/server/models/providers/storage.spec.ts +0 -21
  515. package/src/server/models/providers/storage.ts +0 -34
  516. package/src/server/models/reply.spec.ts +0 -17
  517. package/src/server/models/reply.ts +0 -10
  518. package/src/server/models/router.spec.ts +0 -50
  519. package/src/server/models/router.ts +0 -79
  520. package/src/server/models/service.ts +0 -5
  521. package/src/server/models/transports/index.ts +0 -2
  522. package/src/server/models/transports/model.ts +0 -9
  523. package/src/server/models/transports/storage.spec.ts +0 -14
  524. package/src/server/models/transports/storage.ts +0 -13
  525. package/src/server/services/analytics.service.spec.ts +0 -38
  526. package/src/server/services/analytics.service.ts +0 -58
  527. package/src/server/services/index.ts +0 -2
  528. package/src/server/services/metrics.service.spec.ts +0 -42
  529. package/src/server/services/metrics.service.ts +0 -46
  530. package/src/server/transports/http.transport/context.ts +0 -72
  531. package/src/server/transports/http.transport/executor.ts +0 -156
  532. package/src/server/transports/http.transport/index.ts +0 -53
  533. package/src/server/transports/index.ts +0 -3
  534. package/src/server/transports/internal/http.transport/context.ts +0 -50
  535. package/src/server/transports/internal/http.transport/executor.ts +0 -56
  536. package/src/server/transports/internal/http.transport/index.ts +0 -23
  537. package/src/server/transports/internal/http.transport/reply.ts +0 -82
  538. package/src/server/transports/internal/index.ts +0 -2
  539. package/src/server/transports/internal/io.transport/context.ts +0 -40
  540. package/src/server/transports/internal/io.transport/executor.ts +0 -27
  541. package/src/server/transports/internal/io.transport/index.ts +0 -36
  542. package/src/server/transports/internal/io.transport/reply.ts +0 -26
  543. package/src/server/transports/internal/utils.ts +0 -6
  544. package/src/server/transports/ws.transport/context.ts +0 -90
  545. package/src/server/transports/ws.transport/executor.ts +0 -64
  546. package/src/server/transports/ws.transport/index.ts +0 -105
  547. package/src/server/types/index.ts +0 -32
  548. package/src/server/utils/index.ts +0 -35
  549. package/src/utils/index.spec.ts +0 -31
  550. package/src/utils/index.ts +0 -51
  551. package/test/index.ts +0 -299
  552. package/test/providers/index.ts +0 -2
  553. package/test/providers/root.ts +0 -241
  554. package/test/providers/statics.ts +0 -37
  555. package/tsconfig.json +0 -108
  556. package/tsconfig.tsbuildinfo +0 -1
  557. package/types/common.ts +0 -127
  558. package/types/index.ts +0 -1
  559. package/vite.config.ts +0 -64
@@ -1,41 +0,0 @@
1
- import { AxiosError } from 'axios';
2
- import _ from 'lodash';
3
-
4
- import type { IRequestConfiguration } from './errors';
5
- import type { IEndpointResponse } from '../server';
6
-
7
- import { ConnectionError, InternalServerError, ValidationError } from './errors';
8
- import { Expectation, serializeExpectationSchema } from '../expectations';
9
-
10
- export const handleRequestError = (error: AxiosError<IEndpointResponse<any>>) => {
11
- const configuration: IRequestConfiguration = {
12
- baseURL: error.config.baseURL,
13
- method: error.config.method,
14
- url: error.config.url,
15
- };
16
-
17
- if (!error.response) {
18
- throw new ConnectionError(configuration);
19
- }
20
-
21
- switch(error.response?.data.code) {
22
- case 'INTERNAL_ERROR': {
23
- throw new InternalServerError(configuration, error.response?.data.data?.message);
24
- }
25
- case 'VALIDATION_ERROR': {
26
- throw new ValidationError(configuration, error.response?.data.data?.reasons);
27
- }
28
- }
29
-
30
- throw new InternalServerError(configuration, error.message);
31
- }
32
-
33
- export const prepareExpectationBodyToRequest = <T extends Partial<Expectation<any>['TPlain']>>(body: T): T => ({
34
- ...body,
35
-
36
- schema: {
37
- ...body.schema,
38
- ...(body.schema?.request && { request: serializeExpectationSchema(body.schema.request) }),
39
- ...(body.schema?.response && { response: serializeExpectationSchema(body.schema.response) }),
40
- }
41
- });
@@ -1,34 +0,0 @@
1
- import path from 'path';
2
-
3
- import type { TLoggerLevel } from '../logger';
4
-
5
- import { Config } from './model';
6
- import { cast } from '../utils';
7
-
8
- export * from './model';
9
-
10
- const checkIsTypeScriptRuntime = (): boolean => path.parse(__filename).ext === '.ts';
11
- const getPathToRoot = (): string => path.resolve(__dirname, checkIsTypeScriptRuntime() ? '' : '../', '../../');
12
-
13
- export default Config.build(<const>{
14
- statics: {
15
- public: {
16
- dir: path.resolve(getPathToRoot(), 'public'),
17
- },
18
- },
19
-
20
- routes: {
21
- internal: {
22
- root: '/_system',
23
- gui: '/gui',
24
- },
25
- },
26
-
27
- history: {
28
- limit: 100,
29
- },
30
-
31
- logger: {
32
- level: cast<TLoggerLevel>('D'),
33
- },
34
- });
@@ -1,24 +0,0 @@
1
- import merge from 'deepmerge';
2
- import { PartialDeep, SetRequiredKeys } from '../../types';
3
-
4
- export class Config<T extends object = object> {
5
- public storage: T = merge(this.defaults, JSON.parse(process.env['MOCK_CONFIG'] ?? '{}'));
6
-
7
- constructor(public defaults: T) {}
8
-
9
- public get<K extends keyof T>(key: K): T[K] {
10
- return this.storage[key];
11
- }
12
-
13
- public has<K extends keyof T>(key: K): this is SetRequiredKeys<T, K> {
14
- return key in this.storage;
15
- }
16
-
17
- public merge(payload: PartialDeep<T>): this {
18
- return Object.assign(this, { storage: merge(this.storage, <T>payload, { arrayMerge: (target, source) => source }) });
19
- }
20
-
21
- static build<T extends object>(defaults: T) {
22
- return new Config(defaults);
23
- }
24
- }
@@ -1,61 +0,0 @@
1
- import { IExpectationSchemaContext } from '../types';
2
- import { ContainersStorage } from '../../server/models';
3
-
4
- export const buildExpectationContext = (): IExpectationSchemaContext => ({
5
- storage: new ContainersStorage(),
6
-
7
- transport: 'http',
8
- event: 'connection',
9
-
10
- state: {},
11
- flags: {},
12
-
13
- cache: {
14
- isEnabled: false,
15
- },
16
-
17
- incoming: {
18
- type: 'json',
19
-
20
- path: '/foo/bar/baz',
21
- method: 'POST',
22
-
23
- query: {
24
- foo: 1,
25
- bar: {
26
- baz: null,
27
- },
28
- },
29
-
30
- dataRaw: Buffer.from('{"foo": [{"bar": 1}, {"baz": ["2"]}]}'),
31
- data: {
32
- foo: [
33
- { bar: 1 },
34
- { baz: ['2'] },
35
- ],
36
- },
37
-
38
- headers: {
39
- 'content-type': 'application/json',
40
- 'accept-language': 'en/gb',
41
- },
42
- },
43
-
44
- outgoing: {
45
- type: 'json',
46
- status: 200,
47
-
48
- dataRaw: Buffer.from('{"foo": {"bar": {"baz": true}}}'),
49
- data: {
50
- foo: {
51
- bar: {
52
- baz: true,
53
- },
54
- },
55
- },
56
-
57
- headers: {
58
- 'content-type': 'application/json',
59
- },
60
- },
61
- });
@@ -1,7 +0,0 @@
1
- import { ValueError } from '@n1k1t/typebox/errors';
2
-
3
- export class ExpectationValidationError extends Error {
4
- constructor(public reasons: ValueError[]) {
5
- super('Got error on expectation validation');
6
- }
7
- }
@@ -1,3 +0,0 @@
1
- export * from './models';
2
- export * from './types';
3
- export * from './utils';
@@ -1,96 +0,0 @@
1
- import generateAnimalName from 'random-animal-name';
2
- import { v4 as genUid } from 'uuid';
3
- import { ValueError } from '@n1k1t/typebox/errors';
4
- import _ from 'lodash';
5
-
6
- import { serializeExpectationSchema } from '../utils';
7
- import {
8
- IExpectationMeta,
9
- IExpectationSchemaContext,
10
- IExpectationSchemaInput,
11
- IExpectationSchema,
12
- } from '../types';
13
-
14
- import * as operators from '../operators';
15
-
16
- export class Expectation<
17
- TInput extends IExpectationSchemaInput = {},
18
- TContext extends IExpectationSchemaContext<TInput> = IExpectationSchemaContext<TInput>
19
- > {
20
- public TPlain!: Pick<
21
- Expectation<TInput, TContext>,
22
- 'schema' | 'id' | 'group' | 'isEnabled' | 'meta' | 'name' | 'transports'
23
- >;
24
-
25
- public id: string = this.configuration.id ?? genUid();
26
- public name: string = this.configuration.name ?? generateAnimalName().split(' ').map(_.capitalize).join('');
27
- public group: string = this.configuration.group ?? 'unknown';
28
-
29
- public transports?: TContext['transport'][] = this.configuration.transports;
30
-
31
- public schema = <IExpectationSchema<TContext>>this.configuration.schema;
32
- public isEnabled: boolean = this.configuration.isEnabled ?? true;
33
-
34
- public request = this.schema.request
35
- ? new operators.root<TContext>(operators, this.schema.request)
36
- : new operators.root<TContext>(operators, { $exec: () => true });
37
-
38
- public response = this.schema.response
39
- ? new operators.root<TContext>(operators, this.schema.response)
40
- : null;
41
-
42
- public meta: IExpectationMeta = {
43
- executionsCount: this.configuration.meta?.executionsCount ?? 0,
44
- tags: (this.request?.tags ?? []).concat(this.response?.tags ?? []),
45
- };
46
-
47
- public get forward() {
48
- return this.schema.forward;
49
- }
50
-
51
- private serialized = {
52
- schema: {
53
- request: this.schema.request ? serializeExpectationSchema(this.schema.request) : undefined,
54
- response: this.schema.response ? serializeExpectationSchema(this.schema.response) : undefined,
55
- },
56
- };
57
-
58
- constructor(
59
- public configuration: Pick<Expectation<TContext>, 'schema'> & Partial<
60
- Pick<Expectation<TContext>, 'id' | 'name' | 'isEnabled' | 'group' | 'transports' | 'meta'>
61
- >
62
- ) {}
63
-
64
- public increaseExecutionsCounter(): this {
65
- this.meta.executionsCount += 1;
66
- return this;
67
- }
68
-
69
- public validate(): ValueError[] {
70
- return [];
71
- }
72
-
73
- public toPlain(): Expectation<TInput, TContext>['TPlain'] {
74
- return {
75
- id: this.id,
76
- group: this.group,
77
-
78
- name: this.name,
79
- transports: this.transports,
80
-
81
- meta: this.meta,
82
- isEnabled: this.isEnabled,
83
-
84
- schema: {
85
- ...this.schema,
86
-
87
- request: this.serialized.schema.request,
88
- response: this.serialized.schema.response,
89
- },
90
- };
91
- }
92
-
93
- static build<TContext extends IExpectationSchemaContext>(configuration: Expectation<TContext>['configuration']) {
94
- return new Expectation(configuration);
95
- }
96
- }
@@ -1,3 +0,0 @@
1
- export * from './expectation';
2
- export * from './operator';
3
- export * from './storage';
@@ -1,89 +0,0 @@
1
- import { Faker, ru, en, en_GB } from '@faker-js/faker';
2
- import dayjs from 'dayjs';
3
- import _ from 'lodash';
4
- import * as rxjs from 'rxjs';
5
-
6
- import { Constructable, TFunction } from '../../../types';
7
- import { metaStorage } from '../../meta';
8
- import { Logger } from '../../logger';
9
- import {
10
- IExpectationSchemaContext,
11
- IExpectationExecMode,
12
- IExpectationExecUtils,
13
- IExpectationOperatorsSchema,
14
- TExpectationMetaTag,
15
- TExpectationOperators,
16
- } from '../types';
17
-
18
- const logger = Logger.build('Expectations.Models.Operator');
19
-
20
- export type TExpectationOperatorConstructor<TContext extends IExpectationSchemaContext> =
21
- Constructable<ExpectationOperator<TContext, any>, ConstructorParameters<typeof ExpectationOperator>>
22
-
23
- export abstract class ExpectationOperator<TContext extends IExpectationSchemaContext, TSchema> {
24
- public TContext!: TContext;
25
- public TSchema!: TSchema;
26
-
27
- public abstract match(context: TContext): boolean;
28
- public abstract manipulate<T extends TContext>(context: T): T;
29
-
30
- public abstract get tags(): TExpectationMetaTag[];
31
-
32
- constructor(public operators: TExpectationOperators, public command: TSchema) {}
33
-
34
- protected compileExecHandler(raw: TFunction<any, any[]> | string, provide: ('payload' | 'utils')[]) {
35
- const parameters: string[] = [];
36
-
37
- if (provide.includes('payload')) {
38
- parameters.push('payload');
39
- }
40
- if (provide.includes('utils')) {
41
- parameters.push('{ context, mode, meta, T, _, d, faker }');
42
- }
43
-
44
- const handler = typeof raw === 'function' ? raw : Function(parameters.join(', '), `return (() => ${raw})()`);
45
-
46
- return (mode: IExpectationExecMode, context: TContext, ...args: unknown[]) => {
47
- const utils = this.compileExecUtils(mode, context);
48
- const handled = handler(...args, utils);
49
-
50
- return typeof handled === 'function' ? handled(...args, utils) : handled;
51
- }
52
- }
53
-
54
- protected extractNestedSchema(schema: IExpectationOperatorsSchema<any, any>): {
55
- [K in keyof IExpectationOperatorsSchema]: null | {
56
- key: K;
57
- nested: IExpectationOperatorsSchema[K];
58
- }
59
- }[keyof IExpectationOperatorsSchema] {
60
- const key = <keyof IExpectationOperatorsSchema | undefined>Object.keys(schema)[0];
61
- return key ? { key, nested: <any>schema[key] } : null;
62
- }
63
-
64
- private compileExecUtils<T extends TContext>(
65
- mode: IExpectationExecMode,
66
- context: T
67
- ): IExpectationExecUtils<T> {
68
- const faker = new Faker({ locale: [ru, en, en_GB] });
69
-
70
- if (context.seed) {
71
- faker.seed(context.seed);
72
- }
73
-
74
- return {
75
- _,
76
-
77
- faker,
78
- mode,
79
- logger,
80
-
81
- context: <IExpectationExecUtils<T>['context']>context,
82
- meta: metaStorage.provide(),
83
-
84
- T: (payload) => <any>payload,
85
- rx: rxjs,
86
- d: dayjs,
87
- }
88
- }
89
- }
@@ -1,70 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import { ExpectationsStorage } from './storage'
3
- import { Expectation } from './expectation';
4
-
5
- describe('Expectations.Models.Storage', () => {
6
- it('should not match with empty storage', () => {
7
- const storage = new ExpectationsStorage();
8
- expect(storage.match(buildExpectationContext())).toBeNull();
9
- });
10
-
11
- it('should match with 1 expectation', () => {
12
- const storage = new ExpectationsStorage();
13
-
14
- const { expectation } = <{ expectation: Expectation }>storage.register({
15
- schema: {
16
- request: { $has: { $location: 'path', $value: '/foo/bar/baz' } },
17
- },
18
- });
19
-
20
- expect(storage.match(buildExpectationContext())?.id).toEqual(expectation.id);
21
- });
22
-
23
- it('should not match with 1 expectation', () => {
24
- const storage = new ExpectationsStorage();
25
-
26
- storage.register({
27
- schema: {
28
- request: { $has: { $location: 'path', $value: '/foo' } },
29
- },
30
- });
31
-
32
- expect(storage.match(buildExpectationContext())).toBeNull();
33
- });
34
-
35
- it('should match with 2 expectations', () => {
36
- const storage = new ExpectationsStorage();
37
-
38
- storage.register({
39
- schema: {
40
- request: { $has: { $location: 'path', $value: '/foo/bar' } },
41
- },
42
- });
43
-
44
- const { expectation } = <{ expectation: Expectation }>storage.register({
45
- schema: {
46
- request: { $has: { $location: 'method', $valueAnyOf: ['GET', 'POST'] } },
47
- },
48
- });
49
-
50
- expect(storage.match(buildExpectationContext())?.id).toEqual(expectation.id);
51
- });
52
-
53
- it('should not match with 2 expectations', () => {
54
- const storage = new ExpectationsStorage();
55
-
56
- storage.register({
57
- schema: {
58
- request: { $has: { $location: 'path', $value: '/foo/bar' } },
59
- },
60
- });
61
-
62
- storage.register({
63
- schema: {
64
- request: { $has: { $location: 'method', $valueAnyOf: ['GET'] } },
65
- },
66
- });
67
-
68
- expect(storage.match(buildExpectationContext())).toBeNull();
69
- });
70
- });
@@ -1,42 +0,0 @@
1
- import { ValueError } from '@n1k1t/typebox/errors';
2
-
3
- import { IExpectationSchemaContext } from '../types';
4
- import { Expectation } from './expectation';
5
- import { Logger } from '../../logger';
6
-
7
- export type TExpectationsStorageRegisterationResult =
8
- | { status: 'REGISTERED', expectation: Expectation<any> }
9
- | { status: 'ERROR', reasons: ValueError[] };
10
-
11
- const logger = Logger.build('Expectations.Storage');
12
-
13
- export class ExpectationsStorage extends Map<string, Expectation> {
14
- public register(configuration: Expectation['configuration']): TExpectationsStorageRegisterationResult {
15
- const expectation = Expectation.build<any>(configuration);
16
- const errors = expectation.validate();
17
-
18
- if (errors.length) {
19
- return { status: 'ERROR', reasons: errors }
20
- }
21
-
22
- logger.info(`Expectation [${expectation.name}] has registered in group [${expectation.group}]`);
23
- this.set(expectation.id, expectation);
24
-
25
- return { status: 'REGISTERED', expectation };
26
- }
27
-
28
- public match(context: IExpectationSchemaContext): Expectation<any> | null {
29
- for (const expectation of this.values()) {
30
- if (!expectation.isEnabled) {
31
- continue;
32
- }
33
-
34
- const hasSameTransport = expectation.transports?.includes(context.transport) ?? true;
35
- if (hasSameTransport && expectation.request.match(context)) {
36
- return expectation;
37
- }
38
- }
39
-
40
- return null;
41
- }
42
- }
@@ -1,59 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.And', () => {
5
- describe('matching', () => {
6
- it('should match by schema with one valid condition', () => {
7
- const operator = new operators.$and(operators, [
8
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 1 } },
9
- ]);
10
-
11
- expect(operator.match(buildExpectationContext())).toBeTruthy();
12
- });
13
-
14
- it('should match by schema with two valid conditions', () => {
15
- const operator = new operators.$and(operators, [
16
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 1 } },
17
- { $has: { $location: 'incoming.query', $path: 'bar.baz', $value: null } },
18
- ]);
19
-
20
- expect(operator.match(buildExpectationContext())).toBeTruthy();
21
- });
22
-
23
- it('should match by schema with zero conditions', () => {
24
- expect(new operators.$and(operators, []).match(buildExpectationContext())).toBeTruthy();
25
- });
26
-
27
- it('should match by schema with one valid and one invalid condition', () => {
28
- const operator = new operators.$and(operators, [
29
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 1 } },
30
- { $has: { $location: 'incoming.query', $path: 'bar.baz', $value: 1 } },
31
- ]);
32
-
33
- expect(operator.match(buildExpectationContext())).toBeFalsy();
34
- });
35
-
36
- it('should match by schema with two invalid conditions', () => {
37
- const operator = new operators.$and(operators, [
38
- { $has: { $location: 'incoming.query', $path: 'foo', $value: null } },
39
- { $has: { $location: 'incoming.query', $path: 'bar.baz', $value: 1 } },
40
- ]);
41
-
42
- expect(operator.match(buildExpectationContext())).toBeFalsy();
43
- });
44
- });
45
-
46
- describe('manipulation', () => {
47
- it('should manipulate by schema with two conditions', () => {
48
- const operator = new operators.$and<any>(operators, [
49
- { $set: { $location: 'incoming.headers', $path: 'content-length', $value: 100 } },
50
- { $set: { $location: 'incoming.query', $path: 'bar.baz', $value: { test: true } } },
51
- ]);
52
-
53
- const context = operator.manipulate<any>(buildExpectationContext());
54
-
55
- expect(context.incoming.headers?.['content-length']).toEqual(100);
56
- expect(context.incoming.query?.bar?.baz?.test).toBeTruthy();
57
- });
58
- });
59
- });
@@ -1,37 +0,0 @@
1
- import { ExpectationOperator, TExpectationOperatorConstructor } from '../models/operator';
2
- import {
3
- IExpectationSchemaContext,
4
- IExpectationOperatorsSchema,
5
- TExpectationMetaTag,
6
- TExpectationOperatorLocation,
7
- } from '../types';
8
-
9
- export default class AndExpectationOperator<
10
- TContext extends IExpectationSchemaContext,
11
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation,
12
- TValue = void
13
- > extends ExpectationOperator<
14
- TContext,
15
- IExpectationOperatorsSchema<TContext, TLocation, TValue>[]
16
- > {
17
- public compiled = this.command
18
- .map((schema) => this.extractNestedSchema(schema)!)
19
- .filter(Boolean)
20
- .map((extracted) => {
21
- const Operator = <TExpectationOperatorConstructor<TContext>>this.operators[extracted.key];
22
- return new Operator(this.operators, extracted.nested);
23
- });
24
-
25
- public get tags(): TExpectationMetaTag[] {
26
- return this.compiled.reduce<TExpectationMetaTag[]>((acc, operator) => acc.concat(operator.tags), []);
27
- }
28
-
29
- public match(context: TContext): boolean {
30
- return this.compiled.every((operator) => operator.match(context));
31
- }
32
-
33
- public manipulate<T extends TContext>(context: T): T {
34
- this.compiled.forEach((operator) => operator.manipulate(context));
35
- return context;
36
- }
37
- }
@@ -1,47 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import { IExpectationSchemaContext } from '../types';
3
-
4
- import * as operators from './index';
5
-
6
- describe('Expectations.Operators.Exec', () => {
7
- it('should exec by inline serialized command with utils', () => {
8
- const operator = new operators.$exec(operators, '_.set(context, "incoming.query.test", "foo")');
9
- const context = operator.manipulate<any>(buildExpectationContext());
10
-
11
- expect(context.incoming.query.test).toEqual('foo');
12
- });
13
-
14
- it('should exec by multiline serialized command', () => {
15
- const operator = new operators.$exec(operators, `{
16
- context.incoming.data.foo.push({ test: 1 });
17
- context.incoming.data.foo.push({ test: 2 });
18
- }`);
19
-
20
- const context = operator.manipulate<any>(buildExpectationContext());
21
-
22
- expect(context.incoming.data.foo[2].test).toEqual(1);
23
- expect(context.incoming.data.foo[3].test).toEqual(2);
24
- });
25
-
26
- it('should exec by function', () => {
27
- const operator = new operators.$exec<IExpectationSchemaContext<{
28
- incoming: { query: { test: number } }
29
- }>>(operators, ({ context }) => {
30
- context.incoming.query.test = 100;
31
- });
32
-
33
- const context = operator.manipulate<any>(buildExpectationContext());
34
- expect(context.incoming.query.test).toEqual(100);
35
- });
36
-
37
- it('should exec by function with utils', () => {
38
- const operator = new operators.$exec<IExpectationSchemaContext<{
39
- incoming: { query: { test: number } }
40
- }>>(operators, ({ context, _ }) => {
41
- _.set(context, 'incoming.query.test', 100);
42
- });
43
-
44
- const context = operator.manipulate<any>(buildExpectationContext());
45
- expect(context.incoming.query.test).toEqual(100);
46
- });
47
- });
@@ -1,25 +0,0 @@
1
- import _ from 'lodash';
2
-
3
- import { IExpectationExecUtils, IExpectationSchemaContext, TExpectationMetaTag } from '../types';
4
- import { ExpectationOperator } from '../models/operator';
5
- import { TFunction } from '../../../types';
6
-
7
- export default class ExecExpectationOperator<
8
- TContext extends IExpectationSchemaContext,
9
- > extends ExpectationOperator<TContext, string | TFunction<unknown, [IExpectationExecUtils<TContext>]>> {
10
- public compiled = this.compileExecHandler(this.command, ['utils']);
11
-
12
- public get tags(): TExpectationMetaTag[] {
13
- return [];
14
- }
15
-
16
- public match(context: TContext): boolean {
17
- const result = this.compiled('match', context);
18
- return typeof result === 'boolean' ? result : true;
19
- }
20
-
21
- public manipulate<T extends TContext>(context: T): T {
22
- this.compiled('manipulate', context);
23
- return context;
24
- }
25
- }