@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,316 +0,0 @@
1
- import { prepareExpectationBodyToRequest } from '../utils';
2
- import { Expectation } from '../../expectations';
3
- import { Client } from './client';
4
-
5
-
6
- interface IExpectationContext {
7
- incoming: {
8
- query: {
9
- foo?: 'a' | 'b' | 'c';
10
- bar: 'a' | 'b' | 'c';
11
- }
12
-
13
- body: {
14
- foo: 'a' | 'b' | 'c';
15
- bar?: ('a' | 'b' | 'c')[];
16
-
17
- baz: {
18
- foo: 1 | 2 | 3;
19
- bar?: 1 | 2 | 3;
20
- baz?: (1 | 2 | 3)[];
21
- };
22
- };
23
- };
24
- }
25
-
26
- const buildClient = () => new Client({
27
- ping: () => Promise.resolve('pong'),
28
- deleteExpectations: () => Promise.resolve(null),
29
-
30
- createExpectation: (configuration) => Promise.resolve(
31
- prepareExpectationBodyToRequest(
32
- Object.assign(Expectation.build(configuration).toPlain(), {
33
- id: '12426262-85a3-4340-969b-272e003722e9',
34
- name: 'MaliciousCobra',
35
- })
36
- )
37
- ),
38
-
39
- updateExpectation: ({ id, set }) => Promise.resolve(
40
- prepareExpectationBodyToRequest(
41
- Object.assign(Expectation.build({ ...set, schema: set.schema ?? {} }).toPlain(), { id })
42
- )
43
- ),
44
-
45
- updateExpectationsGroup: () => Promise.resolve([]),
46
- });
47
-
48
- describe('Client.Models.Client', () => {
49
- it('should create expectation with complex schema as object', async () => {
50
- const client = buildClient();
51
-
52
- await expect(
53
- client.createExpectation({
54
- schema: {
55
- request: {
56
- $and: [
57
- { $has: { $location: 'path', $value: '/foo' } },
58
- { $has: { $location: 'path', $valueAnyOf: ['/foo', '/foo/bar'] } },
59
- { $has: { $location: 'path', $match: '/foo/*' } },
60
- { $has: { $location: 'path', $matchAnyOf: ['/foo/*', '*/bar'] } },
61
- { $has: { $location: 'path', $regExp: /^\/foo/ } },
62
- { $has: { $location: 'path', $regExpAnyOf: [/^\/foo$/, /^\/foo\/bar$/] } },
63
- { $has: { $location: 'path', $exec: (payload) => payload.includes('/foo') } },
64
-
65
- { $has: { $location: 'path', $path: '/foo', $value: '/foo' } },
66
- { $has: { $location: 'path', $path: '/foo', $valueAnyOf: ['/foo', '/foo/bar'] } },
67
- { $has: { $location: 'path', $path: '/foo', $match: '/foo/*' } },
68
- { $has: { $location: 'path', $path: '/foo', $matchAnyOf: ['/foo/*', '*/bar'] } },
69
- { $has: { $location: 'path', $path: '/foo', $regExp: /^\/foo/ } },
70
- { $has: { $location: 'path', $path: '/foo', $regExpAnyOf: [/^\/foo$/, /^\/foo\/bar$/] } },
71
- { $has: { $location: 'path', $path: '/foo', $exec: (payload) => payload.includes('/foo') } },
72
-
73
- { $has: { $location: 'incoming.query' } },
74
-
75
- { $has: { $location: 'incoming.query', $value: { foo: 'a' } } },
76
- { $has: { $location: 'incoming.query', $valueAnyOf: [{ foo: 'a' }, { foo: 'b' }] } },
77
- { $has: { $location: 'incoming.query', $match: { foo: 'a' } } },
78
- { $has: { $location: 'incoming.query', $matchAnyOf: [{ foo: 'a' }, { foo: 'b' }] } },
79
- { $has: { $location: 'incoming.query', $exec: (payload) => payload?.foo === 'a' } },
80
-
81
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 'a' } },
82
- { $has: { $location: 'incoming.query', $path: 'foo', $valueAnyOf: ['a', 'b'] } },
83
- { $has: { $location: 'incoming.query', $path: 'foo', $match: 'a' } },
84
- { $has: { $location: 'incoming.query', $path: 'foo', $matchAnyOf: ['a', 'b'] } },
85
- { $has: { $location: 'incoming.query', $path: 'foo', $regExp: /a|b/ } },
86
- { $has: { $location: 'incoming.query', $path: 'foo', $regExpAnyOf: [/a/i, /b/i] } },
87
- { $has: { $location: 'incoming.query', $path: 'foo', $exec: (payload) => payload === 'a' } },
88
-
89
- { $has: { $location: 'incoming.data' } },
90
-
91
- { $has: { $location: 'incoming.data', $value: { foo: 'a', bar: ['a'] } } },
92
- { $has: { $location: 'incoming.data', $valueAnyOf: [{ foo: 'a', bar: ['a'] }, { bar: ['b'] }, { baz: {} }] } },
93
- { $has: { $location: 'incoming.data', $match: { foo: 'a', baz: { foo: 1 } } } },
94
- { $has: { $location: 'incoming.data', $matchAnyOf: [{ baz: {} }, { bar: [] }] } },
95
- { $has: { $location: 'incoming.data', $exec: (payload) => payload?.baz?.foo === 1 } },
96
-
97
- { $has: { $location: 'incoming.data', $path: 'baz', $value: { foo: 1, bar: 1 } } },
98
- { $has: { $location: 'incoming.data', $path: 'baz', $valueAnyOf: [{ foo: 1 }, { bar: 1 }] } },
99
- { $has: { $location: 'incoming.data', $path: 'baz', $match: { foo: 1 } } },
100
- { $has: { $location: 'incoming.data', $path: 'baz', $matchAnyOf: [{}, { foo: '1' }] } },
101
- { $has: { $location: 'incoming.data', $path: 'baz', $exec: (payload) => payload?.foo === 1 } },
102
-
103
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $value: [1] } },
104
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $valueAnyOf: [[1], [1, 2]] } },
105
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $match: '*' } },
106
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $matchAnyOf: ['1', '2'] } },
107
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $regExp: /1/ } },
108
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $regExpAnyOf: [/1/, /2/] } },
109
- { $has: { $location: 'incoming.data', $path: 'baz.baz', $exec: (payload) => payload === 1 } },
110
- ],
111
- },
112
-
113
- response: {
114
- $or: [
115
- {
116
- $switch: {
117
- $location: 'outgoing.status',
118
- $cases: {
119
- 200: {
120
- $and: [
121
- { $set: { $location: 'outgoing.data', $value: {} } },
122
- { $set: { $location: 'outgoing.data', $path: 'foo', $value: 'a' } },
123
-
124
- { $set: { $location: 'outgoing.headers', $exec: () => ({}) } },
125
- { $set: { $location: 'outgoing.headers', $path: 'foo', $value: 'bar' } },
126
- ],
127
- },
128
- },
129
-
130
- $default: { $set: { $location: 'outgoing.data', $value: {} } },
131
- },
132
- },
133
- {
134
- $switch: {
135
- $location: 'outgoing.data',
136
- $path: 'baz.bar',
137
-
138
- $cases: {
139
- 1: {
140
- $and: [
141
- { $merge: { $location: 'outgoing.data', $value: {} } },
142
- { $remove: { $location: 'outgoing.data', $path: 'foo' } },
143
- ],
144
- },
145
- },
146
- },
147
- },
148
- {
149
- $switch: {
150
- $location: 'outgoing.headers',
151
- $exec: (payload) => payload.foo,
152
-
153
- $cases: {
154
- 'a': {
155
- $and: [{
156
- $exec: ({ context }) => {
157
- if (context.incoming.data?.foo === 'a') {
158
- context.outgoing!.status = 200;
159
- }
160
- },
161
- }],
162
- },
163
- },
164
- },
165
- },
166
- ],
167
- },
168
- },
169
- })
170
- ).resolves.toMatchSnapshot();
171
- });
172
-
173
- it('should create expectation with complex schema as function', async () => {
174
- const client = buildClient();
175
-
176
- await expect(
177
- client.createExpectation<IExpectationContext>(({ $ }) => ({
178
- schema: {
179
- request: $.and([
180
- $.has('path', { $value: '/foo' }),
181
- $.has('path', { $valueAnyOf: ['/foo', '/foo/bar'] }),
182
- $.has('path', { $match: '/foo/*' }),
183
- $.has('path', { $matchAnyOf: ['/foo/*', '*/bar'] }),
184
- $.has('path', { $regExp: /^\/foo/ }),
185
- $.has('path', { $regExpAnyOf: [/^\/foo$/, /^\/foo\/bar$/] }),
186
- $.has('path', { $exec: (payload) => payload.includes('/foo') }),
187
-
188
- $.has('path', '$path', '/foo', { $value: '/foo' }),
189
- $.has('path', '$path', '/foo', { $valueAnyOf: ['/foo', '/foo/bar'] }),
190
- $.has('path', '$path', '/foo', { $match: '/foo/*' }),
191
- $.has('path', '$path', '/foo', { $matchAnyOf: ['/foo/*', '*/bar'] }),
192
- $.has('path', '$path', '/foo', { $regExp: /^\/foo/ }),
193
- $.has('path', '$path', '/foo', { $regExpAnyOf: [/^\/foo$/, /^\/foo\/bar$/] }),
194
- $.has('path', '$path', '/foo', { $exec: (payload) => payload.includes('/foo') }),
195
-
196
- $.has('incoming.query', {}),
197
- $.has('incoming.query', '$path', 'foo'),
198
-
199
- $.has('incoming.query', { $value: { foo: 'a', bar: 'a' } }),
200
- $.has('incoming.query', { $valueAnyOf: [{ foo: 'a', bar: 'a' }, { foo: 'b', bar: 'b' }] }),
201
- $.has('incoming.query', { $match: { foo: 'a' } }),
202
- $.has('incoming.query', { $matchAnyOf: [{ foo: 'a' }, { foo: 'b' }] }),
203
- $.has('incoming.query', { $exec: (payload) => payload?.foo === 'a' }),
204
-
205
- $.has('incoming.query', '$path', 'foo', { $value: 'a' }),
206
- $.has('incoming.query', '$path', 'foo', { $valueAnyOf: ['a', 'b'] }),
207
- $.has('incoming.query', '$path', 'foo', { $match: 'a' }),
208
- $.has('incoming.query', '$path', 'foo', { $matchAnyOf: ['a', 'b'] }),
209
- $.has('incoming.query', '$path', 'foo', { $regExp: /a|b/ }),
210
- $.has('incoming.query', '$path', 'foo', { $regExpAnyOf: [/a/i, /b/i] }),
211
- $.has('incoming.query', '$path', 'foo', { $exec: (payload) => payload === 'a' }),
212
-
213
- $.has('incoming.data', {}),
214
-
215
- $.has('incoming.data', { $value: { foo: 'a', bar: ['a'] } }),
216
- $.has('incoming.data', { $valueAnyOf: [{ foo: 'a', bar: ['a'] }, { bar: ['b'] }, { baz: {} }] }),
217
- $.has('incoming.data', { $match: { foo: 'a', baz: { foo: 1 } } }),
218
- $.has('incoming.data', { $matchAnyOf: [{ baz: {} }, { bar: [] }] }),
219
- $.has('incoming.data', { $exec: (payload) => payload?.baz?.foo === 1 }),
220
-
221
- $.has('incoming.data', '$path', 'baz', { $value: { foo: 1, bar: 1 } }),
222
- $.has('incoming.data', '$path', 'baz', { $valueAnyOf: [{ foo: 1 }, { foo: 1, bar: 1 }] }),
223
- $.has('incoming.data', '$path', 'baz', { $match: { foo: 1 } }),
224
- $.has('incoming.data', '$path', 'baz', { $matchAnyOf: [{}, { foo: 1 }] }),
225
- $.has('incoming.data', '$path', 'baz', { $exec: (payload) => payload?.foo === 1 }),
226
-
227
- $.has('incoming.data', '$jsonPath', '123.123.213', {
228
- $match: {},
229
- }),
230
-
231
- $.has('incoming.data', '$path', 'baz.baz', { $value: [1] }),
232
- $.has('incoming.data', '$path', 'baz.baz', { $valueAnyOf: [[1], [1, 2]] }),
233
- $.has('incoming.data', '$path', 'baz.baz.0', { $match: '*' }),
234
- $.has('incoming.data', '$path', 'baz.baz.0', { $matchAnyOf: ['1', '2'] }),
235
- $.has('incoming.data', '$path', 'baz.baz', { $regExp: /1/ }),
236
- $.has('incoming.data', '$path', 'baz.baz', { $regExpAnyOf: [/1/, /2/] }),
237
- $.has('incoming.data', '$path', 'baz.baz', { $exec: (payload) => payload?.[0] === 1 }),
238
-
239
- $.switch('incoming.query', '$path', 'foo', {
240
- $cases: {
241
- 'a': $.and([])
242
- },
243
- }),
244
- ]),
245
-
246
- response: $.or([
247
- $.switch('outgoing.status', {
248
- $cases: {
249
- 200: $.and([
250
- $.set('outgoing.data', { $value: {} }),
251
- $.set('outgoing.data', '$path', 'foo', { $value: 'a' }),
252
- $.set('outgoing.headers', { $exec: () => ({}) }),
253
- $.set('outgoing.headers', '$path', 'foo', { $value: 'bar' }),
254
- ]),
255
- },
256
-
257
- $default: $.set('outgoing.data', { $value: {} }),
258
- }),
259
-
260
- $.switch('incoming.data', '$path', 'baz.bar', {
261
- $cases: {
262
- 1: $.and([
263
- $.merge('outgoing.data', { $value: {} }),
264
- $.remove('outgoing.data', '$path', 'foo'),
265
- ]),
266
- },
267
- }),
268
-
269
- $.switch('incoming.data', '$exec', (payload) => payload.baz.bar, {
270
- $cases: {
271
- 1: $.and([]),
272
- },
273
- }),
274
-
275
- $.switch('outgoing.headers', '$exec', (payload) => payload.foo, {
276
- $cases: {
277
- 'a': $.and([
278
- $.exec(({ context }) => {
279
- if (context.incoming.data.foo === 'a') {
280
- context.outgoing!.status = 200;
281
- }
282
- }),
283
- ]),
284
- },
285
- }),
286
- ]),
287
- },
288
- }))
289
- ).resolves.toMatchSnapshot();
290
- });
291
- });
292
-
293
- // Test generated using Keploy
294
- it('should return pong on ping method', async () => {
295
- const client = buildClient();
296
- await expect(client.ping()).resolves.toEqual('pong');
297
- });
298
-
299
-
300
- // Test generated using Keploy
301
- it('should return null on deleteExpectations method', async () => {
302
- const client = buildClient();
303
- await expect(client.deleteExpectations()).resolves.toBeNull();
304
- });
305
-
306
-
307
- // Test generated using Keploy
308
- it('should update expectation with function predicate', async () => {
309
- const client = buildClient();
310
- const result = await client.updateExpectation((context) => ({
311
- id: 'some-id',
312
- set: { schema: {} },
313
- }));
314
- expect(result).toHaveProperty('id');
315
- });
316
-
@@ -1,85 +0,0 @@
1
- import type { Expectation, IExpectationSchemaInput } from '../../expectations';
2
- import type { IServerContext } from '../../server';
3
- import type { TMethodsSchema } from '../types';
4
- import type { TFunction } from '../../../types';
5
-
6
- import { compileExpectationOperators, ICompiledExpectationOperators } from '../helpers';
7
-
8
- interface IExpectationHandlerContext<
9
- TContext extends IServerContext<any>,
10
- TInput extends IExpectationSchemaInput
11
- > {
12
- $: ICompiledExpectationOperators<TInput & TContext>;
13
- T: <T>(payload: T) => T extends TFunction<any, any[]> ? TFunction<any, any[]> : T;
14
- };
15
-
16
- interface IAnyExpectationInput<TContext extends IServerContext<any>> {
17
- transport: TContext['transport'];
18
- state: any;
19
-
20
- incoming: {
21
- headers: any;
22
- query: any;
23
- data: any;
24
- };
25
-
26
- outgoing: {
27
- headers: any;
28
- data: any;
29
- };
30
- };
31
-
32
- type TExpectationAnyConfiguration<TContext extends IServerContext<any>> =
33
- & Omit<Expectation<TContext>['configuration'], 'schema'>
34
- & Pick<Expectation<any, any>['configuration'], 'schema'>;
35
-
36
- export class Client<TContext extends IServerContext<any>> {
37
- constructor(protected methods: TMethodsSchema) {}
38
-
39
- public get ping() {
40
- return this.methods.ping;
41
- }
42
-
43
- public get deleteExpectations() {
44
- return this.methods.deleteExpectations;
45
- }
46
-
47
- public createExpectation<TInput extends IExpectationSchemaInput>(
48
- handler: TFunction<TExpectationAnyConfiguration<TContext>, [IExpectationHandlerContext<TContext, TInput>]>
49
- ): ReturnType<TMethodsSchema['createExpectation']>;
50
-
51
- public createExpectation(
52
- configuration: Expectation<IAnyExpectationInput<TContext>>['configuration']
53
- ): ReturnType<TMethodsSchema['createExpectation']>;
54
-
55
- public createExpectation(predicate: unknown): ReturnType<TMethodsSchema['createExpectation']> {
56
- return typeof predicate === 'function'
57
- ? this.methods.createExpectation(predicate(this.compileHandlerUtils()))
58
- : this.methods.createExpectation(<Expectation<IAnyExpectationInput<TContext>>['configuration']>predicate);
59
- }
60
-
61
- public updateExpectation(
62
- configuration: { id: string, set: Partial<Expectation<IAnyExpectationInput<TContext>>['configuration']> }
63
- ): ReturnType<TMethodsSchema['updateExpectation']>;
64
-
65
- public updateExpectation<TInput extends IExpectationSchemaInput>(
66
- handler: TFunction<{ id: string, set: Partial<TExpectationAnyConfiguration<TContext>> }, [
67
- IExpectationHandlerContext<TContext, TInput>
68
- ]>
69
- ): ReturnType<TMethodsSchema['updateExpectation']>
70
-
71
- public updateExpectation(predicate: unknown): ReturnType<TMethodsSchema['updateExpectation']> {
72
- return typeof predicate === 'function'
73
- ? this.methods.updateExpectation(predicate(this.compileHandlerUtils()))
74
- : this.methods.updateExpectation(<{ id: string, set: Partial<TExpectationAnyConfiguration<TContext>> }>predicate);
75
- }
76
-
77
- private compileHandlerUtils<
78
- TInput extends IExpectationSchemaInput
79
- >(): IExpectationHandlerContext<TContext, TInput> {
80
- return {
81
- $: compileExpectationOperators(),
82
- T: (payload: any) => payload,
83
- }
84
- }
85
- }
@@ -1,2 +0,0 @@
1
- export * from './method';
2
- export * from './client';
@@ -1,50 +0,0 @@
1
- import type { AxiosInstance } from 'axios';
2
-
3
- import type { SetPartialKeys, TFunction } from '../../../types';
4
- import type { Provider } from '../../server/models';
5
-
6
- import { cast } from '../../utils';
7
-
8
- type THandler<TContext, TSchema extends IClientMethodSchema> = TFunction<
9
- TFunction<Promise<TSchema['outgoing']>, [TSchema['incoming']]>,
10
- [TContext]
11
- >;
12
-
13
- export interface IClientMethodSchema {
14
- incoming?: unknown;
15
- outgoing?: unknown;
16
- };
17
-
18
- export interface IClientMethodHandlers<TSchema extends IClientMethodSchema> {
19
- remote: THandler<AxiosInstance, TSchema>;
20
- onsite: THandler<SetPartialKeys<Provider, 'server'>, TSchema>;
21
- }
22
-
23
- export class ClientMethod<TSchema extends IClientMethodSchema> {
24
- public TSchema!: TSchema;
25
-
26
- private handlers = cast<IClientMethodHandlers<TSchema>>({
27
- remote: () => () => Promise.reject(new Error('Not implemented')),
28
- onsite: () => () => Promise.reject(new Error('Not implemented')),
29
- });
30
-
31
- public register<K extends keyof IClientMethodHandlers<any>>(
32
- type: K,
33
- handler: IClientMethodHandlers<TSchema>[K]
34
- ) {
35
- this.handlers[type] = handler;
36
- return this;
37
- }
38
-
39
- public compile<K extends keyof IClientMethodHandlers<any>>(
40
- type: K,
41
- context: Parameters<IClientMethodHandlers<TSchema>[K]>[0]
42
- ) {
43
- const handler: THandler<any, any> = this.handlers[type];
44
- return handler(context);
45
- }
46
-
47
- static build<TSchema extends IClientMethodSchema>() {
48
- return new ClientMethod<TSchema>();
49
- }
50
- }
@@ -1,23 +0,0 @@
1
- import { OnsiteClient } from './onsite';
2
-
3
- // Test generated using Keploy
4
- test('updateExpectationsGroup(validInput) should return array of expectations', async () => {
5
- const provider = {}; // Mock provider
6
- const client = new OnsiteClient(<any>provider);
7
- const mockExpectationsResponse = [{ id: 1, name: 'Expectation 1' }];
8
- client['methods'] = <any>{
9
- updateExpectationsGroup: jest.fn().mockResolvedValue(mockExpectationsResponse),
10
- };
11
-
12
- const body = { set: [{ someKey: 'someValue' }] };
13
- const result = await client.updateExpectationsGroup(<any>body);
14
- expect(result).toEqual(mockExpectationsResponse);
15
- expect(client['methods'].updateExpectationsGroup).toHaveBeenCalledWith({ set: body });
16
- });
17
-
18
- // Test generated using Keploy
19
- test('build(provider) should return an instance of OnsiteClient', () => {
20
- const provider = {}; // Mock provider
21
- const clientInstance = OnsiteClient.build(<any>provider);
22
- expect(clientInstance).toBeInstanceOf(OnsiteClient);
23
- });
@@ -1,29 +0,0 @@
1
- import _ from 'lodash';
2
-
3
- import type { Provider, IServerContext, TDefaultServerContext } from '../server';
4
- import type { TEndpoints, TMethodsSchema } from './types';
5
- import type { Expectation } from '../expectations';
6
-
7
- import { Client } from './models';
8
-
9
- import * as methods from './methods';
10
-
11
- export class OnsiteClient<TContext extends IServerContext<any> = TDefaultServerContext> extends Client<TContext> {
12
- constructor(provider: Provider<any>) {
13
- super(
14
- Object
15
- .entries(methods)
16
- .reduce((acc, [name, method]) => _.set(acc, name, method.compile('onsite', provider)), <TMethodsSchema>{})
17
- );
18
- }
19
-
20
- public async updateExpectationsGroup(
21
- body: NonNullable<TEndpoints['expectationsGroupUpdate']['incoming']['data']>['set']
22
- ): Promise<Expectation['TPlain'][]> {
23
- return this.methods.updateExpectationsGroup({ set: body });
24
- }
25
-
26
- static build<TContext extends IServerContext<any> = TDefaultServerContext>(provider: Provider<any>) {
27
- return new OnsiteClient<TContext>(provider);
28
- }
29
- }
@@ -1,15 +0,0 @@
1
- import { RemoteClient } from './remote';
2
-
3
- // Test generated using Keploy
4
- it('should initialize the axios instance with correct baseURL and timeout', () => {
5
- const options = { baseUrl: 'http://localhost', timeout: 5000 };
6
- const client = new RemoteClient(options);
7
- expect(client['options'].baseUrl).toEqual('http://localhost');
8
- expect(client['options'].timeout).toEqual(5000);
9
- });
10
-
11
- // Test generated using Keploy
12
- it('should throw an error when pinging fails', async () => {
13
- const options = { baseUrl: 'http://invalidurl', timeout: 5000 };
14
- await expect(RemoteClient.connect(options)).rejects.toThrow();
15
- });
@@ -1,34 +0,0 @@
1
- import axios from 'axios';
2
- import _ from 'lodash';
3
-
4
- import { IRemoteClientConnectOptions, TMethodsSchema } from './types';
5
- import { IServerContext, TDefaultServerContext } from '../server/types';
6
- import { Client } from './models';
7
-
8
- import * as methods from './methods';
9
-
10
- export class RemoteClient<TContext extends IServerContext<any> = TDefaultServerContext> extends Client<TContext> {
11
- get updateExpectationsGroup() {
12
- return this.methods.updateExpectationsGroup;
13
- }
14
-
15
- constructor(public options: IRemoteClientConnectOptions) {
16
- const instance = axios.create({
17
- baseURL: options.baseUrl,
18
- timeout: options.timeout ?? 1000 * 10,
19
- });
20
-
21
- super(
22
- Object
23
- .entries(methods)
24
- .reduce((acc, [name, method]) => _.set(acc, name, method.compile('remote', instance)), <TMethodsSchema>{})
25
- );
26
- }
27
-
28
- static async connect<TContext extends IServerContext<any> = TDefaultServerContext>(options: IRemoteClientConnectOptions) {
29
- const client = new RemoteClient<TContext>(options);
30
-
31
- await client.ping();
32
- return client;
33
- }
34
- }
@@ -1,31 +0,0 @@
1
- import type { TFunction } from '../../types';
2
- import type config from '../config';
3
-
4
- import type * as endpoints from '../server/endpoints';
5
- import type * as methods from './methods';
6
-
7
- export interface IRemoteClientConnectOptions {
8
- baseUrl?: string;
9
- timeout?: number;
10
- }
11
-
12
- export type TMethodsSchema = {
13
- [K in keyof typeof methods]: TFunction<
14
- Promise<typeof methods[K]['TSchema']['outgoing']>, [typeof methods[K]['TSchema']['incoming']]
15
- >;
16
- };
17
-
18
- export type TEndpoints = {
19
- [K in keyof typeof endpoints]: {
20
- http: (typeof endpoints)[K]['http'];
21
- io: (typeof endpoints)[K]['io'];
22
-
23
- incoming: (typeof endpoints)[K]['TSchema']['incoming'];
24
- outgoing: (typeof endpoints)[K]['TSchema']['outgoing'];
25
-
26
- location: {
27
- url: `${typeof config['storage']['routes']['internal']['root']}${(typeof endpoints)[K]['http']['path']}`;
28
- method: (typeof endpoints)[K]['http']['method'];
29
- };
30
- };
31
- }
@@ -1,60 +0,0 @@
1
- import { handleRequestError } from './utils';
2
- import { ConnectionError } from './errors';
3
- import { InternalServerError } from './errors';
4
- import { ValidationError } from './errors';
5
-
6
- // Test generated using Keploy
7
- test('handleRequestError should throw ConnectionError when error.response is undefined', () => {
8
- const mockError = {
9
- config: {
10
- baseURL: 'http://example.com',
11
- method: 'GET',
12
- url: '/endpoint'
13
- },
14
- response: undefined
15
- };
16
-
17
- expect(() => handleRequestError(<any>mockError)).toThrow(ConnectionError);
18
- });
19
-
20
- // Test generated using Keploy
21
- test('handleRequestError should throw InternalServerError for INTERNAL_ERROR code', () => {
22
- const mockError = {
23
- config: {
24
- baseURL: 'http://example.com',
25
- method: 'GET',
26
- url: '/endpoint'
27
- },
28
- response: {
29
- data: {
30
- code: 'INTERNAL_ERROR',
31
- data: {
32
- message: 'An internal server error occurred'
33
- }
34
- }
35
- }
36
- };
37
-
38
- expect(() => handleRequestError(<any>mockError)).toThrow(InternalServerError);
39
- });
40
-
41
- // Test generated using Keploy
42
- test('handleRequestError should throw ValidationError for VALIDATION_ERROR code', () => {
43
- const mockError = {
44
- config: {
45
- baseURL: 'http://example.com',
46
- method: 'POST',
47
- url: '/endpoint'
48
- },
49
- response: {
50
- data: {
51
- code: 'VALIDATION_ERROR',
52
- data: {
53
- reasons: ['Invalid input']
54
- }
55
- }
56
- }
57
- };
58
-
59
- expect(() => handleRequestError(<any>mockError)).toThrow(ValidationError);
60
- });