@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,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 OrExpectationOperator<
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.some((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,40 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.Remove', () => {
5
- it('should handle schema with non object payload', () => {
6
- const operator = new operators.$remove<any>(operators, { $location: 'path' });
7
- const context = operator.manipulate({ incoming: { path: 'foo' } });
8
-
9
- expect(context.incoming.path).toEqual('foo');
10
- });
11
-
12
- it('should handle schema without targeting properties', () => {
13
- const operator = new operators.$remove<any>(operators, { $location: 'incoming.headers' });
14
- const context = operator.manipulate({ headers: { 'content-type': 'unknown' } });
15
-
16
- expect(context.headers['content-type']).toEqual('unknown');
17
- });
18
-
19
- it('should manipulate by schema using path', () => {
20
- const operator = new operators.$remove(operators, {
21
- $location: 'incoming.query',
22
- $path: 'foo',
23
- });
24
-
25
- const context = operator.manipulate<any>(buildExpectationContext());
26
- expect(context.incoming.query.foo).toBeUndefined();
27
- });
28
-
29
- it('should manipulate by schema using jsonPath', () => {
30
- const operator = new operators.$remove(operators, {
31
- $location: 'incoming.data',
32
- $jsonPath: '$.foo[*].bar,baz',
33
- });
34
-
35
- const context = operator.manipulate<any>(buildExpectationContext());
36
-
37
- expect(context.incoming.data.foo[0].bar).toBeUndefined();
38
- expect(context.incoming.data.foo[1].baz).toBeUndefined();
39
- });
40
- });
@@ -1,50 +0,0 @@
1
- import _ from 'lodash';
2
-
3
- import { IExpectationSchemaContext, TExpectationMetaTag, TExpectationOperatorLocation } from '../types';
4
- import { extractContextByLocation, extractWithJsonPathSafe } from '../utils';
5
- import { ExpectationOperator } from '../models/operator';
6
-
7
- export default class RemoveExpectationOperator<
8
- TContext extends IExpectationSchemaContext,
9
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation
10
- > extends ExpectationOperator<
11
- TContext,
12
- {
13
- [K in TLocation]: {
14
- $location: K;
15
-
16
- $path?: string;
17
- $jsonPath?: string;
18
- }
19
- }[TLocation]
20
- > {
21
- public get tags(): TExpectationMetaTag[] {
22
- return [];
23
- }
24
-
25
- public match(): boolean {
26
- return true;
27
- }
28
-
29
- public manipulate<T extends TContext>(context: T): T {
30
- const payload = extractContextByLocation(this.command.$location, context);
31
- if (payload?.type !== 'object') {
32
- return context;
33
- }
34
-
35
- if (this.command.$path) {
36
- _.unset(payload.value, this.command.$path);
37
- return context;
38
- }
39
-
40
- if (this.command.$jsonPath && _.isObject(payload.value)) {
41
- extractWithJsonPathSafe({ path: this.command.$jsonPath, json: payload.value })
42
- .results?.forEach((segment) => _.unset(segment.parent, segment.parentProperty));
43
-
44
- return context;
45
- }
46
-
47
- _.unset(payload.parent, payload.key);
48
- return context;
49
- }
50
- }
@@ -1,26 +0,0 @@
1
- import RootExpectationOperator from './root.operator';
2
-
3
- // Test generated using Keploy
4
- test('should return false when compiled is null', () => {
5
- const mockOperators: any = {};
6
- const operator = new RootExpectationOperator(<any>{}, mockOperators);
7
- operator.compiled = null; // Set compiled to null
8
- expect(operator.match(<any>{})).toBe(false);
9
- });
10
-
11
- // Test generated using Keploy
12
- test('should return original context when compiled is null', () => {
13
- const mockOperators: any = {};
14
- const operator = new RootExpectationOperator(<any>{}, mockOperators);
15
- operator.compiled = null; // Set compiled to null
16
- const context = { data: 'test' };
17
- expect(operator.manipulate(<any>context)).toBe(context);
18
- });
19
-
20
- // Test generated using Keploy
21
- test('tags should return empty array if compiled is null', () => {
22
- const mockOperators: any = {};
23
- const operator = new RootExpectationOperator(<any>{}, mockOperators);
24
- operator.compiled = null; // Set compiled to null
25
- expect(operator.tags).toEqual([]);
26
- });
@@ -1,51 +0,0 @@
1
- import { ExpectationOperator, TExpectationOperatorConstructor } from '../models/operator';
2
- import { Logger } from '../../logger';
3
- import {
4
- IExpectationSchemaContext,
5
- IExpectationOperatorsSchema,
6
- TExpectationMetaTag,
7
- TExpectationOperatorLocation,
8
- } from '../types';
9
-
10
- const logger = Logger.build('Expectations.Operators.Root');
11
-
12
- export default class RootExpectationOperator<
13
- TContext extends IExpectationSchemaContext,
14
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation,
15
- TValue = void
16
- > extends ExpectationOperator<
17
- TContext,
18
- IExpectationOperatorsSchema<TContext, TLocation, TValue>
19
- > {
20
- public compiled = (() => {
21
- const extracted = this.extractNestedSchema(this.command);
22
- if (!extracted) {
23
- return null;
24
- }
25
-
26
- const Operator = <TExpectationOperatorConstructor<TContext>>this.operators[extracted.key];
27
- return new Operator(this.operators, extracted.nested);
28
- })();
29
-
30
- public get tags(): TExpectationMetaTag[] {
31
- return this.compiled?.tags ?? [];
32
- }
33
-
34
- public match(context: TContext): boolean {
35
- try {
36
- return this.compiled?.match(context) ?? false;
37
- } catch(error: any) {
38
- logger.error('Got error on expectation matching', error?.stack ?? error);
39
- return false;
40
- }
41
- }
42
-
43
- public manipulate<T extends TContext>(context: T): T {
44
- try {
45
- return this.compiled?.manipulate(context) ?? context;
46
- } catch(error: any) {
47
- logger.error('Got error on expectation manipulation', error?.stack ?? error);
48
- return context;
49
- }
50
- }
51
- }
@@ -1,96 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.Set', () => {
5
- it('should manipulate by schema in outgoing.status', () => {
6
- const operator = new operators.$set(operators, {
7
- $location: 'outgoing.status',
8
- $value: 404,
9
- });
10
-
11
- const context = operator.manipulate(buildExpectationContext());
12
- expect(context.outgoing?.status).toEqual(404);
13
- });
14
-
15
- it('should manipulate by schema in incoming.headers', () => {
16
- const operator = new operators.$set(operators, {
17
- $location: 'incoming.headers',
18
- $path: 'a.b.c.d',
19
- $value: 'test',
20
- });
21
-
22
- const context = operator.manipulate<any>(buildExpectationContext());
23
- expect(context.incoming.headers.a.b.c.d).toEqual('test');
24
- });
25
-
26
- it('should manipulate by schema in incoming.data using jsonPath', () => {
27
- const operator = new operators.$set(operators, {
28
- $location: 'incoming.data',
29
- $jsonPath: '$.foo[*].bar,baz',
30
- $value: { test: true },
31
- });
32
-
33
- const context = operator.manipulate<any>(buildExpectationContext());
34
-
35
- expect(context.incoming.data.foo[0].bar.test).toBeTruthy();
36
- expect(context.incoming.data.foo[1].baz.test).toBeTruthy();
37
- });
38
-
39
- it('should manipulate by schema in incoming.query', () => {
40
- const operator = new operators.$set(operators, {
41
- $location: 'incoming.query',
42
- $value: { test: true },
43
- });
44
-
45
- const context = operator.manipulate<any>(buildExpectationContext());
46
- expect(context.incoming.query.test).toBeTruthy();
47
- });
48
-
49
- it('should manipulate by schema using path and exec as function', () => {
50
- const operator = new operators.$set<any>(operators, {
51
- $location: 'incoming.query',
52
- $path: 'foo',
53
-
54
- $exec: (payload) => payload + 1,
55
- });
56
-
57
- const context = operator.manipulate<any>(buildExpectationContext());
58
- expect(context.incoming.query.foo).toEqual(2);
59
- });
60
-
61
- it('should manipulate by schema using exec as function', () => {
62
- const operator = new operators.$set<any>(operators, {
63
- $location: 'incoming.query',
64
- $path: 'test',
65
-
66
- $exec: () => true,
67
- });
68
-
69
- const context = operator.manipulate<any>(buildExpectationContext());
70
- expect(context.incoming.query.test).toBeTruthy();
71
- });
72
-
73
- it('should manipulate by schema using exec as string', () => {
74
- const operator = new operators.$set(operators, {
75
- $location: 'incoming.query',
76
- $path: 'test',
77
-
78
- $exec: 'true',
79
- });
80
-
81
- const context = operator.manipulate<any>(buildExpectationContext());
82
- expect(context.incoming.query.test).toBeTruthy();
83
- });
84
-
85
- it('should manipulate by schema using exec as string with utils', () => {
86
- const operator = new operators.$set(operators, {
87
- $location: 'incoming.query',
88
- $path: 'test',
89
-
90
- $exec: '_.isEqual({}, {})',
91
- });
92
-
93
- const context = operator.manipulate<any>(buildExpectationContext());
94
- expect(context.incoming.query.test).toBeTruthy();
95
- });
96
- });
@@ -1,116 +0,0 @@
1
- import _ from 'lodash';
2
-
3
- import { extractContextByLocation, extractWithJsonPathSafe } from '../utils';
4
- import { ExpectationOperator } from '../models/operator';
5
- import { TFunction } from '../../../types';
6
- import {
7
- CompileExpectationOperatorValue,
8
- CompileExpectationOperatorValueWithPredicate,
9
- IExpectationSchemaContext,
10
- IExpectationExecUtils,
11
- TExpectationMetaTag,
12
- TExpectationOperatorLocation,
13
- } from '../types';
14
-
15
- export default class SetExpectationOperator<
16
- TContext extends IExpectationSchemaContext,
17
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation,
18
- TValue = void
19
- > extends ExpectationOperator<
20
- TContext,
21
- {
22
- [K in TLocation]: {
23
- $location: K;
24
-
25
- $value?: CompileExpectationOperatorValueWithPredicate<TContext, K, TValue>;
26
- $exec?: string | TFunction<CompileExpectationOperatorValueWithPredicate<TContext, K, TValue>, [
27
- CompileExpectationOperatorValue<TContext, K, TValue>,
28
- IExpectationExecUtils<TContext>
29
- ]>;
30
-
31
- $path?: string;
32
- $jsonPath?: string;
33
- }
34
- }[TLocation]
35
- > {
36
- public compiled = {
37
- ...(this.command.$exec && {
38
- exec: this.compileExecHandler(this.command.$exec, ['payload', 'utils']),
39
- }),
40
- };
41
-
42
- public get tags(): TExpectationMetaTag[] {
43
- if (this.command.$location === 'outgoing.status') {
44
- return this.command.$value
45
- ? [{ location: 'outgoing.status', value: Number(this.command.$value) }]
46
- : [];
47
- }
48
-
49
- if (this.command.$location === 'error') {
50
- return this.command.$value
51
- ? [{ location: 'error', value: String(this.command.$value) }]
52
- : [];
53
- }
54
-
55
- return [];
56
- }
57
-
58
- public match(): boolean {
59
- return true;
60
- }
61
-
62
- public manipulate<T extends TContext>(context: T): T {
63
- const payload = extractContextByLocation(this.command.$location, context);
64
- if (!payload) {
65
- return context;
66
- }
67
-
68
- switch(payload.type) {
69
- case 'number':
70
- case 'buffer':
71
- case 'string': {
72
- _.set(
73
- payload.parent,
74
- payload.key,
75
- this.compiled.exec ? this.compiled.exec('manipulate', context, payload.value) : this.command.$value
76
- );
77
-
78
- return context;
79
- }
80
-
81
- case 'object': {
82
- if (this.command.$path) {
83
- _.set(
84
- payload.parent,
85
- `${payload.key}.${this.command.$path}`,
86
- this.compiled.exec
87
- ? this.compiled.exec('manipulate', context, _.get(payload.value, this.command.$path))
88
- : this.command.$value
89
- );
90
-
91
- return context;
92
- }
93
-
94
- if (this.command.$jsonPath && _.isObject(payload.value)) {
95
- extractWithJsonPathSafe({ path: this.command.$jsonPath, json: payload.value }).results?.forEach(
96
- ({ parent, parentProperty, value }) => this.compiled.exec
97
- ? _.set(parent, parentProperty, this.compiled.exec('manipulate', context, value))
98
- : _.set(parent, parentProperty, this.command.$value)
99
- );
100
-
101
- return context;
102
- }
103
-
104
- _.set(
105
- payload.parent,
106
- payload.key,
107
- this.compiled.exec ? this.compiled.exec('manipulate', context, payload.value) : this.command.$value
108
- );
109
-
110
- return context;
111
- }
112
-
113
- default: return context;
114
- }
115
- }
116
- }
@@ -1,157 +0,0 @@
1
- import * as operators from './index';
2
-
3
- describe('Expectations.Operators.Switch', () => {
4
- describe('matching', () => {
5
- it('should match by schema in incoming body using path', () => {
6
- const operator = new operators.$switch<any>(operators, {
7
- $location: 'incoming.data',
8
- $path: 'foo.bar',
9
-
10
- $cases: {
11
- 'a': { $has: { $location: 'incoming.data', $path: 'baz', $value: 'a' } },
12
- 'b': { $has: { $location: 'incoming.data', $path: 'baz', $value: 'b' } },
13
- },
14
-
15
- $default: { $exec: () => true },
16
- });
17
-
18
- expect(operator.match({ incoming: { data: {} } })).toBeTruthy();
19
- expect(operator.match({ incoming: { data: { baz: 'a', foo: { bar: 'a' } } } })).toBeTruthy();
20
- expect(operator.match({ incoming: { data: { baz: 'b', foo: { bar: 'b' } } } })).toBeTruthy();
21
-
22
- expect(operator.match({ incoming: { data: { foo: { bar: 'a' } } } })).toBeFalsy();
23
- expect(operator.match({ incoming: { data: { baz: 'b', foo: { bar: 'a' } } } })).toBeFalsy();
24
- expect(operator.match({ incoming: { data: { baz: 'a', foo: { bar: 'b' } } } })).toBeFalsy();
25
- });
26
-
27
- it('should match by schema in incoming body using exec', () => {
28
- const operator = new operators.$switch<any>(operators, {
29
- $location: 'incoming.data',
30
- $exec: (payload) => payload?.foo?.bar,
31
-
32
- $cases: {
33
- 'a': { $has: { $location: 'incoming.data', $path: 'baz', $value: 'a' } },
34
- 'b': { $has: { $location: 'incoming.data', $path: 'baz', $value: 'b' } },
35
- },
36
-
37
- $default: { $exec: () => true },
38
- });
39
-
40
- expect(operator.match({ incoming: { data: {} } })).toBeTruthy();
41
- expect(operator.match({ incoming: { data: { baz: 'a', foo: { bar: 'a' } } } })).toBeTruthy();
42
- expect(operator.match({ incoming: { data: { baz: 'b', foo: { bar: 'b' } } } })).toBeTruthy();
43
-
44
- expect(operator.match({ incoming: { data: { foo: { bar: 'a' } } } })).toBeFalsy();
45
- expect(operator.match({ incoming: { data: { baz: 'b', foo: { bar: 'a' } } } })).toBeFalsy();
46
- expect(operator.match({ incoming: { data: { baz: 'a', foo: { bar: 'b' } } } })).toBeFalsy();
47
- });
48
-
49
- it('should match by schema in incoming body using exec with utils', () => {
50
- const operator = new operators.$switch<any>(operators, {
51
- $location: 'incoming.data',
52
- $exec: (payload, { _ }) => _.get(payload, 'foo.bar'),
53
-
54
- $cases: {
55
- 'a': { $has: { $location: 'incoming.data', $path: 'baz', $value: 'a' } },
56
- 'b': { $has: { $location: 'incoming.data', $path: 'baz', $value: 'b' } },
57
- },
58
-
59
- $default: { $exec: () => true },
60
- });
61
-
62
- expect(operator.match({ incoming: { data: {} } })).toBeTruthy();
63
- expect(operator.match({ incoming: { data: { baz: 'a', foo: { bar: 'a' } } } })).toBeTruthy();
64
- expect(operator.match({ incoming: { data: { baz: 'b', foo: { bar: 'b' } } } })).toBeTruthy();
65
-
66
- expect(operator.match({ incoming: { data: { foo: { bar: 'a' } } } })).toBeFalsy();
67
- expect(operator.match({ incoming: { data: { baz: 'b', foo: { bar: 'a' } } } })).toBeFalsy();
68
- expect(operator.match({ incoming: { data: { baz: 'a', foo: { bar: 'b' } } } })).toBeFalsy();
69
- });
70
- });
71
-
72
- describe('manipulation', () => {
73
- it('should manipulate by schema in incoming body using path', () => {
74
- const operator = new operators.$switch<any>(operators, {
75
- $location: 'incoming.data',
76
- $path: 'foo.bar',
77
-
78
- $cases: {
79
- 'a': { $set: { $location: 'incoming.data', $path: 'baz', $value: 'a' } },
80
- 'b': { $set: { $location: 'incoming.data', $path: 'baz', $value: 'b' } },
81
- },
82
-
83
- $default: { $exec: ({ context }) => context.default = true },
84
- });
85
-
86
- expect(operator.manipulate<any>({ incoming: { data: {} } }).default).toBeTruthy();
87
-
88
- expect(
89
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'a' } } } }).incoming.data.baz
90
- ).toEqual('a');
91
-
92
- expect(
93
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'b' } } } }).incoming.data.baz
94
- ).toEqual('b');
95
-
96
- expect(
97
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'c' } } } }).incoming.data.baz
98
- ).toBeUndefined();
99
- });
100
-
101
- it('should match by schema in incoming body using exec', () => {
102
- const operator = new operators.$switch<any>(operators, {
103
- $location: 'incoming.data',
104
- $exec: (payload) => payload?.foo?.bar,
105
-
106
- $cases: {
107
- 'a': { $set: { $location: 'incoming.data', $path: 'baz', $value: 'a' } },
108
- 'b': { $set: { $location: 'incoming.data', $path: 'baz', $value: 'b' } },
109
- },
110
-
111
- $default: { $exec: ({ context }) => context.default = true },
112
- });
113
-
114
- expect(operator.manipulate<any>({ incoming: { data: {} } }).default).toBeTruthy();
115
-
116
- expect(
117
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'a' } } } }).incoming.data.baz
118
- ).toEqual('a');
119
-
120
- expect(
121
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'b' } } } }).incoming.data.baz
122
- ).toEqual('b');
123
-
124
- expect(
125
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'c' } } } }).incoming.data.baz
126
- ).toBeUndefined();
127
- });
128
-
129
- it('should match by schema in incoming body using exec with utils', () => {
130
- const operator = new operators.$switch<any>(operators, {
131
- $location: 'incoming.data',
132
- $exec: (payload, { _ }) => _.get(payload, 'foo.bar'),
133
-
134
- $cases: {
135
- 'a': { $set: { $location: 'incoming.data', $path: 'baz', $value: 'a' } },
136
- 'b': { $set: { $location: 'incoming.data', $path: 'baz', $value: 'b' } },
137
- },
138
-
139
- $default: { $exec: ({ context }) => context.default = true },
140
- });
141
-
142
- expect(operator.manipulate<any>({ incoming: { data: {} } }).default).toBeTruthy();
143
-
144
- expect(
145
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'a' } } } }).incoming.data.baz
146
- ).toEqual('a');
147
-
148
- expect(
149
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'b' } } } }).incoming.data.baz
150
- ).toEqual('b');
151
-
152
- expect(
153
- operator.manipulate<any>({ incoming: { data: { foo: { bar: 'c' } } } }).incoming.data.baz
154
- ).toBeUndefined();
155
- });
156
- })
157
- });