@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,230 +0,0 @@
1
- import minimatch from 'minimatch';
2
- import _ from 'lodash';
3
-
4
- import { checkIsLocationInContext, extractContextByLocation, extractWithJsonPathSafe } from '../utils';
5
- import { PartialDeep, TFunction } from '../../../types';
6
- import { ExpectationOperator } from '../models/operator';
7
- import {
8
- CompileExpectationOperatorValue,
9
- CompileExpectationOperatorValueWithPredicate,
10
- IExpectationSchemaContext,
11
- IExpectationExecUtils,
12
- TExpectationMetaTag,
13
- TExpectationOperatorLocation,
14
- } from '../types';
15
-
16
- export default class HasExpectationOperator<
17
- TContext extends IExpectationSchemaContext,
18
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation,
19
- TValue = void
20
- > extends ExpectationOperator<
21
- TContext,
22
- {
23
- [K in TLocation]: {
24
- $location: K;
25
-
26
- $path?: string;
27
- $jsonPath?: string;
28
-
29
- $regExp?: RegExp;
30
- $regExpAnyOf?: RegExp[];
31
-
32
- $match?: NonNullable<CompileExpectationOperatorValue<TContext, K, TValue>> extends object
33
- ? PartialDeep<NonNullable<CompileExpectationOperatorValue<TContext, K, TValue>>>
34
- : string;
35
-
36
- $matchAnyOf?: (
37
- NonNullable<CompileExpectationOperatorValue<TContext, K, TValue>> extends object
38
- ? PartialDeep<NonNullable<CompileExpectationOperatorValue<TContext, K, TValue>>>
39
- : string
40
- )[];
41
-
42
- $value?: CompileExpectationOperatorValueWithPredicate<TContext, K, TValue>;
43
- $valueAnyOf?: CompileExpectationOperatorValueWithPredicate<TContext, K, TValue>[];
44
-
45
- $exec?: string | TFunction<boolean, [
46
- CompileExpectationOperatorValue<TContext, K, TValue>,
47
- IExpectationExecUtils<TContext>
48
- ]>;
49
- };
50
- }[TLocation]
51
- > {
52
- public compiled = {
53
- ...(this.command.$regExp && {
54
- regExp: new RegExp(this.command.$regExp.source, this.command.$regExp.flags)
55
- }),
56
-
57
- ...(this.command.$regExpAnyOf && {
58
- regExpAnyOf: this.command.$regExpAnyOf.map((exp) => new RegExp(exp.source, exp.flags)),
59
- }),
60
-
61
- ...(this.command.$exec && {
62
- exec: this.compileExecHandler(this.command.$exec, ['payload', 'utils']),
63
- }),
64
- };
65
-
66
- public get tags(): TExpectationMetaTag[] {
67
- if (this.command.$location !== 'path' && this.command.$location !== 'method') {
68
- return [];
69
- }
70
-
71
- if (this.command.$value) {
72
- return [{ location: this.command.$location, value: String(this.command.$value) }];
73
- }
74
- if (this.command.$valueAnyOf) {
75
- return this.command.$valueAnyOf.map((value) => (<TExpectationMetaTag>{
76
- location: this.command.$location,
77
- value: String(value)
78
- }));
79
- }
80
-
81
- if (this.command.$match) {
82
- return [{ location: this.command.$location, value: String(this.command.$match) }];
83
- }
84
- if (this.command.$matchAnyOf) {
85
- return this.command.$matchAnyOf.map((value) => (<TExpectationMetaTag>{
86
- location: this.command.$location,
87
- value: String(value)
88
- }));
89
- }
90
-
91
- if (this.command.$regExp) {
92
- return [{ location: this.command.$location, value: this.command.$regExp.source }];
93
- }
94
- if (this.command.$regExpAnyOf) {
95
- return this.command.$regExpAnyOf.map((value) => (<TExpectationMetaTag>{
96
- location: this.command.$location,
97
- value: value.source,
98
- }));
99
- }
100
-
101
- return [];
102
- }
103
-
104
- public match(context: TContext): boolean {
105
- if (!checkIsLocationInContext(this.command.$location, context)) {
106
- return false;
107
- }
108
-
109
- const payload = extractContextByLocation(this.command.$location, context);
110
- if (!payload) {
111
- return false;
112
- }
113
-
114
- switch(payload.type) {
115
- case 'string': {
116
- if (this.command.$value !== undefined) {
117
- return payload.value === this.command.$value;
118
- }
119
- if (this.command.$valueAnyOf) {
120
- return this.command.$valueAnyOf.some((value) => payload.value === value);
121
- }
122
-
123
- if (this.compiled.regExp) {
124
- return this.compiled.regExp.test(payload.value ?? '');
125
- }
126
- if (this.compiled.regExpAnyOf) {
127
- return this.compiled.regExpAnyOf.some((regExp) => regExp.test(payload.value ?? ''));
128
- }
129
-
130
- if (typeof this.command.$match === 'string') {
131
- return minimatch(payload.value ?? '', this.command.$match);
132
- }
133
- if (this.command.$matchAnyOf) {
134
- return this.command.$matchAnyOf.some((pattern) => minimatch(payload.value ?? '', String(pattern)));
135
- }
136
-
137
- if (this.compiled.exec) {
138
- return this.compiled.exec('match', context, payload.value) === true;
139
- }
140
-
141
- return false;
142
- }
143
-
144
- case 'number': {
145
- if (this.command.$value !== undefined) {
146
- return payload.value === this.command.$value;
147
- }
148
- if (this.command.$valueAnyOf) {
149
- return this.command.$valueAnyOf.some((value) => payload.value === value);
150
- }
151
-
152
- if (typeof this.command.$match === 'string') {
153
- return minimatch(String(payload.value), this.command.$match);
154
- }
155
- if (this.command.$matchAnyOf) {
156
- const value = String(payload.value);
157
- return this.command.$matchAnyOf.some((pattern) => minimatch(value, String(pattern)));
158
- }
159
-
160
- if (this.compiled.exec) {
161
- return this.compiled.exec('match', context, payload.value) === true;
162
- }
163
-
164
- return false;
165
- }
166
-
167
- case 'buffer': {
168
- if (this.compiled.exec) {
169
- return this.compiled.exec('match', context, payload.value) === true;
170
- }
171
-
172
- return false;
173
- }
174
-
175
- case 'object': {
176
- if (this.command.$path && !_.has(payload.value, this.command.$path)) {
177
- return false;
178
- }
179
-
180
- const values = (
181
- this.command.$path
182
- ? [_.get(payload.value, this.command.$path)]
183
- : (this.command.$jsonPath && _.isObject(payload.value))
184
- ? extractWithJsonPathSafe({ path: this.command.$jsonPath, json: payload.value }).results?.map(({ value }) => value)
185
- : [payload.value]
186
- ) ?? [];
187
-
188
- if (this.command.$value !== undefined) {
189
- return values.every((value) => _.isEqual(this.command.$value, value));
190
- }
191
- if (this.command.$valueAnyOf) {
192
- return values.every((source) => this.command.$valueAnyOf!.some((target) => _.isEqual(source, target)));
193
- }
194
-
195
- if (this.compiled.regExp) {
196
- return values.every((value) => this.compiled.regExp!.test(String(value)));
197
- }
198
- if (this.compiled.regExpAnyOf) {
199
- return values.every((value) => this.compiled.regExpAnyOf!.some((exp) => exp.test(String(value))));
200
- }
201
-
202
- if (typeof this.command.$match === 'string') {
203
- return values.every((value) => minimatch(String(value), <string>this.command.$match));
204
- }
205
- if (typeof this.command.$match === 'object') {
206
- return values.every((value) => _.isMatch(value, <object>this.command.$match));
207
- }
208
-
209
- if (typeof this.command.$matchAnyOf?.[0] === 'string') {
210
- return values.every((value) => this.command.$matchAnyOf!.some((pattern) => minimatch(String(value), String(pattern))));
211
- }
212
- if (typeof this.command.$matchAnyOf?.[0] === 'object') {
213
- return values.every((value) => this.command.$matchAnyOf!.some((target) => _.isMatch(value, <object>target)));
214
- }
215
-
216
- if (this.compiled.exec) {
217
- return values.every((value) => this.compiled.exec!('match', context, value) === true);
218
- }
219
-
220
- return values.length !== 0;
221
- }
222
-
223
- default: return false;
224
- }
225
- }
226
-
227
- public manipulate<T extends TContext>(context: T): T {
228
- return context;
229
- }
230
- }
@@ -1,116 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.If', () => {
5
- describe('matching', () => {
6
- it('should match by schema with simple valid condition and valid [then] target branch', () => {
7
- const operator = new operators.$if(operators, {
8
- $condition: { $has: { $location: 'path', $regExp: /^\/foo/ } },
9
- $then: { $has: { $location: 'method', $value: 'POST' } },
10
- });
11
-
12
- expect(operator.match(buildExpectationContext())).toBeTruthy();
13
- });
14
-
15
- it('should match by schema with simple invalid condition and valid [then] target branch', () => {
16
- const operator = new operators.$if(operators, {
17
- $condition: { $has: { $location: 'path', $regExp: /^\/bar/ } },
18
- $then: { $has: { $location: 'method', $value: 'POST' } },
19
- });
20
-
21
- expect(operator.match(buildExpectationContext())).toBeFalsy();
22
- });
23
-
24
- it('should match by schema with simple valid condition and invalid [then] target branch', () => {
25
- const operator = new operators.$if(operators, {
26
- $condition: { $has: { $location: 'path', $regExp: /^\/foo/ } },
27
- $then: { $has: { $location: 'method', $value: 'GET' } },
28
- });
29
-
30
- expect(operator.match(buildExpectationContext())).toBeFalsy();
31
- });
32
-
33
- it('should match by schema with simple invalid condition and valid [else] target branch', () => {
34
- const operator = new operators.$if(operators, {
35
- $condition: { $has: { $location: 'path', $regExp: /^\/bar/ } },
36
- $else: { $has: { $location: 'method', $value: 'POST' } },
37
- });
38
-
39
- expect(operator.match(buildExpectationContext())).toBeTruthy();
40
- });
41
-
42
- it('should match by schema with simple invalid condition and invalid [else] target branch', () => {
43
- const operator = new operators.$if(operators, {
44
- $condition: { $has: { $location: 'path', $regExp: /^\/bar/ } },
45
- $else: { $has: { $location: 'method', $value: 'GET' } },
46
- });
47
-
48
- expect(operator.match(buildExpectationContext())).toBeFalsy();
49
- });
50
-
51
- it('should match by schema with complex valid condition', () => {
52
- const operator = new operators.$if(operators, {
53
- $condition: {
54
- $or: [
55
- { $if: { $condition: {} } },
56
- { $has: { $location: 'path', $regExp: /^\/bar/ } },
57
- { $has: { $location: 'method', $value: 'POST'} },
58
- ],
59
- },
60
-
61
- $then: {
62
- $or: [
63
- { $has: { $location: 'incoming.data', $path: 'foo.1.test.0', $regExp: /^2/ } },
64
- { $has: { $location: 'incoming.data', $path: 'foo.1.baz.0', $regExp: /^2/ } },
65
- ],
66
- },
67
- });
68
-
69
- expect(operator.match(buildExpectationContext())).toBeTruthy();
70
- });
71
-
72
- it('should match by schema with complex invalid condition', () => {
73
- const operator = new operators.$if(operators, {
74
- $condition: {
75
- $or: [
76
- { $if: { $condition: {} } },
77
- { $has: { $location: 'path', $regExp: /^\/bar/ } },
78
- { $has: { $location: 'method', $value: 'GET'} },
79
- ],
80
- },
81
-
82
- $else: {
83
- $has: { $location: 'incoming.data', $path: 'foo.1.test.0', $regExp: /^2/ },
84
- },
85
- });
86
-
87
- expect(operator.match(buildExpectationContext())).toBeFalsy();
88
- });
89
- });
90
-
91
- describe('manipulation', () => {
92
- it('should manipulate by schema with conplex condition', () => {
93
- const operator = new operators.$if<any>(operators, {
94
- $condition: {
95
- $or: [
96
- { $if: { $condition: {} } },
97
- { $has: { $location: 'path', $regExp: /^\/bar/ } },
98
- { $has: { $location: 'method', $value: 'POST'} },
99
- ],
100
- },
101
-
102
- $then: {
103
- $and: [
104
- { $set: { $location: 'incoming.headers', $path: 'content-length', $value: 100 } },
105
- { $set: { $location: 'incoming.query', $path: 'bar.baz', $value: { test: true } } },
106
- ],
107
- },
108
- });
109
-
110
- const context = operator.manipulate<any>(buildExpectationContext());
111
-
112
- expect(context.incoming.headers?.['content-length']).toEqual(100);
113
- expect(context.incoming.query?.bar?.baz?.test).toBeTruthy();
114
- });
115
- });
116
- });
@@ -1,77 +0,0 @@
1
- import { ExpectationOperator, TExpectationOperatorConstructor } from '../models/operator';
2
- import {
3
- IExpectationSchemaContext,
4
- IExpectationOperatorsSchema,
5
- TExpectationMetaTag,
6
- TExpectationOperatorLocation,
7
- } from '../types';
8
-
9
- export default class IfExpectationOperator<
10
- TContext extends IExpectationSchemaContext,
11
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation,
12
- TValue = void
13
- > extends ExpectationOperator<
14
- TContext,
15
- {
16
- $condition: Pick<IExpectationOperatorsSchema<TContext, TLocation, TValue>, '$and' | '$exec' | '$has' | '$or' | '$not'>;
17
-
18
- $then?: IExpectationOperatorsSchema<TContext, TLocation, TValue>;
19
- $else?: IExpectationOperatorsSchema<TContext, TLocation, TValue>;
20
- }
21
- > {
22
- public compiled = {
23
- condition: (() => {
24
- const extracted = this.extractNestedSchema(this.command.$condition);
25
- if (!extracted) {
26
- return null;
27
- }
28
-
29
- const Operator = <TExpectationOperatorConstructor<TContext>>this.operators[extracted.key];
30
- return new Operator(this.operators, extracted.nested);
31
- })(),
32
-
33
- ...(this.command.$then && {
34
- then: (() => {
35
- const extracted = this.extractNestedSchema(this.command.$then);
36
- if (!extracted) {
37
- return null;
38
- }
39
-
40
- const Operator = <TExpectationOperatorConstructor<TContext>>this.operators[extracted.key];
41
- return new Operator(this.operators, extracted.nested);
42
- })(),
43
- }),
44
-
45
- ...(this.command.$else && {
46
- else: (() => {
47
- const extracted = this.extractNestedSchema(this.command.$else);
48
- if (!extracted) {
49
- return null;
50
- }
51
-
52
- const Operator = <TExpectationOperatorConstructor<TContext>>this.operators[extracted.key];
53
- return new Operator(this.operators, extracted.nested);
54
- })(),
55
- }),
56
- };
57
-
58
- public get tags(): TExpectationMetaTag[] {
59
- return [
60
- ...(this.compiled.condition?.tags ?? []),
61
- ...(this.compiled.then?.tags ?? []),
62
- ...(this.compiled.else?.tags ?? []),
63
- ];
64
- }
65
-
66
- public match(context: TContext): boolean {
67
- const result = this.compiled.condition?.match(context) ?? false;
68
- return (result ? this.compiled.then?.match(context) : this.compiled.else?.match(context)) ?? false;
69
- }
70
-
71
- public manipulate<T extends TContext>(context: T): T {
72
- const result = this.compiled.condition?.match(context) ?? false;
73
-
74
- result ? this.compiled.then?.manipulate(context) : this.compiled.else?.manipulate(context);
75
- return context;
76
- }
77
- }
@@ -1,11 +0,0 @@
1
- export { default as $and } from './and.operator';
2
- export { default as $or } from './or.operator';
3
- export { default as $not } from './not.operator';
4
- export { default as $if } from './if.operator';
5
- export { default as $has } from './has.operator';
6
- export { default as $set } from './set.operator';
7
- export { default as $merge } from './merge.operator';
8
- export { default as $remove } from './remove.operator';
9
- export { default as $exec } from './exec.operator';
10
- export { default as $switch } from './switch.operator';
11
- export { default as root } from './root.operator';
@@ -1,48 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.Merge', () => {
5
- it('should handle schema with non object payload', () => {
6
- const operator = new operators.$merge<any, any>(operators, {
7
- $location: 'path',
8
- $value: true,
9
- });
10
-
11
- const context = operator.manipulate({ incoming: { path: 'test' } });
12
- expect(context.incoming.path).toEqual('test');
13
- });
14
-
15
- it('should manipulate by schema', () => {
16
- const operator = new operators.$merge(operators, {
17
- $location: 'incoming.query',
18
- $value: { test: true },
19
- });
20
-
21
- const context = operator.manipulate<any>(buildExpectationContext());
22
- expect(context.incoming.query.test).toBeTruthy();
23
- });
24
-
25
- it('should manipulate by schema using path', () => {
26
- const operator = new operators.$merge(operators, {
27
- $location: 'incoming.query',
28
- $path: 'bar',
29
- $value: { test: true },
30
- });
31
-
32
- const context = operator.manipulate<any>(buildExpectationContext());
33
- expect(context.incoming.query.bar.test).toBeTruthy();
34
- });
35
-
36
- it('should manipulate by schema using jsonPath', () => {
37
- const operator = new operators.$merge(operators, {
38
- $location: 'incoming.data',
39
- $jsonPath: '$.foo[*]',
40
- $value: { test: true },
41
- });
42
-
43
- const context = operator.manipulate<any>(buildExpectationContext());
44
-
45
- expect(context.incoming.data.foo[0].test).toBeTruthy();
46
- expect(context.incoming.data.foo[1].test).toBeTruthy();
47
- });
48
- });
@@ -1,97 +0,0 @@
1
- import merge from 'deepmerge';
2
- import _ from 'lodash';
3
-
4
- import { extractContextByLocation, extractWithJsonPathSafe } from '../utils';
5
- import { ExpectationOperator } from '../models/operator';
6
- import { TFunction } from '../../../types';
7
- import {
8
- CompileExpectationOperatorValue,
9
- CompileExpectationOperatorValueWithPredicate,
10
- IExpectationSchemaContext,
11
- IExpectationExecUtils,
12
- TExpectationMetaTag,
13
- TExpectationOperatorObjectLocation,
14
- } from '../types';
15
-
16
- export default class MergeExpectationOperator<
17
- TContext extends IExpectationSchemaContext,
18
- TLocation extends TExpectationOperatorObjectLocation = TExpectationOperatorObjectLocation,
19
- TValue = void
20
- > extends ExpectationOperator<
21
- TContext,
22
- {
23
- [K in TLocation]: {
24
- $location: K;
25
-
26
- $value?: CompileExpectationOperatorValueWithPredicate<TContext, K, TValue>;
27
- $exec?: string | TFunction<CompileExpectationOperatorValueWithPredicate<TContext, K, TValue>, [
28
- CompileExpectationOperatorValue<TContext, K, TValue>,
29
- IExpectationExecUtils<TContext>
30
- ]>;
31
-
32
- $path?: string;
33
- $jsonPath?: string;
34
- }
35
- }[TLocation]
36
- > {
37
- public compiled = {
38
- ...(this.command.$exec && {
39
- exec: this.compileExecHandler(this.command.$exec, ['payload', 'utils']),
40
- }),
41
- };
42
-
43
- public get tags(): TExpectationMetaTag[] {
44
- return [];
45
- }
46
-
47
- public match(): boolean {
48
- return true;
49
- }
50
-
51
- public manipulate<T extends TContext>(context: T): T {
52
- const payload = extractContextByLocation(this.command.$location, context);
53
- if (payload?.type !== 'object' || !_.isObject(payload.value)) {
54
- return context;
55
- }
56
-
57
- if (this.command.$path) {
58
- const value = _.get(payload.value, this.command.$path);
59
-
60
- _.set(
61
- payload.parent,
62
- `${payload.key}.${this.command.$path}`,
63
- this.compiled.exec
64
- ? merge(value, this.compiled.exec('manipulate', context, value), { arrayMerge: (target, source) => source })
65
- : merge(value, <object>this.command.$value ?? {}, { arrayMerge: (target, source) => source })
66
- );
67
-
68
- return context;
69
- }
70
-
71
- if (this.command.$jsonPath) {
72
- extractWithJsonPathSafe({ path: this.command.$jsonPath, json: payload.value }).results?.forEach((segment) => {
73
- const value = _.get(segment.parent, segment.parentProperty);
74
-
75
- _.set(
76
- <object>payload.value,
77
- segment.pointer.substring(1).replace(/\//g, '.'),
78
- this.compiled.exec
79
- ? merge(value, this.compiled.exec('manipulate', context, value))
80
- : merge(value, this.command.$value ?? {})
81
- )
82
- });
83
-
84
- return context;
85
- }
86
-
87
- _.set(
88
- payload.parent,
89
- payload.key,
90
- this.compiled.exec
91
- ? merge(payload.value, this.compiled.exec('manipulate', context, payload.value))
92
- : merge(payload.value, this.command.$value ?? {})
93
- );
94
-
95
- return context;
96
- }
97
- }
@@ -1,12 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.Not', () => {
5
- it('should match by schema', () => {
6
- const operator = new operators.$not(operators, {
7
- $has: { $location: 'incoming.query', $path: 'foo', $value: 1 },
8
- });
9
-
10
- expect(operator.match(buildExpectationContext())).toBeFalsy();
11
- });
12
- });
@@ -1,38 +0,0 @@
1
- import { ExpectationOperator, TExpectationOperatorConstructor } from '../models/operator';
2
- import {
3
- IExpectationSchemaContext,
4
- IExpectationOperatorsSchema,
5
- TExpectationMetaTag,
6
- TExpectationOperatorLocation,
7
- } from '../types';
8
-
9
- export default class NotExpectationOperator<
10
- TContext extends IExpectationSchemaContext,
11
- TLocation extends TExpectationOperatorLocation = TExpectationOperatorLocation,
12
- TValue = void
13
- > extends ExpectationOperator<
14
- TContext,
15
- IExpectationOperatorsSchema<TContext, TLocation, TValue>
16
- > {
17
- public compiled = (() => {
18
- const extracted = this.extractNestedSchema(this.command);
19
- if (!extracted) {
20
- return null;
21
- }
22
-
23
- const Operator = <TExpectationOperatorConstructor<TContext>>this.operators[extracted.key];
24
- return new Operator(this.operators, extracted.nested);
25
- })();
26
-
27
- public get tags(): TExpectationMetaTag[] {
28
- return [];
29
- }
30
-
31
- public match(context: TContext): boolean {
32
- return this.compiled ? !this.compiled.match(context) : false;
33
- }
34
-
35
- public manipulate<T extends TContext>(context: T): T {
36
- return context;
37
- }
38
- }
@@ -1,60 +0,0 @@
1
- import { buildExpectationContext } from '../__utils__';
2
- import * as operators from './index';
3
-
4
- describe('Expectations.Operators.Or', () => {
5
- describe('matching', () => {
6
- it('should match by schema with one valid condition', () => {
7
- const operator = new operators.$or(operators, [
8
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 1 } },
9
- ]);
10
-
11
- expect(operator.match(buildExpectationContext())).toBeTruthy();
12
- });
13
-
14
- it('should match by schema with two valid conditions', () => {
15
- const operator = new operators.$or(operators, [
16
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 1 } },
17
- { $has: { $location: 'incoming.query', $path: 'bar.baz', $value: null } },
18
- ]);
19
-
20
- expect(operator.match(buildExpectationContext())).toBeTruthy();
21
- });
22
-
23
- it('should match by schema with zero conditions', () => {
24
- const operator = new operators.$or(operators, []);
25
- expect(operator.match(buildExpectationContext())).toBeFalsy();
26
- });
27
-
28
- it('should match by schema with one valid and one invalid condition', () => {
29
- const operator = new operators.$or(operators, [
30
- { $has: { $location: 'incoming.query', $path: 'foo', $value: 1 } },
31
- { $has: { $location: 'incoming.query', $path: 'bar.baz', $value: 1 } },
32
- ]);
33
-
34
- expect(operator.match(buildExpectationContext())).toBeTruthy();
35
- });
36
-
37
- it('should match by schema with two invalid conditions', () => {
38
- const operator = new operators.$or(operators, [
39
- { $has: { $location: 'incoming.query', $path: 'foo', $value: null } },
40
- { $has: { $location: 'incoming.query', $path: 'bar.baz', $value: 1 } },
41
- ]);
42
-
43
- expect(operator.match(buildExpectationContext())).toBeFalsy();
44
- });
45
- });
46
-
47
- describe('manipulation', () => {
48
- it('should manipulate by schema with two conditions', () => {
49
- const operator = new operators.$or<any>(operators, [
50
- { $set: { $location: 'incoming.headers', $path: 'content-length', $value: 100 } },
51
- { $set: { $location: 'incoming.query', $path: 'bar.baz', $value: { test: true } } },
52
- ]);
53
-
54
- const context = operator.manipulate<any>(buildExpectationContext());
55
-
56
- expect(context.incoming.headers?.['content-length']).toEqual(100);
57
- expect(context.incoming.query?.bar?.baz?.test).toBeTruthy();
58
- });
59
- });
60
- });