@n1k1t/mock-server 0.1.61 → 0.1.63

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 (639) hide show
  1. package/lib/package.json +1 -1
  2. package/lib/src/client/helpers/expectations.d.ts.map +1 -1
  3. package/lib/src/client/helpers/expectations.js.map +1 -1
  4. package/lib/src/client/models/client.d.ts +6 -25
  5. package/lib/src/client/models/client.d.ts.map +1 -1
  6. package/lib/src/client/models/client.js +0 -2
  7. package/lib/src/client/models/client.js.map +1 -1
  8. package/lib/src/client/models/types.d.ts +28 -0
  9. package/lib/src/client/models/types.d.ts.map +1 -0
  10. package/lib/src/client/models/types.js +6 -0
  11. package/lib/src/client/models/types.js.map +1 -0
  12. package/lib/src/client/onsite.d.ts +3 -3
  13. package/lib/src/client/onsite.d.ts.map +1 -1
  14. package/lib/src/client/onsite.js.map +1 -1
  15. package/lib/src/client/remote.d.ts +4 -4
  16. package/lib/src/client/remote.d.ts.map +1 -1
  17. package/lib/src/client/remote.js +3 -3
  18. package/lib/src/client/remote.js.map +1 -1
  19. package/lib/src/expectations/models/expectation.d.ts +6 -6
  20. package/lib/src/expectations/models/expectation.d.ts.map +1 -1
  21. package/lib/src/expectations/models/expectation.js +1 -1
  22. package/lib/src/expectations/models/expectation.js.map +1 -1
  23. package/lib/src/expectations/models/operator.d.ts +1 -1
  24. package/lib/src/expectations/models/operator.d.ts.map +1 -1
  25. package/lib/src/expectations/models/storage.d.ts +1 -1
  26. package/lib/src/expectations/models/storage.d.ts.map +1 -1
  27. package/lib/src/expectations/models/storage.js.map +1 -1
  28. package/lib/src/expectations/types.d.ts +4 -4
  29. package/lib/src/expectations/types.d.ts.map +1 -1
  30. package/lib/src/expectations/types.js.map +1 -1
  31. package/lib/src/server/endpoints/expectations.create.endpoint.d.ts +1 -1
  32. package/lib/src/server/endpoints/gui.endpoint.d.ts +1 -8
  33. package/lib/src/server/endpoints/gui.endpoint.d.ts.map +1 -1
  34. package/lib/src/server/index.d.ts +17 -20
  35. package/lib/src/server/index.d.ts.map +1 -1
  36. package/lib/src/server/index.js +3 -2
  37. package/lib/src/server/index.js.map +1 -1
  38. package/lib/src/server/models/context/index.d.ts +4 -4
  39. package/lib/src/server/models/context/index.d.ts.map +1 -1
  40. package/lib/src/server/models/context/index.js +1 -1
  41. package/lib/src/server/models/context/index.js.map +1 -1
  42. package/lib/src/server/models/context/snapshot.d.ts +2 -2
  43. package/lib/src/server/models/context/snapshot.d.ts.map +1 -1
  44. package/lib/src/server/models/context/snapshot.js.map +1 -1
  45. package/lib/src/server/models/providers/model.d.ts +4 -4
  46. package/lib/src/server/models/providers/model.d.ts.map +1 -1
  47. package/lib/src/server/models/providers/model.js.map +1 -1
  48. package/lib/src/server/models/providers/storage.d.ts +5 -4
  49. package/lib/src/server/models/providers/storage.d.ts.map +1 -1
  50. package/lib/src/server/models/providers/storage.js +3 -0
  51. package/lib/src/server/models/providers/storage.js.map +1 -1
  52. package/lib/src/server/models/router.d.ts +4 -4
  53. package/lib/src/server/models/router.d.ts.map +1 -1
  54. package/lib/src/server/models/router.js.map +1 -1
  55. package/lib/src/server/models/transports/model.d.ts +1 -1
  56. package/lib/src/server/models/transports/model.d.ts.map +1 -1
  57. package/lib/src/server/models/transports/model.js.map +1 -1
  58. package/lib/src/server/models/transports/storage.d.ts +2 -1
  59. package/lib/src/server/models/transports/storage.d.ts.map +1 -1
  60. package/lib/src/server/models/transports/storage.js +3 -0
  61. package/lib/src/server/models/transports/storage.js.map +1 -1
  62. package/lib/src/server/transports/http.transport/context.d.ts +4 -4
  63. package/lib/src/server/transports/http.transport/context.d.ts.map +1 -1
  64. package/lib/src/server/transports/http.transport/context.js.map +1 -1
  65. package/lib/src/server/transports/http.transport/index.d.ts +2 -2
  66. package/lib/src/server/transports/http.transport/index.d.ts.map +1 -1
  67. package/lib/src/server/transports/http.transport/index.js.map +1 -1
  68. package/lib/src/server/transports/internal/http.transport/index.d.ts +1 -1
  69. package/lib/src/server/transports/internal/http.transport/index.d.ts.map +1 -1
  70. package/lib/src/server/transports/internal/http.transport/index.js.map +1 -1
  71. package/lib/src/server/transports/internal/io.transport/index.d.ts +1 -1
  72. package/lib/src/server/transports/internal/io.transport/index.d.ts.map +1 -1
  73. package/lib/src/server/transports/internal/io.transport/index.js.map +1 -1
  74. package/lib/src/server/transports/ws.transport/context.d.ts +3 -3
  75. package/lib/src/server/transports/ws.transport/context.d.ts.map +1 -1
  76. package/lib/src/server/transports/ws.transport/context.js.map +1 -1
  77. package/lib/src/server/transports/ws.transport/index.d.ts +2 -2
  78. package/lib/src/server/transports/ws.transport/index.d.ts.map +1 -1
  79. package/lib/src/server/transports/ws.transport/index.js.map +1 -1
  80. package/lib/src/server/types/index.d.ts +14 -4
  81. package/lib/src/server/types/index.d.ts.map +1 -1
  82. package/package.json +1 -1
  83. package/bin/index.ts +0 -33
  84. package/coverage/clover.xml +0 -1372
  85. package/coverage/cobertura-coverage.xml +0 -3466
  86. package/coverage/coverage-final.json +0 -76
  87. package/coverage/lcov-report/base.css +0 -224
  88. package/coverage/lcov-report/block-navigation.js +0 -87
  89. package/coverage/lcov-report/client/errors/connection.error.ts.html +0 -106
  90. package/coverage/lcov-report/client/errors/index.html +0 -161
  91. package/coverage/lcov-report/client/errors/index.ts.html +0 -97
  92. package/coverage/lcov-report/client/errors/internal-server.error.ts.html +0 -115
  93. package/coverage/lcov-report/client/errors/validation.error.ts.html +0 -115
  94. package/coverage/lcov-report/client/helpers/expectations.ts.html +0 -766
  95. package/coverage/lcov-report/client/helpers/index.html +0 -131
  96. package/coverage/lcov-report/client/helpers/index.ts.html +0 -88
  97. package/coverage/lcov-report/client/index.html +0 -161
  98. package/coverage/lcov-report/client/index.ts.html +0 -100
  99. package/coverage/lcov-report/client/methods/expectations-group.update.method.ts.html +0 -193
  100. package/coverage/lcov-report/client/methods/expectations.create.method.ts.html +0 -202
  101. package/coverage/lcov-report/client/methods/expectations.delete.method.ts.html +0 -184
  102. package/coverage/lcov-report/client/methods/expectations.update.method.ts.html +0 -241
  103. package/coverage/lcov-report/client/methods/index.html +0 -191
  104. package/coverage/lcov-report/client/methods/index.ts.html +0 -103
  105. package/coverage/lcov-report/client/methods/ping.method.ts.html +0 -160
  106. package/coverage/lcov-report/client/models/client.ts.html +0 -340
  107. package/coverage/lcov-report/client/models/index.html +0 -146
  108. package/coverage/lcov-report/client/models/index.ts.html +0 -91
  109. package/coverage/lcov-report/client/models/method.ts.html +0 -235
  110. package/coverage/lcov-report/client/onsite.ts.html +0 -172
  111. package/coverage/lcov-report/client/remote.ts.html +0 -187
  112. package/coverage/lcov-report/client/utils.ts.html +0 -211
  113. package/coverage/lcov-report/config/index.html +0 -131
  114. package/coverage/lcov-report/config/index.ts.html +0 -97
  115. package/coverage/lcov-report/config/model.ts.html +0 -226
  116. package/coverage/lcov-report/expectations/__utils__/index.html +0 -116
  117. package/coverage/lcov-report/expectations/__utils__/index.ts.html +0 -268
  118. package/coverage/lcov-report/expectations/index.html +0 -146
  119. package/coverage/lcov-report/expectations/index.ts.html +0 -94
  120. package/coverage/lcov-report/expectations/models/expectation.ts.html +0 -373
  121. package/coverage/lcov-report/expectations/models/index.html +0 -161
  122. package/coverage/lcov-report/expectations/models/index.ts.html +0 -94
  123. package/coverage/lcov-report/expectations/models/operator.ts.html +0 -352
  124. package/coverage/lcov-report/expectations/models/storage.ts.html +0 -211
  125. package/coverage/lcov-report/expectations/operators/and.operator.ts.html +0 -196
  126. package/coverage/lcov-report/expectations/operators/exec.operator.ts.html +0 -160
  127. package/coverage/lcov-report/expectations/operators/has.operator.ts.html +0 -778
  128. package/coverage/lcov-report/expectations/operators/if.operator.ts.html +0 -316
  129. package/coverage/lcov-report/expectations/operators/index.html +0 -281
  130. package/coverage/lcov-report/expectations/operators/index.ts.html +0 -118
  131. package/coverage/lcov-report/expectations/operators/merge.operator.ts.html +0 -379
  132. package/coverage/lcov-report/expectations/operators/not.operator.ts.html +0 -199
  133. package/coverage/lcov-report/expectations/operators/or.operator.ts.html +0 -196
  134. package/coverage/lcov-report/expectations/operators/remove.operator.ts.html +0 -238
  135. package/coverage/lcov-report/expectations/operators/root.operator.ts.html +0 -238
  136. package/coverage/lcov-report/expectations/operators/set.operator.ts.html +0 -436
  137. package/coverage/lcov-report/expectations/operators/switch.operator.ts.html +0 -463
  138. package/coverage/lcov-report/expectations/types.ts.html +0 -766
  139. package/coverage/lcov-report/expectations/utils.ts.html +0 -802
  140. package/coverage/lcov-report/favicon.png +0 -0
  141. package/coverage/lcov-report/index.html +0 -431
  142. package/coverage/lcov-report/logger/index.html +0 -131
  143. package/coverage/lcov-report/logger/index.ts.html +0 -325
  144. package/coverage/lcov-report/logger/utils.ts.html +0 -160
  145. package/coverage/lcov-report/meta/index.html +0 -146
  146. package/coverage/lcov-report/meta/index.ts.html +0 -103
  147. package/coverage/lcov-report/meta/model.ts.html +0 -172
  148. package/coverage/lcov-report/meta/storage.ts.html +0 -145
  149. package/coverage/lcov-report/prettify.css +0 -1
  150. package/coverage/lcov-report/prettify.js +0 -2
  151. package/coverage/lcov-report/server/expectations/__utils__/index.html +0 -116
  152. package/coverage/lcov-report/server/expectations/__utils__/index.ts.html +0 -199
  153. package/coverage/lcov-report/server/expectations/index.html +0 -131
  154. package/coverage/lcov-report/server/expectations/operators/and.operator.ts.html +0 -103
  155. package/coverage/lcov-report/server/expectations/operators/exec.operator.ts.html +0 -139
  156. package/coverage/lcov-report/server/expectations/operators/has.operator.ts.html +0 -358
  157. package/coverage/lcov-report/server/expectations/operators/if.operator.ts.html +0 -130
  158. package/coverage/lcov-report/server/expectations/operators/index.html +0 -266
  159. package/coverage/lcov-report/server/expectations/operators/index.ts.html +0 -112
  160. package/coverage/lcov-report/server/expectations/operators/merge.operator.ts.html +0 -193
  161. package/coverage/lcov-report/server/expectations/operators/not.operator.ts.html +0 -100
  162. package/coverage/lcov-report/server/expectations/operators/or.operator.ts.html +0 -115
  163. package/coverage/lcov-report/server/expectations/operators/remove.operator.ts.html +0 -169
  164. package/coverage/lcov-report/server/expectations/operators/set.operator.ts.html +0 -208
  165. package/coverage/lcov-report/server/expectations/operators/utils.ts.html +0 -346
  166. package/coverage/lcov-report/server/expectations/types.ts.html +0 -517
  167. package/coverage/lcov-report/server/expectations/utils.ts.html +0 -358
  168. package/coverage/lcov-report/server/models/containers/index.html +0 -161
  169. package/coverage/lcov-report/server/models/containers/index.ts.html +0 -91
  170. package/coverage/lcov-report/server/models/containers/model.ts.html +0 -328
  171. package/coverage/lcov-report/server/models/containers/storage.ts.html +0 -256
  172. package/coverage/lcov-report/server/models/containers/utils.ts.html +0 -97
  173. package/coverage/lcov-report/server/models/context/index.html +0 -146
  174. package/coverage/lcov-report/server/models/context/index.ts.html +0 -514
  175. package/coverage/lcov-report/server/models/context/snapshot.ts.html +0 -529
  176. package/coverage/lcov-report/server/models/context/utils.ts.html +0 -382
  177. package/coverage/lcov-report/server/models/endpoint.ts.html +0 -304
  178. package/coverage/lcov-report/server/models/exchanges/index.html +0 -131
  179. package/coverage/lcov-report/server/models/exchanges/index.ts.html +0 -88
  180. package/coverage/lcov-report/server/models/exchanges/socket-io.ts.html +0 -154
  181. package/coverage/lcov-report/server/models/executor/errors/index.html +0 -116
  182. package/coverage/lcov-report/server/models/executor/errors/index.ts.html +0 -130
  183. package/coverage/lcov-report/server/models/executor/index.html +0 -116
  184. package/coverage/lcov-report/server/models/executor/index.ts.html +0 -1018
  185. package/coverage/lcov-report/server/models/history/index.html +0 -146
  186. package/coverage/lcov-report/server/models/history/index.ts.html +0 -91
  187. package/coverage/lcov-report/server/models/history/model.ts.html +0 -331
  188. package/coverage/lcov-report/server/models/history/storage.ts.html +0 -184
  189. package/coverage/lcov-report/server/models/index.html +0 -161
  190. package/coverage/lcov-report/server/models/index.ts.html +0 -115
  191. package/coverage/lcov-report/server/models/providers/index.html +0 -146
  192. package/coverage/lcov-report/server/models/providers/index.ts.html +0 -91
  193. package/coverage/lcov-report/server/models/providers/model.ts.html +0 -211
  194. package/coverage/lcov-report/server/models/providers/storage.ts.html +0 -172
  195. package/coverage/lcov-report/server/models/reply.ts.html +0 -115
  196. package/coverage/lcov-report/server/models/router.ts.html +0 -313
  197. package/coverage/lcov-report/server/models/transports/index.html +0 -146
  198. package/coverage/lcov-report/server/models/transports/index.ts.html +0 -91
  199. package/coverage/lcov-report/server/models/transports/model.ts.html +0 -112
  200. package/coverage/lcov-report/server/models/transports/storage.ts.html +0 -124
  201. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  202. package/coverage/lcov-report/sorter.js +0 -196
  203. package/coverage/lcov-report/utils/common.ts.html +0 -187
  204. package/coverage/lcov-report/utils/index.html +0 -176
  205. package/coverage/lcov-report/utils/index.ts.html +0 -97
  206. package/coverage/lcov-report/utils/json.ts.html +0 -193
  207. package/coverage/lcov-report/utils/regexp.ts.html +0 -97
  208. package/coverage/lcov-report/utils/validation.ts.html +0 -190
  209. package/coverage/lcov.info +0 -3012
  210. package/discardedTests.txt +0 -35606
  211. package/images/preview.png +0 -0
  212. package/images/strategy.png +0 -0
  213. package/keploy.yml +0 -64
  214. package/lib/src/client/errors/connection.error.spec.d.ts +0 -2
  215. package/lib/src/client/errors/connection.error.spec.d.ts.map +0 -1
  216. package/lib/src/client/errors/connection.error.spec.js +0 -12
  217. package/lib/src/client/errors/connection.error.spec.js.map +0 -1
  218. package/lib/src/client/errors/internal-server.error.spec.d.ts +0 -2
  219. package/lib/src/client/errors/internal-server.error.spec.d.ts.map +0 -1
  220. package/lib/src/client/errors/internal-server.error.spec.js +0 -12
  221. package/lib/src/client/errors/internal-server.error.spec.js.map +0 -1
  222. package/lib/src/client/errors/validation.error.spec.d.ts +0 -2
  223. package/lib/src/client/errors/validation.error.spec.d.ts.map +0 -1
  224. package/lib/src/client/errors/validation.error.spec.js +0 -10
  225. package/lib/src/client/errors/validation.error.spec.js.map +0 -1
  226. package/lib/src/client/models/client.spec.d.ts +0 -2
  227. package/lib/src/client/models/client.spec.d.ts.map +0 -1
  228. package/lib/src/client/models/client.spec.js +0 -244
  229. package/lib/src/client/models/client.spec.js.map +0 -1
  230. package/lib/src/client/onsite.spec.d.ts +0 -2
  231. package/lib/src/client/onsite.spec.d.ts.map +0 -1
  232. package/lib/src/client/onsite.spec.js +0 -23
  233. package/lib/src/client/onsite.spec.js.map +0 -1
  234. package/lib/src/client/remote.spec.d.ts +0 -2
  235. package/lib/src/client/remote.spec.d.ts.map +0 -1
  236. package/lib/src/client/remote.spec.js +0 -16
  237. package/lib/src/client/remote.spec.js.map +0 -1
  238. package/lib/src/client/utils.spec.d.ts +0 -2
  239. package/lib/src/client/utils.spec.d.ts.map +0 -1
  240. package/lib/src/client/utils.spec.js +0 -57
  241. package/lib/src/client/utils.spec.js.map +0 -1
  242. package/lib/src/expectations/models/storage.spec.d.ts +0 -2
  243. package/lib/src/expectations/models/storage.spec.d.ts.map +0 -1
  244. package/lib/src/expectations/models/storage.spec.js +0 -57
  245. package/lib/src/expectations/models/storage.spec.js.map +0 -1
  246. package/lib/src/expectations/operators/and.operator.spec.d.ts +0 -2
  247. package/lib/src/expectations/operators/and.operator.spec.d.ts.map +0 -1
  248. package/lib/src/expectations/operators/and.operator.spec.js +0 -83
  249. package/lib/src/expectations/operators/and.operator.spec.js.map +0 -1
  250. package/lib/src/expectations/operators/exec.operator.spec.d.ts +0 -2
  251. package/lib/src/expectations/operators/exec.operator.spec.d.ts.map +0 -1
  252. package/lib/src/expectations/operators/exec.operator.spec.js +0 -68
  253. package/lib/src/expectations/operators/exec.operator.spec.js.map +0 -1
  254. package/lib/src/expectations/operators/has.operator.spec.d.ts +0 -2
  255. package/lib/src/expectations/operators/has.operator.spec.d.ts.map +0 -1
  256. package/lib/src/expectations/operators/has.operator.spec.js +0 -444
  257. package/lib/src/expectations/operators/has.operator.spec.js.map +0 -1
  258. package/lib/src/expectations/operators/if.operator.spec.d.ts +0 -2
  259. package/lib/src/expectations/operators/if.operator.spec.d.ts.map +0 -1
  260. package/lib/src/expectations/operators/if.operator.spec.js +0 -132
  261. package/lib/src/expectations/operators/if.operator.spec.js.map +0 -1
  262. package/lib/src/expectations/operators/merge.operator.spec.d.ts +0 -2
  263. package/lib/src/expectations/operators/merge.operator.spec.d.ts.map +0 -1
  264. package/lib/src/expectations/operators/merge.operator.spec.js +0 -75
  265. package/lib/src/expectations/operators/merge.operator.spec.js.map +0 -1
  266. package/lib/src/expectations/operators/not.operator.spec.d.ts +0 -2
  267. package/lib/src/expectations/operators/not.operator.spec.d.ts.map +0 -1
  268. package/lib/src/expectations/operators/not.operator.spec.js +0 -46
  269. package/lib/src/expectations/operators/not.operator.spec.js.map +0 -1
  270. package/lib/src/expectations/operators/or.operator.spec.d.ts +0 -2
  271. package/lib/src/expectations/operators/or.operator.spec.d.ts.map +0 -1
  272. package/lib/src/expectations/operators/or.operator.spec.js +0 -84
  273. package/lib/src/expectations/operators/or.operator.spec.js.map +0 -1
  274. package/lib/src/expectations/operators/remove.operator.spec.d.ts +0 -2
  275. package/lib/src/expectations/operators/remove.operator.spec.d.ts.map +0 -1
  276. package/lib/src/expectations/operators/remove.operator.spec.js +0 -67
  277. package/lib/src/expectations/operators/remove.operator.spec.js.map +0 -1
  278. package/lib/src/expectations/operators/root.operator.spec.d.ts +0 -2
  279. package/lib/src/expectations/operators/root.operator.spec.d.ts.map +0 -1
  280. package/lib/src/expectations/operators/root.operator.spec.js +0 -29
  281. package/lib/src/expectations/operators/root.operator.spec.js.map +0 -1
  282. package/lib/src/expectations/operators/set.operator.spec.d.ts +0 -2
  283. package/lib/src/expectations/operators/set.operator.spec.d.ts.map +0 -1
  284. package/lib/src/expectations/operators/set.operator.spec.js +0 -111
  285. package/lib/src/expectations/operators/set.operator.spec.js.map +0 -1
  286. package/lib/src/expectations/operators/switch.operator.spec.d.ts +0 -2
  287. package/lib/src/expectations/operators/switch.operator.spec.d.ts.map +0 -1
  288. package/lib/src/expectations/operators/switch.operator.spec.js +0 -139
  289. package/lib/src/expectations/operators/switch.operator.spec.js.map +0 -1
  290. package/lib/src/expectations/utils/location.spec.d.ts +0 -2
  291. package/lib/src/expectations/utils/location.spec.d.ts.map +0 -1
  292. package/lib/src/expectations/utils/location.spec.js +0 -62
  293. package/lib/src/expectations/utils/location.spec.js.map +0 -1
  294. package/lib/src/expectations/utils/schema.spec.d.ts +0 -2
  295. package/lib/src/expectations/utils/schema.spec.d.ts.map +0 -1
  296. package/lib/src/expectations/utils/schema.spec.js +0 -19
  297. package/lib/src/expectations/utils/schema.spec.js.map +0 -1
  298. package/lib/src/meta/model.spec.d.ts +0 -2
  299. package/lib/src/meta/model.spec.d.ts.map +0 -1
  300. package/lib/src/meta/model.spec.js +0 -28
  301. package/lib/src/meta/model.spec.js.map +0 -1
  302. package/lib/src/meta/storage.spec.d.ts +0 -2
  303. package/lib/src/meta/storage.spec.d.ts.map +0 -1
  304. package/lib/src/meta/storage.spec.js +0 -19
  305. package/lib/src/meta/storage.spec.js.map +0 -1
  306. package/lib/src/server/models/containers/model.spec.d.ts +0 -2
  307. package/lib/src/server/models/containers/model.spec.d.ts.map +0 -1
  308. package/lib/src/server/models/containers/model.spec.js +0 -79
  309. package/lib/src/server/models/containers/model.spec.js.map +0 -1
  310. package/lib/src/server/models/containers/storage.spec.d.ts +0 -2
  311. package/lib/src/server/models/containers/storage.spec.d.ts.map +0 -1
  312. package/lib/src/server/models/containers/storage.spec.js +0 -39
  313. package/lib/src/server/models/containers/storage.spec.js.map +0 -1
  314. package/lib/src/server/models/context/index.spec.d.ts +0 -2
  315. package/lib/src/server/models/context/index.spec.d.ts.map +0 -1
  316. package/lib/src/server/models/context/index.spec.js +0 -143
  317. package/lib/src/server/models/context/index.spec.js.map +0 -1
  318. package/lib/src/server/models/context/snapshot.spec.d.ts +0 -2
  319. package/lib/src/server/models/context/snapshot.spec.d.ts.map +0 -1
  320. package/lib/src/server/models/context/snapshot.spec.js +0 -75
  321. package/lib/src/server/models/context/snapshot.spec.js.map +0 -1
  322. package/lib/src/server/models/context/utils.spec.d.ts +0 -2
  323. package/lib/src/server/models/context/utils.spec.d.ts.map +0 -1
  324. package/lib/src/server/models/context/utils.spec.js +0 -69
  325. package/lib/src/server/models/context/utils.spec.js.map +0 -1
  326. package/lib/src/server/models/endpoint.spec.d.ts +0 -2
  327. package/lib/src/server/models/endpoint.spec.d.ts.map +0 -1
  328. package/lib/src/server/models/endpoint.spec.js +0 -28
  329. package/lib/src/server/models/endpoint.spec.js.map +0 -1
  330. package/lib/src/server/models/exchanges/socket-io.spec.d.ts +0 -2
  331. package/lib/src/server/models/exchanges/socket-io.spec.d.ts.map +0 -1
  332. package/lib/src/server/models/exchanges/socket-io.spec.js +0 -12
  333. package/lib/src/server/models/exchanges/socket-io.spec.js.map +0 -1
  334. package/lib/src/server/models/executor/errors/index.spec.d.ts +0 -2
  335. package/lib/src/server/models/executor/errors/index.spec.d.ts.map +0 -1
  336. package/lib/src/server/models/executor/errors/index.spec.js +0 -23
  337. package/lib/src/server/models/executor/errors/index.spec.js.map +0 -1
  338. package/lib/src/server/models/executor/index.spec.d.ts +0 -2
  339. package/lib/src/server/models/executor/index.spec.d.ts.map +0 -1
  340. package/lib/src/server/models/executor/index.spec.js +0 -137
  341. package/lib/src/server/models/executor/index.spec.js.map +0 -1
  342. package/lib/src/server/models/history/model.spec.d.ts +0 -2
  343. package/lib/src/server/models/history/model.spec.d.ts.map +0 -1
  344. package/lib/src/server/models/history/model.spec.js +0 -30
  345. package/lib/src/server/models/history/model.spec.js.map +0 -1
  346. package/lib/src/server/models/history/storage.spec.d.ts +0 -2
  347. package/lib/src/server/models/history/storage.spec.d.ts.map +0 -1
  348. package/lib/src/server/models/history/storage.spec.js +0 -42
  349. package/lib/src/server/models/history/storage.spec.js.map +0 -1
  350. package/lib/src/server/models/providers/model.spec.d.ts +0 -2
  351. package/lib/src/server/models/providers/model.spec.d.ts.map +0 -1
  352. package/lib/src/server/models/providers/model.spec.js +0 -13
  353. package/lib/src/server/models/providers/model.spec.js.map +0 -1
  354. package/lib/src/server/models/providers/storage.spec.d.ts +0 -2
  355. package/lib/src/server/models/providers/storage.spec.d.ts.map +0 -1
  356. package/lib/src/server/models/providers/storage.spec.js +0 -19
  357. package/lib/src/server/models/providers/storage.spec.js.map +0 -1
  358. package/lib/src/server/models/reply.spec.d.ts +0 -2
  359. package/lib/src/server/models/reply.spec.d.ts.map +0 -1
  360. package/lib/src/server/models/reply.spec.js +0 -20
  361. package/lib/src/server/models/reply.spec.js.map +0 -1
  362. package/lib/src/server/models/router.spec.d.ts +0 -2
  363. package/lib/src/server/models/router.spec.d.ts.map +0 -1
  364. package/lib/src/server/models/router.spec.js +0 -46
  365. package/lib/src/server/models/router.spec.js.map +0 -1
  366. package/lib/src/server/models/transports/storage.spec.d.ts +0 -2
  367. package/lib/src/server/models/transports/storage.spec.d.ts.map +0 -1
  368. package/lib/src/server/models/transports/storage.spec.js +0 -13
  369. package/lib/src/server/models/transports/storage.spec.js.map +0 -1
  370. package/lib/src/server/services/analytics.service.spec.d.ts +0 -2
  371. package/lib/src/server/services/analytics.service.spec.d.ts.map +0 -1
  372. package/lib/src/server/services/analytics.service.spec.js +0 -35
  373. package/lib/src/server/services/analytics.service.spec.js.map +0 -1
  374. package/lib/src/server/services/metrics.service.spec.d.ts +0 -2
  375. package/lib/src/server/services/metrics.service.spec.d.ts.map +0 -1
  376. package/lib/src/server/services/metrics.service.spec.js +0 -35
  377. package/lib/src/server/services/metrics.service.spec.js.map +0 -1
  378. package/lib/src/utils/index.spec.d.ts +0 -2
  379. package/lib/src/utils/index.spec.d.ts.map +0 -1
  380. package/lib/src/utils/index.spec.js +0 -30
  381. package/lib/src/utils/index.spec.js.map +0 -1
  382. package/lib/tsconfig.tsbuildinfo +0 -1
  383. package/lib/vite.config.d.ts +0 -3
  384. package/lib/vite.config.d.ts.map +0 -1
  385. package/lib/vite.config.js +0 -57
  386. package/lib/vite.config.js.map +0 -1
  387. package/src/client/errors/connection.error.spec.ts +0 -10
  388. package/src/client/errors/connection.error.ts +0 -7
  389. package/src/client/errors/index.ts +0 -4
  390. package/src/client/errors/internal-server.error.spec.ts +0 -12
  391. package/src/client/errors/internal-server.error.ts +0 -10
  392. package/src/client/errors/types.ts +0 -3
  393. package/src/client/errors/validation.error.spec.ts +0 -9
  394. package/src/client/errors/validation.error.ts +0 -10
  395. package/src/client/helpers/expectations.ts +0 -227
  396. package/src/client/helpers/index.ts +0 -1
  397. package/src/client/index.ts +0 -5
  398. package/src/client/methods/expectations-group.update.method.ts +0 -36
  399. package/src/client/methods/expectations.create.method.ts +0 -39
  400. package/src/client/methods/expectations.delete.method.ts +0 -33
  401. package/src/client/methods/expectations.update.method.ts +0 -58
  402. package/src/client/methods/index.ts +0 -6
  403. package/src/client/methods/ping.method.ts +0 -25
  404. package/src/client/models/__snapshots__/client.spec.ts.snap +0 -1294
  405. package/src/client/models/client.spec.ts +0 -316
  406. package/src/client/models/client.ts +0 -85
  407. package/src/client/models/index.ts +0 -2
  408. package/src/client/models/method.ts +0 -50
  409. package/src/client/onsite.spec.ts +0 -23
  410. package/src/client/onsite.ts +0 -29
  411. package/src/client/remote.spec.ts +0 -15
  412. package/src/client/remote.ts +0 -34
  413. package/src/client/types.ts +0 -31
  414. package/src/client/utils.spec.ts +0 -60
  415. package/src/client/utils.ts +0 -41
  416. package/src/config/index.ts +0 -34
  417. package/src/config/model.ts +0 -24
  418. package/src/expectations/__utils__/index.ts +0 -61
  419. package/src/expectations/errors/index.ts +0 -7
  420. package/src/expectations/index.ts +0 -3
  421. package/src/expectations/models/expectation.ts +0 -96
  422. package/src/expectations/models/index.ts +0 -3
  423. package/src/expectations/models/operator.ts +0 -89
  424. package/src/expectations/models/storage.spec.ts +0 -70
  425. package/src/expectations/models/storage.ts +0 -42
  426. package/src/expectations/operators/and.operator.spec.ts +0 -59
  427. package/src/expectations/operators/and.operator.ts +0 -37
  428. package/src/expectations/operators/exec.operator.spec.ts +0 -47
  429. package/src/expectations/operators/exec.operator.ts +0 -25
  430. package/src/expectations/operators/has.operator.spec.ts +0 -514
  431. package/src/expectations/operators/has.operator.ts +0 -230
  432. package/src/expectations/operators/if.operator.spec.ts +0 -116
  433. package/src/expectations/operators/if.operator.ts +0 -77
  434. package/src/expectations/operators/index.ts +0 -11
  435. package/src/expectations/operators/merge.operator.spec.ts +0 -48
  436. package/src/expectations/operators/merge.operator.ts +0 -97
  437. package/src/expectations/operators/not.operator.spec.ts +0 -12
  438. package/src/expectations/operators/not.operator.ts +0 -38
  439. package/src/expectations/operators/or.operator.spec.ts +0 -60
  440. package/src/expectations/operators/or.operator.ts +0 -37
  441. package/src/expectations/operators/remove.operator.spec.ts +0 -40
  442. package/src/expectations/operators/remove.operator.ts +0 -50
  443. package/src/expectations/operators/root.operator.spec.ts +0 -26
  444. package/src/expectations/operators/root.operator.ts +0 -51
  445. package/src/expectations/operators/set.operator.spec.ts +0 -96
  446. package/src/expectations/operators/set.operator.ts +0 -116
  447. package/src/expectations/operators/switch.operator.spec.ts +0 -157
  448. package/src/expectations/operators/switch.operator.ts +0 -126
  449. package/src/expectations/types.ts +0 -225
  450. package/src/expectations/utils/index.ts +0 -3
  451. package/src/expectations/utils/json.ts +0 -22
  452. package/src/expectations/utils/location.spec.ts +0 -64
  453. package/src/expectations/utils/location.ts +0 -180
  454. package/src/expectations/utils/schema.spec.ts +0 -17
  455. package/src/expectations/utils/schema.ts +0 -60
  456. package/src/gui/app/components/chart.component/index.ts +0 -173
  457. package/src/gui/app/components/chart.component/style.scss +0 -4
  458. package/src/gui/app/components/checkbox-area.component/index.ts +0 -101
  459. package/src/gui/app/components/checkbox-area.component/item.component.ts +0 -72
  460. package/src/gui/app/components/checkbox-area.component/style.scss +0 -19
  461. package/src/gui/app/components/checkbox-area.component/template.hbs +0 -3
  462. package/src/gui/app/components/curtain.component/index.ts +0 -19
  463. package/src/gui/app/components/curtain.component/style.scss +0 -14
  464. package/src/gui/app/components/empty.component/index.ts +0 -10
  465. package/src/gui/app/components/empty.component/style.scss +0 -34
  466. package/src/gui/app/components/empty.component/template.hbs +0 -6
  467. package/src/gui/app/components/expectation.component/index.ts +0 -60
  468. package/src/gui/app/components/expectation.component/style.scss +0 -5
  469. package/src/gui/app/components/expectation.component/template.hbs +0 -5
  470. package/src/gui/app/components/header.component/index.ts +0 -81
  471. package/src/gui/app/components/header.component/style.scss +0 -46
  472. package/src/gui/app/components/header.component/template.hbs +0 -15
  473. package/src/gui/app/components/history.component/index.ts +0 -86
  474. package/src/gui/app/components/history.component/style.scss +0 -5
  475. package/src/gui/app/components/history.component/template.hbs +0 -62
  476. package/src/gui/app/components/index.ts +0 -11
  477. package/src/gui/app/components/loader.component/index.ts +0 -12
  478. package/src/gui/app/components/loader.component/style.scss +0 -39
  479. package/src/gui/app/components/panel.component/index.ts +0 -52
  480. package/src/gui/app/components/panel.component/style.scss +0 -60
  481. package/src/gui/app/components/panel.component/template.hbs +0 -13
  482. package/src/gui/app/components/popups.component/index.ts +0 -26
  483. package/src/gui/app/components/popups.component/style.scss +0 -51
  484. package/src/gui/app/components/popups.component/template.hbs +0 -9
  485. package/src/gui/app/components/search.component/index.ts +0 -67
  486. package/src/gui/app/components/search.component/style.scss +0 -43
  487. package/src/gui/app/components/search.component/template.hbs +0 -7
  488. package/src/gui/app/components/viewer.component/index.ts +0 -28
  489. package/src/gui/app/components/viewer.component/style.scss +0 -38
  490. package/src/gui/app/components/viewer.component/template.hbs +0 -3
  491. package/src/gui/app/context.ts +0 -76
  492. package/src/gui/app/handlebars/helpers.ts +0 -32
  493. package/src/gui/app/handlebars/index.ts +0 -11
  494. package/src/gui/app/handlebars/partials/expectation-meta.hbs +0 -53
  495. package/src/gui/app/handlebars/partials/index.ts +0 -2
  496. package/src/gui/app/handlebars/partials/truncated.hbs +0 -10
  497. package/src/gui/app/handlebars/utils.ts +0 -9
  498. package/src/gui/app/main.ts +0 -38
  499. package/src/gui/app/models/button.ts +0 -41
  500. package/src/gui/app/models/client-storage.ts +0 -21
  501. package/src/gui/app/models/component.ts +0 -79
  502. package/src/gui/app/models/context.ts +0 -14
  503. package/src/gui/app/models/dynamic-storage.ts +0 -36
  504. package/src/gui/app/models/form.ts +0 -75
  505. package/src/gui/app/models/index.ts +0 -7
  506. package/src/gui/app/models/section.ts +0 -82
  507. package/src/gui/app/sections/analytics.section/index.ts +0 -97
  508. package/src/gui/app/sections/analytics.section/style.scss +0 -1
  509. package/src/gui/app/sections/analytics.section/template.hbs +0 -6
  510. package/src/gui/app/sections/expectations.section/index.ts +0 -179
  511. package/src/gui/app/sections/expectations.section/style.scss +0 -1
  512. package/src/gui/app/sections/expectations.section/template.hbs +0 -15
  513. package/src/gui/app/sections/history.section/index.ts +0 -175
  514. package/src/gui/app/sections/history.section/style.scss +0 -10
  515. package/src/gui/app/sections/history.section/templates/actions.hbs +0 -5
  516. package/src/gui/app/sections/history.section/templates/section.hbs +0 -15
  517. package/src/gui/app/sections/index.ts +0 -4
  518. package/src/gui/app/sections/settings.section/index.ts +0 -63
  519. package/src/gui/app/sections/settings.section/style.scss +0 -24
  520. package/src/gui/app/sections/settings.section/templates/cache.hbs +0 -6
  521. package/src/gui/app/sections/settings.section/templates/section.hbs +0 -6
  522. package/src/gui/app/sections/settings.section/templates/stats.hbs +0 -6
  523. package/src/gui/app/setup.ts +0 -7
  524. package/src/gui/app/tsconfig.json +0 -20
  525. package/src/gui/app/types/dev.ts +0 -6
  526. package/src/gui/app/types/index.ts +0 -1
  527. package/src/gui/app/types/window.global.ts +0 -9
  528. package/src/gui/app/utils.ts +0 -15
  529. package/src/gui/assets/fa-all.css +0 -5
  530. package/src/gui/assets/fa-regular-400.woff2 +0 -0
  531. package/src/gui/assets/fa-solid-900.woff2 +0 -0
  532. package/src/gui/assets/favicon.png +0 -0
  533. package/src/gui/index.html +0 -18
  534. package/src/gui/styles/_constants.scss +0 -11
  535. package/src/gui/styles/_elements.scss +0 -216
  536. package/src/gui/styles/_soon.scss +0 -35
  537. package/src/gui/styles/main.scss +0 -245
  538. package/src/index.ts +0 -9
  539. package/src/logger/index.ts +0 -80
  540. package/src/logger/types.ts +0 -4
  541. package/src/logger/utils.ts +0 -25
  542. package/src/meta/index.ts +0 -6
  543. package/src/meta/model.spec.ts +0 -28
  544. package/src/meta/model.ts +0 -29
  545. package/src/meta/storage.spec.ts +0 -18
  546. package/src/meta/storage.ts +0 -20
  547. package/src/server/endpoints/cache.delete.endpoint.ts +0 -54
  548. package/src/server/endpoints/cache.usage.get.endpoint.ts +0 -12
  549. package/src/server/endpoints/config.get.endpoint.ts +0 -10
  550. package/src/server/endpoints/expectations-group.update.endpoint.ts +0 -32
  551. package/src/server/endpoints/expectations.create.endpoint.ts +0 -23
  552. package/src/server/endpoints/expectations.delete.endpoint.ts +0 -12
  553. package/src/server/endpoints/expectations.get-list.endpoint.ts +0 -15
  554. package/src/server/endpoints/expectations.update.endpoint.ts +0 -29
  555. package/src/server/endpoints/gui.endpoint.ts +0 -76
  556. package/src/server/endpoints/history.delete.endpoint.ts +0 -10
  557. package/src/server/endpoints/history.get-list.endpoint.ts +0 -15
  558. package/src/server/endpoints/index.ts +0 -18
  559. package/src/server/endpoints/metrics.endpoint.ts +0 -12
  560. package/src/server/endpoints/ping.endpoint.ts +0 -7
  561. package/src/server/endpoints/stats.endpoint.ts +0 -20
  562. package/src/server/index.ts +0 -182
  563. package/src/server/models/containers/index.ts +0 -2
  564. package/src/server/models/containers/model.spec.ts +0 -81
  565. package/src/server/models/containers/model.ts +0 -79
  566. package/src/server/models/containers/storage.spec.ts +0 -41
  567. package/src/server/models/containers/storage.ts +0 -59
  568. package/src/server/models/containers/utils.ts +0 -4
  569. package/src/server/models/context/index.spec.ts +0 -171
  570. package/src/server/models/context/index.ts +0 -136
  571. package/src/server/models/context/snapshot.spec.ts +0 -84
  572. package/src/server/models/context/snapshot.ts +0 -148
  573. package/src/server/models/context/types.ts +0 -65
  574. package/src/server/models/context/utils.spec.ts +0 -77
  575. package/src/server/models/context/utils.ts +0 -99
  576. package/src/server/models/endpoint.spec.ts +0 -28
  577. package/src/server/models/endpoint.ts +0 -69
  578. package/src/server/models/exchanges/index.ts +0 -1
  579. package/src/server/models/exchanges/socket-io.spec.ts +0 -13
  580. package/src/server/models/exchanges/socket-io.ts +0 -14
  581. package/src/server/models/executor/errors/index.spec.ts +0 -23
  582. package/src/server/models/executor/errors/index.ts +0 -15
  583. package/src/server/models/executor/index.spec.ts +0 -148
  584. package/src/server/models/executor/index.ts +0 -297
  585. package/src/server/models/history/index.ts +0 -2
  586. package/src/server/models/history/model.spec.ts +0 -35
  587. package/src/server/models/history/model.ts +0 -82
  588. package/src/server/models/history/storage.spec.ts +0 -41
  589. package/src/server/models/history/storage.ts +0 -38
  590. package/src/server/models/index.ts +0 -11
  591. package/src/server/models/providers/index.ts +0 -2
  592. package/src/server/models/providers/model.spec.ts +0 -11
  593. package/src/server/models/providers/model.ts +0 -33
  594. package/src/server/models/providers/storage.spec.ts +0 -21
  595. package/src/server/models/providers/storage.ts +0 -34
  596. package/src/server/models/reply.spec.ts +0 -17
  597. package/src/server/models/reply.ts +0 -10
  598. package/src/server/models/router.spec.ts +0 -50
  599. package/src/server/models/router.ts +0 -79
  600. package/src/server/models/service.ts +0 -5
  601. package/src/server/models/transports/index.ts +0 -2
  602. package/src/server/models/transports/model.ts +0 -9
  603. package/src/server/models/transports/storage.spec.ts +0 -14
  604. package/src/server/models/transports/storage.ts +0 -13
  605. package/src/server/services/analytics.service.spec.ts +0 -38
  606. package/src/server/services/analytics.service.ts +0 -58
  607. package/src/server/services/index.ts +0 -2
  608. package/src/server/services/metrics.service.spec.ts +0 -42
  609. package/src/server/services/metrics.service.ts +0 -46
  610. package/src/server/transports/http.transport/context.ts +0 -72
  611. package/src/server/transports/http.transport/executor.ts +0 -156
  612. package/src/server/transports/http.transport/index.ts +0 -53
  613. package/src/server/transports/index.ts +0 -3
  614. package/src/server/transports/internal/http.transport/context.ts +0 -50
  615. package/src/server/transports/internal/http.transport/executor.ts +0 -56
  616. package/src/server/transports/internal/http.transport/index.ts +0 -23
  617. package/src/server/transports/internal/http.transport/reply.ts +0 -82
  618. package/src/server/transports/internal/index.ts +0 -2
  619. package/src/server/transports/internal/io.transport/context.ts +0 -40
  620. package/src/server/transports/internal/io.transport/executor.ts +0 -27
  621. package/src/server/transports/internal/io.transport/index.ts +0 -36
  622. package/src/server/transports/internal/io.transport/reply.ts +0 -26
  623. package/src/server/transports/internal/utils.ts +0 -6
  624. package/src/server/transports/ws.transport/context.ts +0 -90
  625. package/src/server/transports/ws.transport/executor.ts +0 -64
  626. package/src/server/transports/ws.transport/index.ts +0 -105
  627. package/src/server/types/index.ts +0 -32
  628. package/src/server/utils/index.ts +0 -35
  629. package/src/utils/index.spec.ts +0 -31
  630. package/src/utils/index.ts +0 -51
  631. package/test/index.ts +0 -299
  632. package/test/providers/index.ts +0 -2
  633. package/test/providers/root.ts +0 -241
  634. package/test/providers/statics.ts +0 -37
  635. package/tsconfig.json +0 -108
  636. package/tsconfig.tsbuildinfo +0 -1
  637. package/types/common.ts +0 -127
  638. package/types/index.ts +0 -1
  639. 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
- });