@n1k1t/mock-server 0.1.60 → 0.1.61

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 (575) hide show
  1. package/bin/index.ts +33 -0
  2. package/coverage/clover.xml +1372 -0
  3. package/coverage/cobertura-coverage.xml +3466 -0
  4. package/coverage/coverage-final.json +76 -0
  5. package/coverage/lcov-report/base.css +224 -0
  6. package/coverage/lcov-report/block-navigation.js +87 -0
  7. package/coverage/lcov-report/client/errors/connection.error.ts.html +106 -0
  8. package/coverage/lcov-report/client/errors/index.html +161 -0
  9. package/coverage/lcov-report/client/errors/index.ts.html +97 -0
  10. package/coverage/lcov-report/client/errors/internal-server.error.ts.html +115 -0
  11. package/coverage/lcov-report/client/errors/validation.error.ts.html +115 -0
  12. package/coverage/lcov-report/client/helpers/expectations.ts.html +766 -0
  13. package/coverage/lcov-report/client/helpers/index.html +131 -0
  14. package/coverage/lcov-report/client/helpers/index.ts.html +88 -0
  15. package/coverage/lcov-report/client/index.html +161 -0
  16. package/coverage/lcov-report/client/index.ts.html +100 -0
  17. package/coverage/lcov-report/client/methods/expectations-group.update.method.ts.html +193 -0
  18. package/coverage/lcov-report/client/methods/expectations.create.method.ts.html +202 -0
  19. package/coverage/lcov-report/client/methods/expectations.delete.method.ts.html +184 -0
  20. package/coverage/lcov-report/client/methods/expectations.update.method.ts.html +241 -0
  21. package/coverage/lcov-report/client/methods/index.html +191 -0
  22. package/coverage/lcov-report/client/methods/index.ts.html +103 -0
  23. package/coverage/lcov-report/client/methods/ping.method.ts.html +160 -0
  24. package/coverage/lcov-report/client/models/client.ts.html +340 -0
  25. package/coverage/lcov-report/client/models/index.html +146 -0
  26. package/coverage/lcov-report/client/models/index.ts.html +91 -0
  27. package/coverage/lcov-report/client/models/method.ts.html +235 -0
  28. package/coverage/lcov-report/client/onsite.ts.html +172 -0
  29. package/coverage/lcov-report/client/remote.ts.html +187 -0
  30. package/coverage/lcov-report/client/utils.ts.html +211 -0
  31. package/coverage/lcov-report/config/index.html +131 -0
  32. package/coverage/lcov-report/config/index.ts.html +97 -0
  33. package/coverage/lcov-report/config/model.ts.html +226 -0
  34. package/coverage/lcov-report/expectations/__utils__/index.html +116 -0
  35. package/coverage/lcov-report/expectations/__utils__/index.ts.html +268 -0
  36. package/coverage/lcov-report/expectations/index.html +146 -0
  37. package/coverage/lcov-report/expectations/index.ts.html +94 -0
  38. package/coverage/lcov-report/expectations/models/expectation.ts.html +373 -0
  39. package/coverage/lcov-report/expectations/models/index.html +161 -0
  40. package/coverage/lcov-report/expectations/models/index.ts.html +94 -0
  41. package/coverage/lcov-report/expectations/models/operator.ts.html +352 -0
  42. package/coverage/lcov-report/expectations/models/storage.ts.html +211 -0
  43. package/coverage/lcov-report/expectations/operators/and.operator.ts.html +196 -0
  44. package/coverage/lcov-report/expectations/operators/exec.operator.ts.html +160 -0
  45. package/coverage/lcov-report/expectations/operators/has.operator.ts.html +778 -0
  46. package/coverage/lcov-report/expectations/operators/if.operator.ts.html +316 -0
  47. package/coverage/lcov-report/expectations/operators/index.html +281 -0
  48. package/coverage/lcov-report/expectations/operators/index.ts.html +118 -0
  49. package/coverage/lcov-report/expectations/operators/merge.operator.ts.html +379 -0
  50. package/coverage/lcov-report/expectations/operators/not.operator.ts.html +199 -0
  51. package/coverage/lcov-report/expectations/operators/or.operator.ts.html +196 -0
  52. package/coverage/lcov-report/expectations/operators/remove.operator.ts.html +238 -0
  53. package/coverage/lcov-report/expectations/operators/root.operator.ts.html +238 -0
  54. package/coverage/lcov-report/expectations/operators/set.operator.ts.html +436 -0
  55. package/coverage/lcov-report/expectations/operators/switch.operator.ts.html +463 -0
  56. package/coverage/lcov-report/expectations/types.ts.html +766 -0
  57. package/coverage/lcov-report/expectations/utils.ts.html +802 -0
  58. package/coverage/lcov-report/favicon.png +0 -0
  59. package/coverage/lcov-report/index.html +431 -0
  60. package/coverage/lcov-report/logger/index.html +131 -0
  61. package/coverage/lcov-report/logger/index.ts.html +325 -0
  62. package/coverage/lcov-report/logger/utils.ts.html +160 -0
  63. package/coverage/lcov-report/meta/index.html +146 -0
  64. package/coverage/lcov-report/meta/index.ts.html +103 -0
  65. package/coverage/lcov-report/meta/model.ts.html +172 -0
  66. package/coverage/lcov-report/meta/storage.ts.html +145 -0
  67. package/coverage/lcov-report/prettify.css +1 -0
  68. package/coverage/lcov-report/prettify.js +2 -0
  69. package/coverage/lcov-report/server/expectations/__utils__/index.html +116 -0
  70. package/coverage/lcov-report/server/expectations/__utils__/index.ts.html +199 -0
  71. package/coverage/lcov-report/server/expectations/index.html +131 -0
  72. package/coverage/lcov-report/server/expectations/operators/and.operator.ts.html +103 -0
  73. package/coverage/lcov-report/server/expectations/operators/exec.operator.ts.html +139 -0
  74. package/coverage/lcov-report/server/expectations/operators/has.operator.ts.html +358 -0
  75. package/coverage/lcov-report/server/expectations/operators/if.operator.ts.html +130 -0
  76. package/coverage/lcov-report/server/expectations/operators/index.html +266 -0
  77. package/coverage/lcov-report/server/expectations/operators/index.ts.html +112 -0
  78. package/coverage/lcov-report/server/expectations/operators/merge.operator.ts.html +193 -0
  79. package/coverage/lcov-report/server/expectations/operators/not.operator.ts.html +100 -0
  80. package/coverage/lcov-report/server/expectations/operators/or.operator.ts.html +115 -0
  81. package/coverage/lcov-report/server/expectations/operators/remove.operator.ts.html +169 -0
  82. package/coverage/lcov-report/server/expectations/operators/set.operator.ts.html +208 -0
  83. package/coverage/lcov-report/server/expectations/operators/utils.ts.html +346 -0
  84. package/coverage/lcov-report/server/expectations/types.ts.html +517 -0
  85. package/coverage/lcov-report/server/expectations/utils.ts.html +358 -0
  86. package/coverage/lcov-report/server/models/containers/index.html +161 -0
  87. package/coverage/lcov-report/server/models/containers/index.ts.html +91 -0
  88. package/coverage/lcov-report/server/models/containers/model.ts.html +328 -0
  89. package/coverage/lcov-report/server/models/containers/storage.ts.html +256 -0
  90. package/coverage/lcov-report/server/models/containers/utils.ts.html +97 -0
  91. package/coverage/lcov-report/server/models/context/index.html +146 -0
  92. package/coverage/lcov-report/server/models/context/index.ts.html +514 -0
  93. package/coverage/lcov-report/server/models/context/snapshot.ts.html +529 -0
  94. package/coverage/lcov-report/server/models/context/utils.ts.html +382 -0
  95. package/coverage/lcov-report/server/models/endpoint.ts.html +304 -0
  96. package/coverage/lcov-report/server/models/exchanges/index.html +131 -0
  97. package/coverage/lcov-report/server/models/exchanges/index.ts.html +88 -0
  98. package/coverage/lcov-report/server/models/exchanges/socket-io.ts.html +154 -0
  99. package/coverage/lcov-report/server/models/executor/errors/index.html +116 -0
  100. package/coverage/lcov-report/server/models/executor/errors/index.ts.html +130 -0
  101. package/coverage/lcov-report/server/models/executor/index.html +116 -0
  102. package/coverage/lcov-report/server/models/executor/index.ts.html +1018 -0
  103. package/coverage/lcov-report/server/models/history/index.html +146 -0
  104. package/coverage/lcov-report/server/models/history/index.ts.html +91 -0
  105. package/coverage/lcov-report/server/models/history/model.ts.html +331 -0
  106. package/coverage/lcov-report/server/models/history/storage.ts.html +184 -0
  107. package/coverage/lcov-report/server/models/index.html +161 -0
  108. package/coverage/lcov-report/server/models/index.ts.html +115 -0
  109. package/coverage/lcov-report/server/models/providers/index.html +146 -0
  110. package/coverage/lcov-report/server/models/providers/index.ts.html +91 -0
  111. package/coverage/lcov-report/server/models/providers/model.ts.html +211 -0
  112. package/coverage/lcov-report/server/models/providers/storage.ts.html +172 -0
  113. package/coverage/lcov-report/server/models/reply.ts.html +115 -0
  114. package/coverage/lcov-report/server/models/router.ts.html +313 -0
  115. package/coverage/lcov-report/server/models/transports/index.html +146 -0
  116. package/coverage/lcov-report/server/models/transports/index.ts.html +91 -0
  117. package/coverage/lcov-report/server/models/transports/model.ts.html +112 -0
  118. package/coverage/lcov-report/server/models/transports/storage.ts.html +124 -0
  119. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  120. package/coverage/lcov-report/sorter.js +196 -0
  121. package/coverage/lcov-report/utils/common.ts.html +187 -0
  122. package/coverage/lcov-report/utils/index.html +176 -0
  123. package/coverage/lcov-report/utils/index.ts.html +97 -0
  124. package/coverage/lcov-report/utils/json.ts.html +193 -0
  125. package/coverage/lcov-report/utils/regexp.ts.html +97 -0
  126. package/coverage/lcov-report/utils/validation.ts.html +190 -0
  127. package/coverage/lcov.info +3012 -0
  128. package/discardedTests.txt +35606 -0
  129. package/images/preview.png +0 -0
  130. package/images/strategy.png +0 -0
  131. package/keploy.yml +64 -0
  132. package/lib/package.json +1 -1
  133. package/lib/src/client/errors/connection.error.spec.d.ts +2 -0
  134. package/lib/src/client/errors/connection.error.spec.d.ts.map +1 -0
  135. package/lib/src/client/errors/connection.error.spec.js +12 -0
  136. package/lib/src/client/errors/connection.error.spec.js.map +1 -0
  137. package/lib/src/client/errors/internal-server.error.spec.d.ts +2 -0
  138. package/lib/src/client/errors/internal-server.error.spec.d.ts.map +1 -0
  139. package/lib/src/client/errors/internal-server.error.spec.js +12 -0
  140. package/lib/src/client/errors/internal-server.error.spec.js.map +1 -0
  141. package/lib/src/client/errors/validation.error.spec.d.ts +2 -0
  142. package/lib/src/client/errors/validation.error.spec.d.ts.map +1 -0
  143. package/lib/src/client/errors/validation.error.spec.js +10 -0
  144. package/lib/src/client/errors/validation.error.spec.js.map +1 -0
  145. package/lib/src/client/models/client.spec.d.ts +2 -0
  146. package/lib/src/client/models/client.spec.d.ts.map +1 -0
  147. package/lib/src/client/models/client.spec.js +244 -0
  148. package/lib/src/client/models/client.spec.js.map +1 -0
  149. package/lib/src/client/onsite.spec.d.ts +2 -0
  150. package/lib/src/client/onsite.spec.d.ts.map +1 -0
  151. package/lib/src/client/onsite.spec.js +23 -0
  152. package/lib/src/client/onsite.spec.js.map +1 -0
  153. package/lib/src/client/remote.spec.d.ts +2 -0
  154. package/lib/src/client/remote.spec.d.ts.map +1 -0
  155. package/lib/src/client/remote.spec.js +16 -0
  156. package/lib/src/client/remote.spec.js.map +1 -0
  157. package/lib/src/client/utils.spec.d.ts +2 -0
  158. package/lib/src/client/utils.spec.d.ts.map +1 -0
  159. package/lib/src/client/utils.spec.js +57 -0
  160. package/lib/src/client/utils.spec.js.map +1 -0
  161. package/lib/src/expectations/models/storage.spec.d.ts +2 -0
  162. package/lib/src/expectations/models/storage.spec.d.ts.map +1 -0
  163. package/lib/src/expectations/models/storage.spec.js +57 -0
  164. package/lib/src/expectations/models/storage.spec.js.map +1 -0
  165. package/lib/src/expectations/operators/and.operator.spec.d.ts +2 -0
  166. package/lib/src/expectations/operators/and.operator.spec.d.ts.map +1 -0
  167. package/lib/src/expectations/operators/and.operator.spec.js +83 -0
  168. package/lib/src/expectations/operators/and.operator.spec.js.map +1 -0
  169. package/lib/src/expectations/operators/exec.operator.spec.d.ts +2 -0
  170. package/lib/src/expectations/operators/exec.operator.spec.d.ts.map +1 -0
  171. package/lib/src/expectations/operators/exec.operator.spec.js +68 -0
  172. package/lib/src/expectations/operators/exec.operator.spec.js.map +1 -0
  173. package/lib/src/expectations/operators/has.operator.spec.d.ts +2 -0
  174. package/lib/src/expectations/operators/has.operator.spec.d.ts.map +1 -0
  175. package/lib/src/expectations/operators/has.operator.spec.js +444 -0
  176. package/lib/src/expectations/operators/has.operator.spec.js.map +1 -0
  177. package/lib/src/expectations/operators/if.operator.spec.d.ts +2 -0
  178. package/lib/src/expectations/operators/if.operator.spec.d.ts.map +1 -0
  179. package/lib/src/expectations/operators/if.operator.spec.js +132 -0
  180. package/lib/src/expectations/operators/if.operator.spec.js.map +1 -0
  181. package/lib/src/expectations/operators/merge.operator.spec.d.ts +2 -0
  182. package/lib/src/expectations/operators/merge.operator.spec.d.ts.map +1 -0
  183. package/lib/src/expectations/operators/merge.operator.spec.js +75 -0
  184. package/lib/src/expectations/operators/merge.operator.spec.js.map +1 -0
  185. package/lib/src/expectations/operators/not.operator.spec.d.ts +2 -0
  186. package/lib/src/expectations/operators/not.operator.spec.d.ts.map +1 -0
  187. package/lib/src/expectations/operators/not.operator.spec.js +46 -0
  188. package/lib/src/expectations/operators/not.operator.spec.js.map +1 -0
  189. package/lib/src/expectations/operators/or.operator.spec.d.ts +2 -0
  190. package/lib/src/expectations/operators/or.operator.spec.d.ts.map +1 -0
  191. package/lib/src/expectations/operators/or.operator.spec.js +84 -0
  192. package/lib/src/expectations/operators/or.operator.spec.js.map +1 -0
  193. package/lib/src/expectations/operators/remove.operator.spec.d.ts +2 -0
  194. package/lib/src/expectations/operators/remove.operator.spec.d.ts.map +1 -0
  195. package/lib/src/expectations/operators/remove.operator.spec.js +67 -0
  196. package/lib/src/expectations/operators/remove.operator.spec.js.map +1 -0
  197. package/lib/src/expectations/operators/root.operator.spec.d.ts +2 -0
  198. package/lib/src/expectations/operators/root.operator.spec.d.ts.map +1 -0
  199. package/lib/src/expectations/operators/root.operator.spec.js +29 -0
  200. package/lib/src/expectations/operators/root.operator.spec.js.map +1 -0
  201. package/lib/src/expectations/operators/set.operator.spec.d.ts +2 -0
  202. package/lib/src/expectations/operators/set.operator.spec.d.ts.map +1 -0
  203. package/lib/src/expectations/operators/set.operator.spec.js +111 -0
  204. package/lib/src/expectations/operators/set.operator.spec.js.map +1 -0
  205. package/lib/src/expectations/operators/switch.operator.spec.d.ts +2 -0
  206. package/lib/src/expectations/operators/switch.operator.spec.d.ts.map +1 -0
  207. package/lib/src/expectations/operators/switch.operator.spec.js +139 -0
  208. package/lib/src/expectations/operators/switch.operator.spec.js.map +1 -0
  209. package/lib/src/expectations/utils/location.spec.d.ts +2 -0
  210. package/lib/src/expectations/utils/location.spec.d.ts.map +1 -0
  211. package/lib/src/expectations/utils/location.spec.js +62 -0
  212. package/lib/src/expectations/utils/location.spec.js.map +1 -0
  213. package/lib/src/expectations/utils/schema.spec.d.ts +2 -0
  214. package/lib/src/expectations/utils/schema.spec.d.ts.map +1 -0
  215. package/lib/src/expectations/utils/schema.spec.js +19 -0
  216. package/lib/src/expectations/utils/schema.spec.js.map +1 -0
  217. package/lib/src/gui/app/types/dev.d.ts +7 -0
  218. package/lib/src/gui/app/types/dev.d.ts.map +1 -0
  219. package/lib/src/gui/app/types/dev.js +3 -0
  220. package/lib/src/gui/app/types/dev.js.map +1 -0
  221. package/lib/src/gui/app/types/index.d.ts +2 -0
  222. package/lib/src/gui/app/types/index.d.ts.map +1 -0
  223. package/lib/src/gui/app/types/index.js +18 -0
  224. package/lib/src/gui/app/types/index.js.map +1 -0
  225. package/lib/src/index.d.ts +1 -1
  226. package/lib/src/index.d.ts.map +1 -1
  227. package/lib/src/index.js +1 -1
  228. package/lib/src/index.js.map +1 -1
  229. package/lib/src/meta/model.spec.d.ts +2 -0
  230. package/lib/src/meta/model.spec.d.ts.map +1 -0
  231. package/lib/src/meta/model.spec.js +28 -0
  232. package/lib/src/meta/model.spec.js.map +1 -0
  233. package/lib/src/meta/storage.spec.d.ts +2 -0
  234. package/lib/src/meta/storage.spec.d.ts.map +1 -0
  235. package/lib/src/meta/storage.spec.js +19 -0
  236. package/lib/src/meta/storage.spec.js.map +1 -0
  237. package/lib/src/server/models/containers/model.spec.d.ts +2 -0
  238. package/lib/src/server/models/containers/model.spec.d.ts.map +1 -0
  239. package/lib/src/server/models/containers/model.spec.js +79 -0
  240. package/lib/src/server/models/containers/model.spec.js.map +1 -0
  241. package/lib/src/server/models/containers/storage.spec.d.ts +2 -0
  242. package/lib/src/server/models/containers/storage.spec.d.ts.map +1 -0
  243. package/lib/src/server/models/containers/storage.spec.js +39 -0
  244. package/lib/src/server/models/containers/storage.spec.js.map +1 -0
  245. package/lib/src/server/models/context/index.spec.d.ts +2 -0
  246. package/lib/src/server/models/context/index.spec.d.ts.map +1 -0
  247. package/lib/src/server/models/context/index.spec.js +143 -0
  248. package/lib/src/server/models/context/index.spec.js.map +1 -0
  249. package/lib/src/server/models/context/snapshot.spec.d.ts +2 -0
  250. package/lib/src/server/models/context/snapshot.spec.d.ts.map +1 -0
  251. package/lib/src/server/models/context/snapshot.spec.js +75 -0
  252. package/lib/src/server/models/context/snapshot.spec.js.map +1 -0
  253. package/lib/src/server/models/context/utils.spec.d.ts +2 -0
  254. package/lib/src/server/models/context/utils.spec.d.ts.map +1 -0
  255. package/lib/src/server/models/context/utils.spec.js +69 -0
  256. package/lib/src/server/models/context/utils.spec.js.map +1 -0
  257. package/lib/src/server/models/endpoint.spec.d.ts +2 -0
  258. package/lib/src/server/models/endpoint.spec.d.ts.map +1 -0
  259. package/lib/src/server/models/endpoint.spec.js +28 -0
  260. package/lib/src/server/models/endpoint.spec.js.map +1 -0
  261. package/lib/src/server/models/exchanges/socket-io.spec.d.ts +2 -0
  262. package/lib/src/server/models/exchanges/socket-io.spec.d.ts.map +1 -0
  263. package/lib/src/server/models/exchanges/socket-io.spec.js +12 -0
  264. package/lib/src/server/models/exchanges/socket-io.spec.js.map +1 -0
  265. package/lib/src/server/models/executor/errors/index.spec.d.ts +2 -0
  266. package/lib/src/server/models/executor/errors/index.spec.d.ts.map +1 -0
  267. package/lib/src/server/models/executor/errors/index.spec.js +23 -0
  268. package/lib/src/server/models/executor/errors/index.spec.js.map +1 -0
  269. package/lib/src/server/models/executor/index.spec.d.ts +2 -0
  270. package/lib/src/server/models/executor/index.spec.d.ts.map +1 -0
  271. package/lib/src/server/models/executor/index.spec.js +137 -0
  272. package/lib/src/server/models/executor/index.spec.js.map +1 -0
  273. package/lib/src/server/models/history/model.spec.d.ts +2 -0
  274. package/lib/src/server/models/history/model.spec.d.ts.map +1 -0
  275. package/lib/src/server/models/history/model.spec.js +30 -0
  276. package/lib/src/server/models/history/model.spec.js.map +1 -0
  277. package/lib/src/server/models/history/storage.spec.d.ts +2 -0
  278. package/lib/src/server/models/history/storage.spec.d.ts.map +1 -0
  279. package/lib/src/server/models/history/storage.spec.js +42 -0
  280. package/lib/src/server/models/history/storage.spec.js.map +1 -0
  281. package/lib/src/server/models/providers/model.spec.d.ts +2 -0
  282. package/lib/src/server/models/providers/model.spec.d.ts.map +1 -0
  283. package/lib/src/server/models/providers/model.spec.js +13 -0
  284. package/lib/src/server/models/providers/model.spec.js.map +1 -0
  285. package/lib/src/server/models/providers/storage.spec.d.ts +2 -0
  286. package/lib/src/server/models/providers/storage.spec.d.ts.map +1 -0
  287. package/lib/src/server/models/providers/storage.spec.js +19 -0
  288. package/lib/src/server/models/providers/storage.spec.js.map +1 -0
  289. package/lib/src/server/models/reply.spec.d.ts +2 -0
  290. package/lib/src/server/models/reply.spec.d.ts.map +1 -0
  291. package/lib/src/server/models/reply.spec.js +20 -0
  292. package/lib/src/server/models/reply.spec.js.map +1 -0
  293. package/lib/src/server/models/router.spec.d.ts +2 -0
  294. package/lib/src/server/models/router.spec.d.ts.map +1 -0
  295. package/lib/src/server/models/router.spec.js +46 -0
  296. package/lib/src/server/models/router.spec.js.map +1 -0
  297. package/lib/src/server/models/transports/storage.spec.d.ts +2 -0
  298. package/lib/src/server/models/transports/storage.spec.d.ts.map +1 -0
  299. package/lib/src/server/models/transports/storage.spec.js +13 -0
  300. package/lib/src/server/models/transports/storage.spec.js.map +1 -0
  301. package/lib/src/server/services/analytics.service.spec.d.ts +2 -0
  302. package/lib/src/server/services/analytics.service.spec.d.ts.map +1 -0
  303. package/lib/src/server/services/analytics.service.spec.js +35 -0
  304. package/lib/src/server/services/analytics.service.spec.js.map +1 -0
  305. package/lib/src/server/services/metrics.service.spec.d.ts +2 -0
  306. package/lib/src/server/services/metrics.service.spec.d.ts.map +1 -0
  307. package/lib/src/server/services/metrics.service.spec.js +35 -0
  308. package/lib/src/server/services/metrics.service.spec.js.map +1 -0
  309. package/lib/src/server/types/index.d.ts +27 -0
  310. package/lib/src/server/types/index.d.ts.map +1 -0
  311. package/lib/src/server/types/index.js +3 -0
  312. package/lib/src/server/types/index.js.map +1 -0
  313. package/lib/src/utils/index.spec.d.ts +2 -0
  314. package/lib/src/utils/index.spec.d.ts.map +1 -0
  315. package/lib/src/utils/index.spec.js +30 -0
  316. package/lib/src/utils/index.spec.js.map +1 -0
  317. package/lib/tsconfig.tsbuildinfo +1 -0
  318. package/lib/vite.config.d.ts +3 -0
  319. package/lib/vite.config.d.ts.map +1 -0
  320. package/lib/vite.config.js +57 -0
  321. package/lib/vite.config.js.map +1 -0
  322. package/package.json +1 -1
  323. package/src/client/errors/connection.error.spec.ts +10 -0
  324. package/src/client/errors/connection.error.ts +7 -0
  325. package/src/client/errors/index.ts +4 -0
  326. package/src/client/errors/internal-server.error.spec.ts +12 -0
  327. package/src/client/errors/internal-server.error.ts +10 -0
  328. package/src/client/errors/types.ts +3 -0
  329. package/src/client/errors/validation.error.spec.ts +9 -0
  330. package/src/client/errors/validation.error.ts +10 -0
  331. package/src/client/helpers/expectations.ts +227 -0
  332. package/src/client/helpers/index.ts +1 -0
  333. package/src/client/index.ts +5 -0
  334. package/src/client/methods/expectations-group.update.method.ts +36 -0
  335. package/src/client/methods/expectations.create.method.ts +39 -0
  336. package/src/client/methods/expectations.delete.method.ts +33 -0
  337. package/src/client/methods/expectations.update.method.ts +58 -0
  338. package/src/client/methods/index.ts +6 -0
  339. package/src/client/methods/ping.method.ts +25 -0
  340. package/src/client/models/__snapshots__/client.spec.ts.snap +1294 -0
  341. package/src/client/models/client.spec.ts +316 -0
  342. package/src/client/models/client.ts +85 -0
  343. package/src/client/models/index.ts +2 -0
  344. package/src/client/models/method.ts +50 -0
  345. package/src/client/onsite.spec.ts +23 -0
  346. package/src/client/onsite.ts +29 -0
  347. package/src/client/remote.spec.ts +15 -0
  348. package/src/client/remote.ts +34 -0
  349. package/src/client/types.ts +31 -0
  350. package/src/client/utils.spec.ts +60 -0
  351. package/src/client/utils.ts +41 -0
  352. package/src/config/index.ts +34 -0
  353. package/src/config/model.ts +24 -0
  354. package/src/expectations/__utils__/index.ts +61 -0
  355. package/src/expectations/errors/index.ts +7 -0
  356. package/src/expectations/index.ts +3 -0
  357. package/src/expectations/models/expectation.ts +96 -0
  358. package/src/expectations/models/index.ts +3 -0
  359. package/src/expectations/models/operator.ts +89 -0
  360. package/src/expectations/models/storage.spec.ts +70 -0
  361. package/src/expectations/models/storage.ts +42 -0
  362. package/src/expectations/operators/and.operator.spec.ts +59 -0
  363. package/src/expectations/operators/and.operator.ts +37 -0
  364. package/src/expectations/operators/exec.operator.spec.ts +47 -0
  365. package/src/expectations/operators/exec.operator.ts +25 -0
  366. package/src/expectations/operators/has.operator.spec.ts +514 -0
  367. package/src/expectations/operators/has.operator.ts +230 -0
  368. package/src/expectations/operators/if.operator.spec.ts +116 -0
  369. package/src/expectations/operators/if.operator.ts +77 -0
  370. package/src/expectations/operators/index.ts +11 -0
  371. package/src/expectations/operators/merge.operator.spec.ts +48 -0
  372. package/src/expectations/operators/merge.operator.ts +97 -0
  373. package/src/expectations/operators/not.operator.spec.ts +12 -0
  374. package/src/expectations/operators/not.operator.ts +38 -0
  375. package/src/expectations/operators/or.operator.spec.ts +60 -0
  376. package/src/expectations/operators/or.operator.ts +37 -0
  377. package/src/expectations/operators/remove.operator.spec.ts +40 -0
  378. package/src/expectations/operators/remove.operator.ts +50 -0
  379. package/src/expectations/operators/root.operator.spec.ts +26 -0
  380. package/src/expectations/operators/root.operator.ts +51 -0
  381. package/src/expectations/operators/set.operator.spec.ts +96 -0
  382. package/src/expectations/operators/set.operator.ts +116 -0
  383. package/src/expectations/operators/switch.operator.spec.ts +157 -0
  384. package/src/expectations/operators/switch.operator.ts +126 -0
  385. package/src/expectations/types.ts +225 -0
  386. package/src/expectations/utils/index.ts +3 -0
  387. package/src/expectations/utils/json.ts +22 -0
  388. package/src/expectations/utils/location.spec.ts +64 -0
  389. package/src/expectations/utils/location.ts +180 -0
  390. package/src/expectations/utils/schema.spec.ts +17 -0
  391. package/src/expectations/utils/schema.ts +60 -0
  392. package/src/gui/app/components/chart.component/index.ts +173 -0
  393. package/src/gui/app/components/chart.component/style.scss +4 -0
  394. package/src/gui/app/components/checkbox-area.component/index.ts +101 -0
  395. package/src/gui/app/components/checkbox-area.component/item.component.ts +72 -0
  396. package/src/gui/app/components/checkbox-area.component/style.scss +19 -0
  397. package/src/gui/app/components/checkbox-area.component/template.hbs +3 -0
  398. package/src/gui/app/components/curtain.component/index.ts +19 -0
  399. package/src/gui/app/components/curtain.component/style.scss +14 -0
  400. package/src/gui/app/components/empty.component/index.ts +10 -0
  401. package/src/gui/app/components/empty.component/style.scss +34 -0
  402. package/src/gui/app/components/empty.component/template.hbs +6 -0
  403. package/src/gui/app/components/expectation.component/index.ts +60 -0
  404. package/src/gui/app/components/expectation.component/style.scss +5 -0
  405. package/src/gui/app/components/expectation.component/template.hbs +5 -0
  406. package/src/gui/app/components/header.component/index.ts +81 -0
  407. package/src/gui/app/components/header.component/style.scss +46 -0
  408. package/src/gui/app/components/header.component/template.hbs +15 -0
  409. package/src/gui/app/components/history.component/index.ts +86 -0
  410. package/src/gui/app/components/history.component/style.scss +5 -0
  411. package/src/gui/app/components/history.component/template.hbs +62 -0
  412. package/src/gui/app/components/index.ts +11 -0
  413. package/src/gui/app/components/loader.component/index.ts +12 -0
  414. package/src/gui/app/components/loader.component/style.scss +39 -0
  415. package/src/gui/app/components/panel.component/index.ts +52 -0
  416. package/src/gui/app/components/panel.component/style.scss +60 -0
  417. package/src/gui/app/components/panel.component/template.hbs +13 -0
  418. package/src/gui/app/components/popups.component/index.ts +26 -0
  419. package/src/gui/app/components/popups.component/style.scss +51 -0
  420. package/src/gui/app/components/popups.component/template.hbs +9 -0
  421. package/src/gui/app/components/search.component/index.ts +67 -0
  422. package/src/gui/app/components/search.component/style.scss +43 -0
  423. package/src/gui/app/components/search.component/template.hbs +7 -0
  424. package/src/gui/app/components/viewer.component/index.ts +28 -0
  425. package/src/gui/app/components/viewer.component/style.scss +38 -0
  426. package/src/gui/app/components/viewer.component/template.hbs +3 -0
  427. package/src/gui/app/context.ts +76 -0
  428. package/src/gui/app/handlebars/helpers.ts +32 -0
  429. package/src/gui/app/handlebars/index.ts +11 -0
  430. package/src/gui/app/handlebars/partials/expectation-meta.hbs +53 -0
  431. package/src/gui/app/handlebars/partials/index.ts +2 -0
  432. package/src/gui/app/handlebars/partials/truncated.hbs +10 -0
  433. package/src/gui/app/handlebars/utils.ts +9 -0
  434. package/src/gui/app/main.ts +38 -0
  435. package/src/gui/app/models/button.ts +41 -0
  436. package/src/gui/app/models/client-storage.ts +21 -0
  437. package/src/gui/app/models/component.ts +79 -0
  438. package/src/gui/app/models/context.ts +14 -0
  439. package/src/gui/app/models/dynamic-storage.ts +36 -0
  440. package/src/gui/app/models/form.ts +75 -0
  441. package/src/gui/app/models/index.ts +7 -0
  442. package/src/gui/app/models/section.ts +82 -0
  443. package/src/gui/app/sections/analytics.section/index.ts +97 -0
  444. package/src/gui/app/sections/analytics.section/style.scss +1 -0
  445. package/src/gui/app/sections/analytics.section/template.hbs +6 -0
  446. package/src/gui/app/sections/expectations.section/index.ts +179 -0
  447. package/src/gui/app/sections/expectations.section/style.scss +1 -0
  448. package/src/gui/app/sections/expectations.section/template.hbs +15 -0
  449. package/src/gui/app/sections/history.section/index.ts +175 -0
  450. package/src/gui/app/sections/history.section/style.scss +10 -0
  451. package/src/gui/app/sections/history.section/templates/actions.hbs +5 -0
  452. package/src/gui/app/sections/history.section/templates/section.hbs +15 -0
  453. package/src/gui/app/sections/index.ts +4 -0
  454. package/src/gui/app/sections/settings.section/index.ts +63 -0
  455. package/src/gui/app/sections/settings.section/style.scss +24 -0
  456. package/src/gui/app/sections/settings.section/templates/cache.hbs +6 -0
  457. package/src/gui/app/sections/settings.section/templates/section.hbs +6 -0
  458. package/src/gui/app/sections/settings.section/templates/stats.hbs +6 -0
  459. package/src/gui/app/setup.ts +7 -0
  460. package/src/gui/app/tsconfig.json +20 -0
  461. package/src/gui/app/types/dev.ts +6 -0
  462. package/src/gui/app/types/index.ts +1 -0
  463. package/src/gui/app/types/window.global.ts +9 -0
  464. package/src/gui/app/utils.ts +15 -0
  465. package/src/gui/assets/fa-all.css +5 -0
  466. package/src/gui/assets/fa-regular-400.woff2 +0 -0
  467. package/src/gui/assets/fa-solid-900.woff2 +0 -0
  468. package/src/gui/assets/favicon.png +0 -0
  469. package/src/gui/index.html +18 -0
  470. package/src/gui/styles/_constants.scss +11 -0
  471. package/src/gui/styles/_elements.scss +216 -0
  472. package/src/gui/styles/_soon.scss +35 -0
  473. package/src/gui/styles/main.scss +245 -0
  474. package/src/index.ts +9 -0
  475. package/src/logger/index.ts +80 -0
  476. package/src/logger/types.ts +4 -0
  477. package/src/logger/utils.ts +25 -0
  478. package/src/meta/index.ts +6 -0
  479. package/src/meta/model.spec.ts +28 -0
  480. package/src/meta/model.ts +29 -0
  481. package/src/meta/storage.spec.ts +18 -0
  482. package/src/meta/storage.ts +20 -0
  483. package/src/server/endpoints/cache.delete.endpoint.ts +54 -0
  484. package/src/server/endpoints/cache.usage.get.endpoint.ts +12 -0
  485. package/src/server/endpoints/config.get.endpoint.ts +10 -0
  486. package/src/server/endpoints/expectations-group.update.endpoint.ts +32 -0
  487. package/src/server/endpoints/expectations.create.endpoint.ts +23 -0
  488. package/src/server/endpoints/expectations.delete.endpoint.ts +12 -0
  489. package/src/server/endpoints/expectations.get-list.endpoint.ts +15 -0
  490. package/src/server/endpoints/expectations.update.endpoint.ts +29 -0
  491. package/src/server/endpoints/gui.endpoint.ts +76 -0
  492. package/src/server/endpoints/history.delete.endpoint.ts +10 -0
  493. package/src/server/endpoints/history.get-list.endpoint.ts +15 -0
  494. package/src/server/endpoints/index.ts +18 -0
  495. package/src/server/endpoints/metrics.endpoint.ts +12 -0
  496. package/src/server/endpoints/ping.endpoint.ts +7 -0
  497. package/src/server/endpoints/stats.endpoint.ts +20 -0
  498. package/src/server/index.ts +182 -0
  499. package/src/server/models/containers/index.ts +2 -0
  500. package/src/server/models/containers/model.spec.ts +81 -0
  501. package/src/server/models/containers/model.ts +79 -0
  502. package/src/server/models/containers/storage.spec.ts +41 -0
  503. package/src/server/models/containers/storage.ts +59 -0
  504. package/src/server/models/containers/utils.ts +4 -0
  505. package/src/server/models/context/index.spec.ts +171 -0
  506. package/src/server/models/context/index.ts +136 -0
  507. package/src/server/models/context/snapshot.spec.ts +84 -0
  508. package/src/server/models/context/snapshot.ts +148 -0
  509. package/src/server/models/context/types.ts +65 -0
  510. package/src/server/models/context/utils.spec.ts +77 -0
  511. package/src/server/models/context/utils.ts +99 -0
  512. package/src/server/models/endpoint.spec.ts +28 -0
  513. package/src/server/models/endpoint.ts +69 -0
  514. package/src/server/models/exchanges/index.ts +1 -0
  515. package/src/server/models/exchanges/socket-io.spec.ts +13 -0
  516. package/src/server/models/exchanges/socket-io.ts +14 -0
  517. package/src/server/models/executor/errors/index.spec.ts +23 -0
  518. package/src/server/models/executor/errors/index.ts +15 -0
  519. package/src/server/models/executor/index.spec.ts +148 -0
  520. package/src/server/models/executor/index.ts +297 -0
  521. package/src/server/models/history/index.ts +2 -0
  522. package/src/server/models/history/model.spec.ts +35 -0
  523. package/src/server/models/history/model.ts +82 -0
  524. package/src/server/models/history/storage.spec.ts +41 -0
  525. package/src/server/models/history/storage.ts +38 -0
  526. package/src/server/models/index.ts +11 -0
  527. package/src/server/models/providers/index.ts +2 -0
  528. package/src/server/models/providers/model.spec.ts +11 -0
  529. package/src/server/models/providers/model.ts +33 -0
  530. package/src/server/models/providers/storage.spec.ts +21 -0
  531. package/src/server/models/providers/storage.ts +34 -0
  532. package/src/server/models/reply.spec.ts +17 -0
  533. package/src/server/models/reply.ts +10 -0
  534. package/src/server/models/router.spec.ts +50 -0
  535. package/src/server/models/router.ts +79 -0
  536. package/src/server/models/service.ts +5 -0
  537. package/src/server/models/transports/index.ts +2 -0
  538. package/src/server/models/transports/model.ts +9 -0
  539. package/src/server/models/transports/storage.spec.ts +14 -0
  540. package/src/server/models/transports/storage.ts +13 -0
  541. package/src/server/services/analytics.service.spec.ts +38 -0
  542. package/src/server/services/analytics.service.ts +58 -0
  543. package/src/server/services/index.ts +2 -0
  544. package/src/server/services/metrics.service.spec.ts +42 -0
  545. package/src/server/services/metrics.service.ts +46 -0
  546. package/src/server/transports/http.transport/context.ts +72 -0
  547. package/src/server/transports/http.transport/executor.ts +156 -0
  548. package/src/server/transports/http.transport/index.ts +53 -0
  549. package/src/server/transports/index.ts +3 -0
  550. package/src/server/transports/internal/http.transport/context.ts +50 -0
  551. package/src/server/transports/internal/http.transport/executor.ts +56 -0
  552. package/src/server/transports/internal/http.transport/index.ts +23 -0
  553. package/src/server/transports/internal/http.transport/reply.ts +82 -0
  554. package/src/server/transports/internal/index.ts +2 -0
  555. package/src/server/transports/internal/io.transport/context.ts +40 -0
  556. package/src/server/transports/internal/io.transport/executor.ts +27 -0
  557. package/src/server/transports/internal/io.transport/index.ts +36 -0
  558. package/src/server/transports/internal/io.transport/reply.ts +26 -0
  559. package/src/server/transports/internal/utils.ts +6 -0
  560. package/src/server/transports/ws.transport/context.ts +90 -0
  561. package/src/server/transports/ws.transport/executor.ts +64 -0
  562. package/src/server/transports/ws.transport/index.ts +105 -0
  563. package/src/server/types/index.ts +32 -0
  564. package/src/server/utils/index.ts +35 -0
  565. package/src/utils/index.spec.ts +31 -0
  566. package/src/utils/index.ts +51 -0
  567. package/test/index.ts +299 -0
  568. package/test/providers/index.ts +2 -0
  569. package/test/providers/root.ts +241 -0
  570. package/test/providers/statics.ts +37 -0
  571. package/tsconfig.json +108 -0
  572. package/tsconfig.tsbuildinfo +1 -0
  573. package/types/common.ts +127 -0
  574. package/types/index.ts +1 -0
  575. package/vite.config.ts +64 -0
@@ -0,0 +1,1018 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <title>Code coverage report for server/models/executor/index.ts</title>
7
+ <meta charset="utf-8" />
8
+ <link rel="stylesheet" href="../../../prettify.css" />
9
+ <link rel="stylesheet" href="../../../base.css" />
10
+ <link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
11
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
12
+ <style type='text/css'>
13
+ .coverage-summary .sorter {
14
+ background-image: url(../../../sort-arrow-sprite.png);
15
+ }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <div class='wrapper'>
21
+ <div class='pad1'>
22
+ <h1><a href="../../../index.html">All files</a> / <a href="index.html">server/models/executor</a> index.ts</h1>
23
+ <div class='clearfix'>
24
+
25
+ <div class='fl pad1y space-right2'>
26
+ <span class="strong">11% </span>
27
+ <span class="quiet">Statements</span>
28
+ <span class='fraction'>12/109</span>
29
+ </div>
30
+
31
+
32
+ <div class='fl pad1y space-right2'>
33
+ <span class="strong">0% </span>
34
+ <span class="quiet">Branches</span>
35
+ <span class='fraction'>0/81</span>
36
+ </div>
37
+
38
+
39
+ <div class='fl pad1y space-right2'>
40
+ <span class="strong">0% </span>
41
+ <span class="quiet">Functions</span>
42
+ <span class='fraction'>0/20</span>
43
+ </div>
44
+
45
+
46
+ <div class='fl pad1y space-right2'>
47
+ <span class="strong">11.32% </span>
48
+ <span class="quiet">Lines</span>
49
+ <span class='fraction'>12/106</span>
50
+ </div>
51
+
52
+
53
+ </div>
54
+ <p class="quiet">
55
+ Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
+ </p>
57
+ <template id="filterTemplate">
58
+ <div class="quiet">
59
+ Filter:
60
+ <input oninput="onInput()" type="search" id="fileSearch">
61
+ </div>
62
+ </template>
63
+ </div>
64
+ <div class='status-line low'></div>
65
+ <pre><table class="coverage">
66
+ <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
+ <a name='L2'></a><a href='#L2'>2</a>
68
+ <a name='L3'></a><a href='#L3'>3</a>
69
+ <a name='L4'></a><a href='#L4'>4</a>
70
+ <a name='L5'></a><a href='#L5'>5</a>
71
+ <a name='L6'></a><a href='#L6'>6</a>
72
+ <a name='L7'></a><a href='#L7'>7</a>
73
+ <a name='L8'></a><a href='#L8'>8</a>
74
+ <a name='L9'></a><a href='#L9'>9</a>
75
+ <a name='L10'></a><a href='#L10'>10</a>
76
+ <a name='L11'></a><a href='#L11'>11</a>
77
+ <a name='L12'></a><a href='#L12'>12</a>
78
+ <a name='L13'></a><a href='#L13'>13</a>
79
+ <a name='L14'></a><a href='#L14'>14</a>
80
+ <a name='L15'></a><a href='#L15'>15</a>
81
+ <a name='L16'></a><a href='#L16'>16</a>
82
+ <a name='L17'></a><a href='#L17'>17</a>
83
+ <a name='L18'></a><a href='#L18'>18</a>
84
+ <a name='L19'></a><a href='#L19'>19</a>
85
+ <a name='L20'></a><a href='#L20'>20</a>
86
+ <a name='L21'></a><a href='#L21'>21</a>
87
+ <a name='L22'></a><a href='#L22'>22</a>
88
+ <a name='L23'></a><a href='#L23'>23</a>
89
+ <a name='L24'></a><a href='#L24'>24</a>
90
+ <a name='L25'></a><a href='#L25'>25</a>
91
+ <a name='L26'></a><a href='#L26'>26</a>
92
+ <a name='L27'></a><a href='#L27'>27</a>
93
+ <a name='L28'></a><a href='#L28'>28</a>
94
+ <a name='L29'></a><a href='#L29'>29</a>
95
+ <a name='L30'></a><a href='#L30'>30</a>
96
+ <a name='L31'></a><a href='#L31'>31</a>
97
+ <a name='L32'></a><a href='#L32'>32</a>
98
+ <a name='L33'></a><a href='#L33'>33</a>
99
+ <a name='L34'></a><a href='#L34'>34</a>
100
+ <a name='L35'></a><a href='#L35'>35</a>
101
+ <a name='L36'></a><a href='#L36'>36</a>
102
+ <a name='L37'></a><a href='#L37'>37</a>
103
+ <a name='L38'></a><a href='#L38'>38</a>
104
+ <a name='L39'></a><a href='#L39'>39</a>
105
+ <a name='L40'></a><a href='#L40'>40</a>
106
+ <a name='L41'></a><a href='#L41'>41</a>
107
+ <a name='L42'></a><a href='#L42'>42</a>
108
+ <a name='L43'></a><a href='#L43'>43</a>
109
+ <a name='L44'></a><a href='#L44'>44</a>
110
+ <a name='L45'></a><a href='#L45'>45</a>
111
+ <a name='L46'></a><a href='#L46'>46</a>
112
+ <a name='L47'></a><a href='#L47'>47</a>
113
+ <a name='L48'></a><a href='#L48'>48</a>
114
+ <a name='L49'></a><a href='#L49'>49</a>
115
+ <a name='L50'></a><a href='#L50'>50</a>
116
+ <a name='L51'></a><a href='#L51'>51</a>
117
+ <a name='L52'></a><a href='#L52'>52</a>
118
+ <a name='L53'></a><a href='#L53'>53</a>
119
+ <a name='L54'></a><a href='#L54'>54</a>
120
+ <a name='L55'></a><a href='#L55'>55</a>
121
+ <a name='L56'></a><a href='#L56'>56</a>
122
+ <a name='L57'></a><a href='#L57'>57</a>
123
+ <a name='L58'></a><a href='#L58'>58</a>
124
+ <a name='L59'></a><a href='#L59'>59</a>
125
+ <a name='L60'></a><a href='#L60'>60</a>
126
+ <a name='L61'></a><a href='#L61'>61</a>
127
+ <a name='L62'></a><a href='#L62'>62</a>
128
+ <a name='L63'></a><a href='#L63'>63</a>
129
+ <a name='L64'></a><a href='#L64'>64</a>
130
+ <a name='L65'></a><a href='#L65'>65</a>
131
+ <a name='L66'></a><a href='#L66'>66</a>
132
+ <a name='L67'></a><a href='#L67'>67</a>
133
+ <a name='L68'></a><a href='#L68'>68</a>
134
+ <a name='L69'></a><a href='#L69'>69</a>
135
+ <a name='L70'></a><a href='#L70'>70</a>
136
+ <a name='L71'></a><a href='#L71'>71</a>
137
+ <a name='L72'></a><a href='#L72'>72</a>
138
+ <a name='L73'></a><a href='#L73'>73</a>
139
+ <a name='L74'></a><a href='#L74'>74</a>
140
+ <a name='L75'></a><a href='#L75'>75</a>
141
+ <a name='L76'></a><a href='#L76'>76</a>
142
+ <a name='L77'></a><a href='#L77'>77</a>
143
+ <a name='L78'></a><a href='#L78'>78</a>
144
+ <a name='L79'></a><a href='#L79'>79</a>
145
+ <a name='L80'></a><a href='#L80'>80</a>
146
+ <a name='L81'></a><a href='#L81'>81</a>
147
+ <a name='L82'></a><a href='#L82'>82</a>
148
+ <a name='L83'></a><a href='#L83'>83</a>
149
+ <a name='L84'></a><a href='#L84'>84</a>
150
+ <a name='L85'></a><a href='#L85'>85</a>
151
+ <a name='L86'></a><a href='#L86'>86</a>
152
+ <a name='L87'></a><a href='#L87'>87</a>
153
+ <a name='L88'></a><a href='#L88'>88</a>
154
+ <a name='L89'></a><a href='#L89'>89</a>
155
+ <a name='L90'></a><a href='#L90'>90</a>
156
+ <a name='L91'></a><a href='#L91'>91</a>
157
+ <a name='L92'></a><a href='#L92'>92</a>
158
+ <a name='L93'></a><a href='#L93'>93</a>
159
+ <a name='L94'></a><a href='#L94'>94</a>
160
+ <a name='L95'></a><a href='#L95'>95</a>
161
+ <a name='L96'></a><a href='#L96'>96</a>
162
+ <a name='L97'></a><a href='#L97'>97</a>
163
+ <a name='L98'></a><a href='#L98'>98</a>
164
+ <a name='L99'></a><a href='#L99'>99</a>
165
+ <a name='L100'></a><a href='#L100'>100</a>
166
+ <a name='L101'></a><a href='#L101'>101</a>
167
+ <a name='L102'></a><a href='#L102'>102</a>
168
+ <a name='L103'></a><a href='#L103'>103</a>
169
+ <a name='L104'></a><a href='#L104'>104</a>
170
+ <a name='L105'></a><a href='#L105'>105</a>
171
+ <a name='L106'></a><a href='#L106'>106</a>
172
+ <a name='L107'></a><a href='#L107'>107</a>
173
+ <a name='L108'></a><a href='#L108'>108</a>
174
+ <a name='L109'></a><a href='#L109'>109</a>
175
+ <a name='L110'></a><a href='#L110'>110</a>
176
+ <a name='L111'></a><a href='#L111'>111</a>
177
+ <a name='L112'></a><a href='#L112'>112</a>
178
+ <a name='L113'></a><a href='#L113'>113</a>
179
+ <a name='L114'></a><a href='#L114'>114</a>
180
+ <a name='L115'></a><a href='#L115'>115</a>
181
+ <a name='L116'></a><a href='#L116'>116</a>
182
+ <a name='L117'></a><a href='#L117'>117</a>
183
+ <a name='L118'></a><a href='#L118'>118</a>
184
+ <a name='L119'></a><a href='#L119'>119</a>
185
+ <a name='L120'></a><a href='#L120'>120</a>
186
+ <a name='L121'></a><a href='#L121'>121</a>
187
+ <a name='L122'></a><a href='#L122'>122</a>
188
+ <a name='L123'></a><a href='#L123'>123</a>
189
+ <a name='L124'></a><a href='#L124'>124</a>
190
+ <a name='L125'></a><a href='#L125'>125</a>
191
+ <a name='L126'></a><a href='#L126'>126</a>
192
+ <a name='L127'></a><a href='#L127'>127</a>
193
+ <a name='L128'></a><a href='#L128'>128</a>
194
+ <a name='L129'></a><a href='#L129'>129</a>
195
+ <a name='L130'></a><a href='#L130'>130</a>
196
+ <a name='L131'></a><a href='#L131'>131</a>
197
+ <a name='L132'></a><a href='#L132'>132</a>
198
+ <a name='L133'></a><a href='#L133'>133</a>
199
+ <a name='L134'></a><a href='#L134'>134</a>
200
+ <a name='L135'></a><a href='#L135'>135</a>
201
+ <a name='L136'></a><a href='#L136'>136</a>
202
+ <a name='L137'></a><a href='#L137'>137</a>
203
+ <a name='L138'></a><a href='#L138'>138</a>
204
+ <a name='L139'></a><a href='#L139'>139</a>
205
+ <a name='L140'></a><a href='#L140'>140</a>
206
+ <a name='L141'></a><a href='#L141'>141</a>
207
+ <a name='L142'></a><a href='#L142'>142</a>
208
+ <a name='L143'></a><a href='#L143'>143</a>
209
+ <a name='L144'></a><a href='#L144'>144</a>
210
+ <a name='L145'></a><a href='#L145'>145</a>
211
+ <a name='L146'></a><a href='#L146'>146</a>
212
+ <a name='L147'></a><a href='#L147'>147</a>
213
+ <a name='L148'></a><a href='#L148'>148</a>
214
+ <a name='L149'></a><a href='#L149'>149</a>
215
+ <a name='L150'></a><a href='#L150'>150</a>
216
+ <a name='L151'></a><a href='#L151'>151</a>
217
+ <a name='L152'></a><a href='#L152'>152</a>
218
+ <a name='L153'></a><a href='#L153'>153</a>
219
+ <a name='L154'></a><a href='#L154'>154</a>
220
+ <a name='L155'></a><a href='#L155'>155</a>
221
+ <a name='L156'></a><a href='#L156'>156</a>
222
+ <a name='L157'></a><a href='#L157'>157</a>
223
+ <a name='L158'></a><a href='#L158'>158</a>
224
+ <a name='L159'></a><a href='#L159'>159</a>
225
+ <a name='L160'></a><a href='#L160'>160</a>
226
+ <a name='L161'></a><a href='#L161'>161</a>
227
+ <a name='L162'></a><a href='#L162'>162</a>
228
+ <a name='L163'></a><a href='#L163'>163</a>
229
+ <a name='L164'></a><a href='#L164'>164</a>
230
+ <a name='L165'></a><a href='#L165'>165</a>
231
+ <a name='L166'></a><a href='#L166'>166</a>
232
+ <a name='L167'></a><a href='#L167'>167</a>
233
+ <a name='L168'></a><a href='#L168'>168</a>
234
+ <a name='L169'></a><a href='#L169'>169</a>
235
+ <a name='L170'></a><a href='#L170'>170</a>
236
+ <a name='L171'></a><a href='#L171'>171</a>
237
+ <a name='L172'></a><a href='#L172'>172</a>
238
+ <a name='L173'></a><a href='#L173'>173</a>
239
+ <a name='L174'></a><a href='#L174'>174</a>
240
+ <a name='L175'></a><a href='#L175'>175</a>
241
+ <a name='L176'></a><a href='#L176'>176</a>
242
+ <a name='L177'></a><a href='#L177'>177</a>
243
+ <a name='L178'></a><a href='#L178'>178</a>
244
+ <a name='L179'></a><a href='#L179'>179</a>
245
+ <a name='L180'></a><a href='#L180'>180</a>
246
+ <a name='L181'></a><a href='#L181'>181</a>
247
+ <a name='L182'></a><a href='#L182'>182</a>
248
+ <a name='L183'></a><a href='#L183'>183</a>
249
+ <a name='L184'></a><a href='#L184'>184</a>
250
+ <a name='L185'></a><a href='#L185'>185</a>
251
+ <a name='L186'></a><a href='#L186'>186</a>
252
+ <a name='L187'></a><a href='#L187'>187</a>
253
+ <a name='L188'></a><a href='#L188'>188</a>
254
+ <a name='L189'></a><a href='#L189'>189</a>
255
+ <a name='L190'></a><a href='#L190'>190</a>
256
+ <a name='L191'></a><a href='#L191'>191</a>
257
+ <a name='L192'></a><a href='#L192'>192</a>
258
+ <a name='L193'></a><a href='#L193'>193</a>
259
+ <a name='L194'></a><a href='#L194'>194</a>
260
+ <a name='L195'></a><a href='#L195'>195</a>
261
+ <a name='L196'></a><a href='#L196'>196</a>
262
+ <a name='L197'></a><a href='#L197'>197</a>
263
+ <a name='L198'></a><a href='#L198'>198</a>
264
+ <a name='L199'></a><a href='#L199'>199</a>
265
+ <a name='L200'></a><a href='#L200'>200</a>
266
+ <a name='L201'></a><a href='#L201'>201</a>
267
+ <a name='L202'></a><a href='#L202'>202</a>
268
+ <a name='L203'></a><a href='#L203'>203</a>
269
+ <a name='L204'></a><a href='#L204'>204</a>
270
+ <a name='L205'></a><a href='#L205'>205</a>
271
+ <a name='L206'></a><a href='#L206'>206</a>
272
+ <a name='L207'></a><a href='#L207'>207</a>
273
+ <a name='L208'></a><a href='#L208'>208</a>
274
+ <a name='L209'></a><a href='#L209'>209</a>
275
+ <a name='L210'></a><a href='#L210'>210</a>
276
+ <a name='L211'></a><a href='#L211'>211</a>
277
+ <a name='L212'></a><a href='#L212'>212</a>
278
+ <a name='L213'></a><a href='#L213'>213</a>
279
+ <a name='L214'></a><a href='#L214'>214</a>
280
+ <a name='L215'></a><a href='#L215'>215</a>
281
+ <a name='L216'></a><a href='#L216'>216</a>
282
+ <a name='L217'></a><a href='#L217'>217</a>
283
+ <a name='L218'></a><a href='#L218'>218</a>
284
+ <a name='L219'></a><a href='#L219'>219</a>
285
+ <a name='L220'></a><a href='#L220'>220</a>
286
+ <a name='L221'></a><a href='#L221'>221</a>
287
+ <a name='L222'></a><a href='#L222'>222</a>
288
+ <a name='L223'></a><a href='#L223'>223</a>
289
+ <a name='L224'></a><a href='#L224'>224</a>
290
+ <a name='L225'></a><a href='#L225'>225</a>
291
+ <a name='L226'></a><a href='#L226'>226</a>
292
+ <a name='L227'></a><a href='#L227'>227</a>
293
+ <a name='L228'></a><a href='#L228'>228</a>
294
+ <a name='L229'></a><a href='#L229'>229</a>
295
+ <a name='L230'></a><a href='#L230'>230</a>
296
+ <a name='L231'></a><a href='#L231'>231</a>
297
+ <a name='L232'></a><a href='#L232'>232</a>
298
+ <a name='L233'></a><a href='#L233'>233</a>
299
+ <a name='L234'></a><a href='#L234'>234</a>
300
+ <a name='L235'></a><a href='#L235'>235</a>
301
+ <a name='L236'></a><a href='#L236'>236</a>
302
+ <a name='L237'></a><a href='#L237'>237</a>
303
+ <a name='L238'></a><a href='#L238'>238</a>
304
+ <a name='L239'></a><a href='#L239'>239</a>
305
+ <a name='L240'></a><a href='#L240'>240</a>
306
+ <a name='L241'></a><a href='#L241'>241</a>
307
+ <a name='L242'></a><a href='#L242'>242</a>
308
+ <a name='L243'></a><a href='#L243'>243</a>
309
+ <a name='L244'></a><a href='#L244'>244</a>
310
+ <a name='L245'></a><a href='#L245'>245</a>
311
+ <a name='L246'></a><a href='#L246'>246</a>
312
+ <a name='L247'></a><a href='#L247'>247</a>
313
+ <a name='L248'></a><a href='#L248'>248</a>
314
+ <a name='L249'></a><a href='#L249'>249</a>
315
+ <a name='L250'></a><a href='#L250'>250</a>
316
+ <a name='L251'></a><a href='#L251'>251</a>
317
+ <a name='L252'></a><a href='#L252'>252</a>
318
+ <a name='L253'></a><a href='#L253'>253</a>
319
+ <a name='L254'></a><a href='#L254'>254</a>
320
+ <a name='L255'></a><a href='#L255'>255</a>
321
+ <a name='L256'></a><a href='#L256'>256</a>
322
+ <a name='L257'></a><a href='#L257'>257</a>
323
+ <a name='L258'></a><a href='#L258'>258</a>
324
+ <a name='L259'></a><a href='#L259'>259</a>
325
+ <a name='L260'></a><a href='#L260'>260</a>
326
+ <a name='L261'></a><a href='#L261'>261</a>
327
+ <a name='L262'></a><a href='#L262'>262</a>
328
+ <a name='L263'></a><a href='#L263'>263</a>
329
+ <a name='L264'></a><a href='#L264'>264</a>
330
+ <a name='L265'></a><a href='#L265'>265</a>
331
+ <a name='L266'></a><a href='#L266'>266</a>
332
+ <a name='L267'></a><a href='#L267'>267</a>
333
+ <a name='L268'></a><a href='#L268'>268</a>
334
+ <a name='L269'></a><a href='#L269'>269</a>
335
+ <a name='L270'></a><a href='#L270'>270</a>
336
+ <a name='L271'></a><a href='#L271'>271</a>
337
+ <a name='L272'></a><a href='#L272'>272</a>
338
+ <a name='L273'></a><a href='#L273'>273</a>
339
+ <a name='L274'></a><a href='#L274'>274</a>
340
+ <a name='L275'></a><a href='#L275'>275</a>
341
+ <a name='L276'></a><a href='#L276'>276</a>
342
+ <a name='L277'></a><a href='#L277'>277</a>
343
+ <a name='L278'></a><a href='#L278'>278</a>
344
+ <a name='L279'></a><a href='#L279'>279</a>
345
+ <a name='L280'></a><a href='#L280'>280</a>
346
+ <a name='L281'></a><a href='#L281'>281</a>
347
+ <a name='L282'></a><a href='#L282'>282</a>
348
+ <a name='L283'></a><a href='#L283'>283</a>
349
+ <a name='L284'></a><a href='#L284'>284</a>
350
+ <a name='L285'></a><a href='#L285'>285</a>
351
+ <a name='L286'></a><a href='#L286'>286</a>
352
+ <a name='L287'></a><a href='#L287'>287</a>
353
+ <a name='L288'></a><a href='#L288'>288</a>
354
+ <a name='L289'></a><a href='#L289'>289</a>
355
+ <a name='L290'></a><a href='#L290'>290</a>
356
+ <a name='L291'></a><a href='#L291'>291</a>
357
+ <a name='L292'></a><a href='#L292'>292</a>
358
+ <a name='L293'></a><a href='#L293'>293</a>
359
+ <a name='L294'></a><a href='#L294'>294</a>
360
+ <a name='L295'></a><a href='#L295'>295</a>
361
+ <a name='L296'></a><a href='#L296'>296</a>
362
+ <a name='L297'></a><a href='#L297'>297</a>
363
+ <a name='L298'></a><a href='#L298'>298</a>
364
+ <a name='L299'></a><a href='#L299'>299</a>
365
+ <a name='L300'></a><a href='#L300'>300</a>
366
+ <a name='L301'></a><a href='#L301'>301</a>
367
+ <a name='L302'></a><a href='#L302'>302</a>
368
+ <a name='L303'></a><a href='#L303'>303</a>
369
+ <a name='L304'></a><a href='#L304'>304</a>
370
+ <a name='L305'></a><a href='#L305'>305</a>
371
+ <a name='L306'></a><a href='#L306'>306</a>
372
+ <a name='L307'></a><a href='#L307'>307</a>
373
+ <a name='L308'></a><a href='#L308'>308</a>
374
+ <a name='L309'></a><a href='#L309'>309</a>
375
+ <a name='L310'></a><a href='#L310'>310</a>
376
+ <a name='L311'></a><a href='#L311'>311</a>
377
+ <a name='L312'></a><a href='#L312'>312</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">10x</span>
378
+ <span class="cline-any cline-yes">10x</span>
379
+ <span class="cline-any cline-yes">10x</span>
380
+ <span class="cline-any cline-yes">10x</span>
381
+ <span class="cline-any cline-neutral">&nbsp;</span>
382
+ <span class="cline-any cline-neutral">&nbsp;</span>
383
+ <span class="cline-any cline-neutral">&nbsp;</span>
384
+ <span class="cline-any cline-yes">10x</span>
385
+ <span class="cline-any cline-yes">10x</span>
386
+ <span class="cline-any cline-yes">10x</span>
387
+ <span class="cline-any cline-yes">10x</span>
388
+ <span class="cline-any cline-neutral">&nbsp;</span>
389
+ <span class="cline-any cline-neutral">&nbsp;</span>
390
+ <span class="cline-any cline-neutral">&nbsp;</span>
391
+ <span class="cline-any cline-neutral">&nbsp;</span>
392
+ <span class="cline-any cline-neutral">&nbsp;</span>
393
+ <span class="cline-any cline-neutral">&nbsp;</span>
394
+ <span class="cline-any cline-neutral">&nbsp;</span>
395
+ <span class="cline-any cline-neutral">&nbsp;</span>
396
+ <span class="cline-any cline-neutral">&nbsp;</span>
397
+ <span class="cline-any cline-neutral">&nbsp;</span>
398
+ <span class="cline-any cline-yes">10x</span>
399
+ <span class="cline-any cline-neutral">&nbsp;</span>
400
+ <span class="cline-any cline-yes">10x</span>
401
+ <span class="cline-any cline-yes">10x</span>
402
+ <span class="cline-any cline-neutral">&nbsp;</span>
403
+ <span class="cline-any cline-yes">10x</span>
404
+ <span class="cline-any cline-neutral">&nbsp;</span>
405
+ <span class="cline-any cline-neutral">&nbsp;</span>
406
+ <span class="cline-any cline-neutral">&nbsp;</span>
407
+ <span class="cline-any cline-neutral">&nbsp;</span>
408
+ <span class="cline-any cline-neutral">&nbsp;</span>
409
+ <span class="cline-any cline-neutral">&nbsp;</span>
410
+ <span class="cline-any cline-neutral">&nbsp;</span>
411
+ <span class="cline-any cline-neutral">&nbsp;</span>
412
+ <span class="cline-any cline-neutral">&nbsp;</span>
413
+ <span class="cline-any cline-neutral">&nbsp;</span>
414
+ <span class="cline-any cline-neutral">&nbsp;</span>
415
+ <span class="cline-any cline-neutral">&nbsp;</span>
416
+ <span class="cline-any cline-neutral">&nbsp;</span>
417
+ <span class="cline-any cline-neutral">&nbsp;</span>
418
+ <span class="cline-any cline-neutral">&nbsp;</span>
419
+ <span class="cline-any cline-neutral">&nbsp;</span>
420
+ <span class="cline-any cline-neutral">&nbsp;</span>
421
+ <span class="cline-any cline-neutral">&nbsp;</span>
422
+ <span class="cline-any cline-neutral">&nbsp;</span>
423
+ <span class="cline-any cline-neutral">&nbsp;</span>
424
+ <span class="cline-any cline-neutral">&nbsp;</span>
425
+ <span class="cline-any cline-neutral">&nbsp;</span>
426
+ <span class="cline-any cline-neutral">&nbsp;</span>
427
+ <span class="cline-any cline-neutral">&nbsp;</span>
428
+ <span class="cline-any cline-neutral">&nbsp;</span>
429
+ <span class="cline-any cline-neutral">&nbsp;</span>
430
+ <span class="cline-any cline-neutral">&nbsp;</span>
431
+ <span class="cline-any cline-neutral">&nbsp;</span>
432
+ <span class="cline-any cline-neutral">&nbsp;</span>
433
+ <span class="cline-any cline-neutral">&nbsp;</span>
434
+ <span class="cline-any cline-neutral">&nbsp;</span>
435
+ <span class="cline-any cline-neutral">&nbsp;</span>
436
+ <span class="cline-any cline-no">&nbsp;</span>
437
+ <span class="cline-any cline-no">&nbsp;</span>
438
+ <span class="cline-any cline-no">&nbsp;</span>
439
+ <span class="cline-any cline-neutral">&nbsp;</span>
440
+ <span class="cline-any cline-neutral">&nbsp;</span>
441
+ <span class="cline-any cline-no">&nbsp;</span>
442
+ <span class="cline-any cline-no">&nbsp;</span>
443
+ <span class="cline-any cline-neutral">&nbsp;</span>
444
+ <span class="cline-any cline-neutral">&nbsp;</span>
445
+ <span class="cline-any cline-neutral">&nbsp;</span>
446
+ <span class="cline-any cline-neutral">&nbsp;</span>
447
+ <span class="cline-any cline-no">&nbsp;</span>
448
+ <span class="cline-any cline-no">&nbsp;</span>
449
+ <span class="cline-any cline-no">&nbsp;</span>
450
+ <span class="cline-any cline-neutral">&nbsp;</span>
451
+ <span class="cline-any cline-neutral">&nbsp;</span>
452
+ <span class="cline-any cline-no">&nbsp;</span>
453
+ <span class="cline-any cline-no">&nbsp;</span>
454
+ <span class="cline-any cline-neutral">&nbsp;</span>
455
+ <span class="cline-any cline-neutral">&nbsp;</span>
456
+ <span class="cline-any cline-no">&nbsp;</span>
457
+ <span class="cline-any cline-neutral">&nbsp;</span>
458
+ <span class="cline-any cline-neutral">&nbsp;</span>
459
+ <span class="cline-any cline-no">&nbsp;</span>
460
+ <span class="cline-any cline-no">&nbsp;</span>
461
+ <span class="cline-any cline-neutral">&nbsp;</span>
462
+ <span class="cline-any cline-neutral">&nbsp;</span>
463
+ <span class="cline-any cline-neutral">&nbsp;</span>
464
+ <span class="cline-any cline-neutral">&nbsp;</span>
465
+ <span class="cline-any cline-no">&nbsp;</span>
466
+ <span class="cline-any cline-neutral">&nbsp;</span>
467
+ <span class="cline-any cline-neutral">&nbsp;</span>
468
+ <span class="cline-any cline-no">&nbsp;</span>
469
+ <span class="cline-any cline-neutral">&nbsp;</span>
470
+ <span class="cline-any cline-neutral">&nbsp;</span>
471
+ <span class="cline-any cline-neutral">&nbsp;</span>
472
+ <span class="cline-any cline-neutral">&nbsp;</span>
473
+ <span class="cline-any cline-no">&nbsp;</span>
474
+ <span class="cline-any cline-no">&nbsp;</span>
475
+ <span class="cline-any cline-neutral">&nbsp;</span>
476
+ <span class="cline-any cline-neutral">&nbsp;</span>
477
+ <span class="cline-any cline-no">&nbsp;</span>
478
+ <span class="cline-any cline-no">&nbsp;</span>
479
+ <span class="cline-any cline-no">&nbsp;</span>
480
+ <span class="cline-any cline-neutral">&nbsp;</span>
481
+ <span class="cline-any cline-neutral">&nbsp;</span>
482
+ <span class="cline-any cline-no">&nbsp;</span>
483
+ <span class="cline-any cline-no">&nbsp;</span>
484
+ <span class="cline-any cline-neutral">&nbsp;</span>
485
+ <span class="cline-any cline-no">&nbsp;</span>
486
+ <span class="cline-any cline-no">&nbsp;</span>
487
+ <span class="cline-any cline-neutral">&nbsp;</span>
488
+ <span class="cline-any cline-neutral">&nbsp;</span>
489
+ <span class="cline-any cline-no">&nbsp;</span>
490
+ <span class="cline-any cline-no">&nbsp;</span>
491
+ <span class="cline-any cline-no">&nbsp;</span>
492
+ <span class="cline-any cline-no">&nbsp;</span>
493
+ <span class="cline-any cline-neutral">&nbsp;</span>
494
+ <span class="cline-any cline-neutral">&nbsp;</span>
495
+ <span class="cline-any cline-no">&nbsp;</span>
496
+ <span class="cline-any cline-no">&nbsp;</span>
497
+ <span class="cline-any cline-neutral">&nbsp;</span>
498
+ <span class="cline-any cline-neutral">&nbsp;</span>
499
+ <span class="cline-any cline-neutral">&nbsp;</span>
500
+ <span class="cline-any cline-neutral">&nbsp;</span>
501
+ <span class="cline-any cline-neutral">&nbsp;</span>
502
+ <span class="cline-any cline-neutral">&nbsp;</span>
503
+ <span class="cline-any cline-neutral">&nbsp;</span>
504
+ <span class="cline-any cline-neutral">&nbsp;</span>
505
+ <span class="cline-any cline-neutral">&nbsp;</span>
506
+ <span class="cline-any cline-neutral">&nbsp;</span>
507
+ <span class="cline-any cline-neutral">&nbsp;</span>
508
+ <span class="cline-any cline-neutral">&nbsp;</span>
509
+ <span class="cline-any cline-neutral">&nbsp;</span>
510
+ <span class="cline-any cline-neutral">&nbsp;</span>
511
+ <span class="cline-any cline-neutral">&nbsp;</span>
512
+ <span class="cline-any cline-neutral">&nbsp;</span>
513
+ <span class="cline-any cline-neutral">&nbsp;</span>
514
+ <span class="cline-any cline-neutral">&nbsp;</span>
515
+ <span class="cline-any cline-neutral">&nbsp;</span>
516
+ <span class="cline-any cline-neutral">&nbsp;</span>
517
+ <span class="cline-any cline-neutral">&nbsp;</span>
518
+ <span class="cline-any cline-no">&nbsp;</span>
519
+ <span class="cline-any cline-no">&nbsp;</span>
520
+ <span class="cline-any cline-neutral">&nbsp;</span>
521
+ <span class="cline-any cline-neutral">&nbsp;</span>
522
+ <span class="cline-any cline-neutral">&nbsp;</span>
523
+ <span class="cline-any cline-neutral">&nbsp;</span>
524
+ <span class="cline-any cline-neutral">&nbsp;</span>
525
+ <span class="cline-any cline-neutral">&nbsp;</span>
526
+ <span class="cline-any cline-neutral">&nbsp;</span>
527
+ <span class="cline-any cline-neutral">&nbsp;</span>
528
+ <span class="cline-any cline-neutral">&nbsp;</span>
529
+ <span class="cline-any cline-neutral">&nbsp;</span>
530
+ <span class="cline-any cline-neutral">&nbsp;</span>
531
+ <span class="cline-any cline-neutral">&nbsp;</span>
532
+ <span class="cline-any cline-no">&nbsp;</span>
533
+ <span class="cline-any cline-neutral">&nbsp;</span>
534
+ <span class="cline-any cline-neutral">&nbsp;</span>
535
+ <span class="cline-any cline-neutral">&nbsp;</span>
536
+ <span class="cline-any cline-no">&nbsp;</span>
537
+ <span class="cline-any cline-no">&nbsp;</span>
538
+ <span class="cline-any cline-neutral">&nbsp;</span>
539
+ <span class="cline-any cline-neutral">&nbsp;</span>
540
+ <span class="cline-any cline-no">&nbsp;</span>
541
+ <span class="cline-any cline-no">&nbsp;</span>
542
+ <span class="cline-any cline-no">&nbsp;</span>
543
+ <span class="cline-any cline-neutral">&nbsp;</span>
544
+ <span class="cline-any cline-neutral">&nbsp;</span>
545
+ <span class="cline-any cline-no">&nbsp;</span>
546
+ <span class="cline-any cline-neutral">&nbsp;</span>
547
+ <span class="cline-any cline-neutral">&nbsp;</span>
548
+ <span class="cline-any cline-neutral">&nbsp;</span>
549
+ <span class="cline-any cline-no">&nbsp;</span>
550
+ <span class="cline-any cline-no">&nbsp;</span>
551
+ <span class="cline-any cline-no">&nbsp;</span>
552
+ <span class="cline-any cline-neutral">&nbsp;</span>
553
+ <span class="cline-any cline-neutral">&nbsp;</span>
554
+ <span class="cline-any cline-no">&nbsp;</span>
555
+ <span class="cline-any cline-neutral">&nbsp;</span>
556
+ <span class="cline-any cline-no">&nbsp;</span>
557
+ <span class="cline-any cline-neutral">&nbsp;</span>
558
+ <span class="cline-any cline-neutral">&nbsp;</span>
559
+ <span class="cline-any cline-neutral">&nbsp;</span>
560
+ <span class="cline-any cline-neutral">&nbsp;</span>
561
+ <span class="cline-any cline-no">&nbsp;</span>
562
+ <span class="cline-any cline-no">&nbsp;</span>
563
+ <span class="cline-any cline-neutral">&nbsp;</span>
564
+ <span class="cline-any cline-neutral">&nbsp;</span>
565
+ <span class="cline-any cline-neutral">&nbsp;</span>
566
+ <span class="cline-any cline-no">&nbsp;</span>
567
+ <span class="cline-any cline-no">&nbsp;</span>
568
+ <span class="cline-any cline-neutral">&nbsp;</span>
569
+ <span class="cline-any cline-neutral">&nbsp;</span>
570
+ <span class="cline-any cline-no">&nbsp;</span>
571
+ <span class="cline-any cline-neutral">&nbsp;</span>
572
+ <span class="cline-any cline-no">&nbsp;</span>
573
+ <span class="cline-any cline-no">&nbsp;</span>
574
+ <span class="cline-any cline-no">&nbsp;</span>
575
+ <span class="cline-any cline-no">&nbsp;</span>
576
+ <span class="cline-any cline-neutral">&nbsp;</span>
577
+ <span class="cline-any cline-neutral">&nbsp;</span>
578
+ <span class="cline-any cline-no">&nbsp;</span>
579
+ <span class="cline-any cline-neutral">&nbsp;</span>
580
+ <span class="cline-any cline-no">&nbsp;</span>
581
+ <span class="cline-any cline-no">&nbsp;</span>
582
+ <span class="cline-any cline-neutral">&nbsp;</span>
583
+ <span class="cline-any cline-neutral">&nbsp;</span>
584
+ <span class="cline-any cline-neutral">&nbsp;</span>
585
+ <span class="cline-any cline-no">&nbsp;</span>
586
+ <span class="cline-any cline-no">&nbsp;</span>
587
+ <span class="cline-any cline-neutral">&nbsp;</span>
588
+ <span class="cline-any cline-no">&nbsp;</span>
589
+ <span class="cline-any cline-no">&nbsp;</span>
590
+ <span class="cline-any cline-neutral">&nbsp;</span>
591
+ <span class="cline-any cline-no">&nbsp;</span>
592
+ <span class="cline-any cline-no">&nbsp;</span>
593
+ <span class="cline-any cline-neutral">&nbsp;</span>
594
+ <span class="cline-any cline-neutral">&nbsp;</span>
595
+ <span class="cline-any cline-no">&nbsp;</span>
596
+ <span class="cline-any cline-neutral">&nbsp;</span>
597
+ <span class="cline-any cline-neutral">&nbsp;</span>
598
+ <span class="cline-any cline-neutral">&nbsp;</span>
599
+ <span class="cline-any cline-neutral">&nbsp;</span>
600
+ <span class="cline-any cline-neutral">&nbsp;</span>
601
+ <span class="cline-any cline-neutral">&nbsp;</span>
602
+ <span class="cline-any cline-neutral">&nbsp;</span>
603
+ <span class="cline-any cline-neutral">&nbsp;</span>
604
+ <span class="cline-any cline-neutral">&nbsp;</span>
605
+ <span class="cline-any cline-neutral">&nbsp;</span>
606
+ <span class="cline-any cline-neutral">&nbsp;</span>
607
+ <span class="cline-any cline-no">&nbsp;</span>
608
+ <span class="cline-any cline-no">&nbsp;</span>
609
+ <span class="cline-any cline-neutral">&nbsp;</span>
610
+ <span class="cline-any cline-neutral">&nbsp;</span>
611
+ <span class="cline-any cline-neutral">&nbsp;</span>
612
+ <span class="cline-any cline-neutral">&nbsp;</span>
613
+ <span class="cline-any cline-neutral">&nbsp;</span>
614
+ <span class="cline-any cline-no">&nbsp;</span>
615
+ <span class="cline-any cline-neutral">&nbsp;</span>
616
+ <span class="cline-any cline-neutral">&nbsp;</span>
617
+ <span class="cline-any cline-no">&nbsp;</span>
618
+ <span class="cline-any cline-no">&nbsp;</span>
619
+ <span class="cline-any cline-neutral">&nbsp;</span>
620
+ <span class="cline-any cline-neutral">&nbsp;</span>
621
+ <span class="cline-any cline-no">&nbsp;</span>
622
+ <span class="cline-any cline-no">&nbsp;</span>
623
+ <span class="cline-any cline-no">&nbsp;</span>
624
+ <span class="cline-any cline-no">&nbsp;</span>
625
+ <span class="cline-any cline-no">&nbsp;</span>
626
+ <span class="cline-any cline-neutral">&nbsp;</span>
627
+ <span class="cline-any cline-neutral">&nbsp;</span>
628
+ <span class="cline-any cline-neutral">&nbsp;</span>
629
+ <span class="cline-any cline-no">&nbsp;</span>
630
+ <span class="cline-any cline-neutral">&nbsp;</span>
631
+ <span class="cline-any cline-neutral">&nbsp;</span>
632
+ <span class="cline-any cline-neutral">&nbsp;</span>
633
+ <span class="cline-any cline-no">&nbsp;</span>
634
+ <span class="cline-any cline-neutral">&nbsp;</span>
635
+ <span class="cline-any cline-neutral">&nbsp;</span>
636
+ <span class="cline-any cline-neutral">&nbsp;</span>
637
+ <span class="cline-any cline-no">&nbsp;</span>
638
+ <span class="cline-any cline-no">&nbsp;</span>
639
+ <span class="cline-any cline-neutral">&nbsp;</span>
640
+ <span class="cline-any cline-neutral">&nbsp;</span>
641
+ <span class="cline-any cline-neutral">&nbsp;</span>
642
+ <span class="cline-any cline-neutral">&nbsp;</span>
643
+ <span class="cline-any cline-neutral">&nbsp;</span>
644
+ <span class="cline-any cline-no">&nbsp;</span>
645
+ <span class="cline-any cline-neutral">&nbsp;</span>
646
+ <span class="cline-any cline-neutral">&nbsp;</span>
647
+ <span class="cline-any cline-no">&nbsp;</span>
648
+ <span class="cline-any cline-no">&nbsp;</span>
649
+ <span class="cline-any cline-neutral">&nbsp;</span>
650
+ <span class="cline-any cline-neutral">&nbsp;</span>
651
+ <span class="cline-any cline-no">&nbsp;</span>
652
+ <span class="cline-any cline-neutral">&nbsp;</span>
653
+ <span class="cline-any cline-neutral">&nbsp;</span>
654
+ <span class="cline-any cline-neutral">&nbsp;</span>
655
+ <span class="cline-any cline-neutral">&nbsp;</span>
656
+ <span class="cline-any cline-neutral">&nbsp;</span>
657
+ <span class="cline-any cline-no">&nbsp;</span>
658
+ <span class="cline-any cline-no">&nbsp;</span>
659
+ <span class="cline-any cline-no">&nbsp;</span>
660
+ <span class="cline-any cline-neutral">&nbsp;</span>
661
+ <span class="cline-any cline-neutral">&nbsp;</span>
662
+ <span class="cline-any cline-neutral">&nbsp;</span>
663
+ <span class="cline-any cline-neutral">&nbsp;</span>
664
+ <span class="cline-any cline-neutral">&nbsp;</span>
665
+ <span class="cline-any cline-no">&nbsp;</span>
666
+ <span class="cline-any cline-no">&nbsp;</span>
667
+ <span class="cline-any cline-neutral">&nbsp;</span>
668
+ <span class="cline-any cline-neutral">&nbsp;</span>
669
+ <span class="cline-any cline-no">&nbsp;</span>
670
+ <span class="cline-any cline-no">&nbsp;</span>
671
+ <span class="cline-any cline-no">&nbsp;</span>
672
+ <span class="cline-any cline-neutral">&nbsp;</span>
673
+ <span class="cline-any cline-neutral">&nbsp;</span>
674
+ <span class="cline-any cline-no">&nbsp;</span>
675
+ <span class="cline-any cline-no">&nbsp;</span>
676
+ <span class="cline-any cline-neutral">&nbsp;</span>
677
+ <span class="cline-any cline-neutral">&nbsp;</span>
678
+ <span class="cline-any cline-neutral">&nbsp;</span>
679
+ <span class="cline-any cline-neutral">&nbsp;</span>
680
+ <span class="cline-any cline-no">&nbsp;</span>
681
+ <span class="cline-any cline-no">&nbsp;</span>
682
+ <span class="cline-any cline-neutral">&nbsp;</span>
683
+ <span class="cline-any cline-neutral">&nbsp;</span>
684
+ <span class="cline-any cline-neutral">&nbsp;</span>
685
+ <span class="cline-any cline-no">&nbsp;</span>
686
+ <span class="cline-any cline-neutral">&nbsp;</span>
687
+ <span class="cline-any cline-neutral">&nbsp;</span>
688
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import { gzip, ungzip } from 'node-gzip';
689
+ import { from } from 'rxjs';
690
+ import rfdc from 'rfdc';
691
+ import _ from 'lodash';
692
+ &nbsp;
693
+ import type { Expectation, IExpectationSchemaForward } from '../../../expectations';
694
+ &nbsp;
695
+ import { ExecutorManualError } from './errors';
696
+ import { cast, wait } from '../../../utils';
697
+ import { Logger } from '../../../logger';
698
+ import {
699
+ parsePayload,
700
+ RequestContext,
701
+ serializePayload,
702
+ extractPayloadType,
703
+ IRequestContextCache,
704
+ IRequestContextOutgoing,
705
+ IRequestContextIncoming,
706
+ IRequestContextForwarded,
707
+ } from '../context';
708
+ &nbsp;
709
+ export * from './errors';
710
+ &nbsp;
711
+ const clone = rfdc();
712
+ const logger = Logger.build('Server.Models.Executor');
713
+ &nbsp;
714
+ export abstract class Executor&lt;TRequestContext extends RequestContext = RequestContext&gt; {
715
+ public TRequestContext!: TRequestContext;
716
+ public TContext!: TRequestContext['TContext'];
717
+ &nbsp;
718
+ /**
719
+ * Uses to handle a request flow when expectation is matched or not
720
+ */
721
+ public abstract handleExpectationMatch(
722
+ context: TRequestContext,
723
+ expectation: Expectation&lt;any&gt; | null
724
+ ): Promise&lt;unknown&gt;;
725
+ &nbsp;
726
+ /**
727
+ * Uses to handle request forwarding
728
+ */
729
+ public abstract forward(
730
+ context: TRequestContext,
731
+ incoming: IRequestContextIncoming,
732
+ configuration: IExpectationSchemaForward,
733
+ ): Promise&lt;IRequestContextForwarded | null&gt;;
734
+ &nbsp;
735
+ /**
736
+ * Uses to handle outgoing payload and reply
737
+ */
738
+ public abstract reply(
739
+ context: TRequestContext,
740
+ outgoing: IRequestContextOutgoing
741
+ ): Promise&lt;IRequestContextOutgoing | null&gt;;
742
+ &nbsp;
743
+ /**
744
+ * Uses to handle whole request
745
+ */
746
+ public <span class="fstat-no" title="function not covered" >async </span>exec(context: TRequestContext): Promise&lt;TRequestContext&gt; {
747
+ const expectation = <span class="cstat-no" title="statement not covered" >await this.matchExpectation(context).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {</span>
748
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while execution [matchExpectation] method', error?.stack ?? error);</span>
749
+ <span class="cstat-no" title="statement not covered" > return null;</span>
750
+ });
751
+ &nbsp;
752
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!expectation) {</span>
753
+ <span class="cstat-no" title="statement not covered" > await this.handleExpectationMatch(context, null).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; <span class="cstat-no" title="statement not covered" >logger.error(</span></span>
754
+ 'Got error while execution [handleAfterExpectationMatch] method',
755
+ error?.stack ?? error
756
+ ));
757
+ &nbsp;
758
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!context.outgoing) {</span>
759
+ <span class="cstat-no" title="statement not covered" > context.provider.storages.history.unregister(context.history);</span>
760
+ <span class="cstat-no" title="statement not covered" > return context;</span>
761
+ }
762
+ &nbsp;
763
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (context.history?.hasStatus('registred')) {</span>
764
+ <span class="cstat-no" title="statement not covered" > context.history.switchStatus('pending');</span>
765
+ }
766
+ &nbsp;
767
+ <span class="cstat-no" title="statement not covered" > return context;</span>
768
+ }
769
+ &nbsp;
770
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (context.history?.hasStatus('registred')) {</span>
771
+ <span class="cstat-no" title="statement not covered" > context.history</span>
772
+ .switchStatus('pending')
773
+ .actualizeSnapshot(context.snapshot)
774
+ .assign({ expectation: context.expectation });
775
+ &nbsp;
776
+ <span class="cstat-no" title="statement not covered" > context.provider.exchanges.io.publish('history:added', context.history.toPlain());</span>
777
+ }
778
+ &nbsp;
779
+ <span class="cstat-no" title="statement not covered" > await this.handleExpectationMatch(context, expectation).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; <span class="cstat-no" title="statement not covered" >logger.error(</span></span>
780
+ 'Got error while execution [handleAfterExpectationMatch] method',
781
+ error?.stack ?? error
782
+ ));
783
+ &nbsp;
784
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!context.hasStatus('handling')) {</span>
785
+ <span class="cstat-no" title="statement not covered" > return context;</span>
786
+ }
787
+ &nbsp;
788
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (context.snapshot.incoming.delay) {</span>
789
+ <span class="cstat-no" title="statement not covered" > logger.info(`Has delayed over [${context.snapshot.incoming.delay}ms]`);</span>
790
+ <span class="cstat-no" title="statement not covered" > await wait(context.snapshot.incoming.delay);</span>
791
+ }
792
+ &nbsp;
793
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (context.snapshot.incoming.error) {</span>
794
+ <span class="cstat-no" title="statement not covered" > logger.info(`Has destroyed using [${context.snapshot.incoming.error}]`);</span>
795
+ &nbsp;
796
+ <span class="cstat-no" title="statement not covered" > context.snapshot.assign({ error: { code: context.snapshot.incoming.error, isManual: true } });</span>
797
+ <span class="cstat-no" title="statement not covered" > throw ExecutorManualError.build(context.snapshot.incoming.error);</span>
798
+ }
799
+ &nbsp;
800
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (expectation.forward) {</span>
801
+ const forwarded = <span class="cstat-no" title="statement not covered" >await this.handleForwarding(context).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {</span>
802
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while execution [handleForwarding] method', error?.stack ?? error);</span>
803
+ <span class="cstat-no" title="statement not covered" > return null;</span>
804
+ });
805
+ &nbsp;
806
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (forwarded) {</span>
807
+ <span class="cstat-no" title="statement not covered" > context.snapshot.assign({</span>
808
+ outgoing: forwarded.outgoing ?? context.snapshot.outgoing,
809
+ &nbsp;
810
+ forwarded: {
811
+ isCached: forwarded.isCached,
812
+ messages: clone(forwarded.messages),
813
+ &nbsp;
814
+ incoming: Object.assign(
815
+ clone(_.omit(forwarded.incoming, ['stream'])),
816
+ _.pick(forwarded.incoming, ['stream'])
817
+ ),
818
+ &nbsp;
819
+ ...(forwarded.outgoing &amp;&amp; {
820
+ outgoing: Object.assign(
821
+ clone(_.omit(forwarded.outgoing, ['stream'])),
822
+ _.pick(forwarded.outgoing, ['stream'])
823
+ ),
824
+ }),
825
+ }
826
+ });
827
+ }
828
+ &nbsp;
829
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (context.snapshot.forwarded &amp;&amp; context.history?.hasStatus('pending')) {</span>
830
+ <span class="cstat-no" title="statement not covered" > context.history.snapshot.assign({</span>
831
+ cache: context.snapshot.cache,
832
+ &nbsp;
833
+ forwarded: {
834
+ isCached: context.snapshot.forwarded.isCached,
835
+ incoming: _.omit(context.snapshot.forwarded.incoming, ['stream']),
836
+ &nbsp;
837
+ ...(context.snapshot.forwarded.outgoing &amp;&amp; {
838
+ outgoing: _.omit(context.snapshot.forwarded.outgoing, ['stream'])
839
+ }),
840
+ },
841
+ });
842
+ &nbsp;
843
+ <span class="cstat-no" title="statement not covered" > context.provider.exchanges.io.publish('history:updated', context.history.toPlain());</span>
844
+ }
845
+ }
846
+ &nbsp;
847
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!context.hasStatus('handling')) {</span>
848
+ <span class="cstat-no" title="statement not covered" > return context;</span>
849
+ }
850
+ &nbsp;
851
+ const outgoing = <span class="cstat-no" title="statement not covered" >await this.handleReplying(context).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {</span>
852
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while execution [handleReplying] method', error?.stack ?? error);</span>
853
+ <span class="cstat-no" title="statement not covered" > return null;</span>
854
+ });
855
+ &nbsp;
856
+ <span class="cstat-no" title="statement not covered" > return outgoing ? context.assign({ outgoing }) : context;</span>
857
+ }
858
+ &nbsp;
859
+ private <span class="fstat-no" title="function not covered" >async </span>matchExpectation(context: TRequestContext): Promise&lt;Expectation&lt;any&gt; | null&gt; {
860
+ const expectation = <span class="cstat-no" title="statement not covered" >context.provider.storages.expectations.match(context.snapshot);</span>
861
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!expectation) {</span>
862
+ <span class="cstat-no" title="statement not covered" > return null;</span>
863
+ }
864
+ &nbsp;
865
+ <span class="cstat-no" title="statement not covered" > logger.info('Expectation has matched as', `"${expectation.name}" [${expectation.id}]`);</span>
866
+ &nbsp;
867
+ <span class="cstat-no" title="statement not covered" > context.assign({</span>
868
+ snapshot: expectation.request.manipulate(context.snapshot),
869
+ expectation: expectation.increaseExecutionsCounter(),
870
+ });
871
+ &nbsp;
872
+ <span class="cstat-no" title="statement not covered" > context.provider.exchanges.io.publish('expectation:updated', expectation.toPlain());</span>
873
+ <span class="cstat-no" title="statement not covered" > return expectation;</span>
874
+ }
875
+ &nbsp;
876
+ private <span class="fstat-no" title="function not covered" >async </span>handleForwarding(context: TRequestContext): Promise&lt;IRequestContextForwarded | null&gt; {
877
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!context.expectation?.forward) {</span>
878
+ <span class="cstat-no" title="statement not covered" > return context.snapshot;</span>
879
+ }
880
+ &nbsp;
881
+ const snapshot = <span class="cstat-no" title="statement not covered" >context.snapshot.assign({ cache: context.compileCacheConfiguration() });</span>
882
+ &nbsp;
883
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (snapshot.cache.isEnabled) {</span>
884
+ const cached = <span class="cstat-no" title="statement not covered" >await context.provider.databases.redis!.get(snapshot.cache.key).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {</span>
885
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while redis get', error?.stack ?? error);</span>
886
+ <span class="cstat-no" title="statement not covered" > return null;</span>
887
+ });
888
+ &nbsp;
889
+ const unziped = <span class="cstat-no" title="statement not covered" >cached</span>
890
+ ? await ungzip(Buffer.from(cached, 'base64')).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {
891
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while cache unzip', error?.stack ?? error);</span>
892
+ <span class="cstat-no" title="statement not covered" > return null;</span>
893
+ })
894
+ : null;
895
+ &nbsp;
896
+ const parsed = &lt;IRequestContextCache | null&gt;(<span class="cstat-no" title="statement not covered" >unziped ? parsePayload('json', unziped) : null)</span>;
897
+ const dataRaw = <span class="cstat-no" title="statement not covered" >parsed?.outgoing.dataRaw ? Buffer.from(parsed?.outgoing.dataRaw, 'base64') : undefined;</span>
898
+ &nbsp;
899
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (parsed) {</span>
900
+ <span class="cstat-no" title="statement not covered" > logger.info(`Got cache [${snapshot.cache.key}]`);</span>
901
+ &nbsp;
902
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (parsed.messages?.length) {</span>
903
+ <span class="cstat-no" title="statement not covered" > parsed.outgoing.stream = from(parsed.messages.map(<span class="fstat-no" title="function not covered" >(m</span>essage) =&gt; <span class="cstat-no" title="statement not covered" >message.data)</span> ?? []);</span>
904
+ }
905
+ &nbsp;
906
+ <span class="cstat-no" title="statement not covered" > return Object.assign(snapshot.pick(['incoming']), {</span>
907
+ isCached: true,
908
+ messages: parsed.messages,
909
+ &nbsp;
910
+ outgoing: Object.assign(_.omit(parsed.outgoing, ['dataRaw']), {
911
+ data: dataRaw ? parsePayload(parsed.outgoing.type, dataRaw) : undefined,
912
+ dataRaw,
913
+ }),
914
+ });
915
+ }
916
+ }
917
+ &nbsp;
918
+ const type = <span class="cstat-no" title="statement not covered" >extractPayloadType(snapshot.incoming.headers) ?? 'plain';</span>
919
+ const dataRaw = <span class="cstat-no" title="statement not covered" >snapshot.incoming.data === undefined</span>
920
+ ? snapshot.incoming.dataRaw
921
+ : typeof snapshot.incoming.data === 'object'
922
+ ? serializePayload(type, snapshot.incoming.data)
923
+ : Buffer.from(String(snapshot.incoming.data));
924
+ &nbsp;
925
+ const forwarded = <span class="cstat-no" title="statement not covered" >await this</span>
926
+ .forward(context, Object.assign(snapshot.incoming, { type, dataRaw }), context.expectation.forward)
927
+ .catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {
928
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while execution [forward] method', error?.stack ?? error);</span>
929
+ <span class="cstat-no" title="statement not covered" > return null;</span>
930
+ });
931
+ &nbsp;
932
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (forwarded) {</span>
933
+ <span class="cstat-no" title="statement not covered" > forwarded.messages = [];</span>
934
+ <span class="cstat-no" title="statement not covered" > forwarded.outgoing?.stream?.subscribe({</span>
935
+ error: <span class="fstat-no" title="function not covered" >() =</span>&gt; <span class="cstat-no" title="statement not covered" >null,</span>
936
+ next: <span class="fstat-no" title="function not covered" >(d</span>ata) =&gt; <span class="cstat-no" title="statement not covered" >forwarded.messages!.push({ data, location: 'outgoing' }),</span>
937
+ });
938
+ }
939
+ &nbsp;
940
+ <span class="cstat-no" title="statement not covered" > return forwarded;</span>
941
+ }
942
+ &nbsp;
943
+ private <span class="fstat-no" title="function not covered" >async </span>handleReplying(context: TRequestContext): Promise&lt;IRequestContextOutgoing | null&gt; {
944
+ const snapshot = <span class="cstat-no" title="statement not covered" >context.expectation?.response</span>
945
+ ? context.expectation.response.manipulate(context.snapshot)
946
+ : context.snapshot;
947
+ &nbsp;
948
+ const type = <span class="cstat-no" title="statement not covered" >extractPayloadType(snapshot.outgoing.headers) ?? snapshot.outgoing.type;</span>
949
+ const dataRaw = <span class="cstat-no" title="statement not covered" >snapshot.outgoing.data === undefined</span>
950
+ ? snapshot.outgoing.dataRaw
951
+ : typeof snapshot.outgoing.data === 'object'
952
+ ? serializePayload(type, snapshot.outgoing.data)
953
+ : Buffer.from(String(snapshot.outgoing.data));
954
+ &nbsp;
955
+ const outgoing = <span class="cstat-no" title="statement not covered" >await this</span>
956
+ .reply(context, Object.assign(snapshot.outgoing, { type, dataRaw }))
957
+ .catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {
958
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while execution [reply] method', error?.stack ?? error);</span>
959
+ <span class="cstat-no" title="statement not covered" > return null;</span>
960
+ });
961
+ &nbsp;
962
+ const shouldBeCached = <span class="cstat-no" title="statement not covered" >snapshot.cache.isEnabled</span>
963
+ &amp;&amp; snapshot.forwarded?.outgoing
964
+ &amp;&amp; !snapshot.forwarded.isCached
965
+ &amp;&amp; snapshot.cache.ttl
966
+ &amp;&amp; typeof snapshot.cache.key === 'string';
967
+ &nbsp;
968
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (shouldBeCached) {</span>
969
+ const serialized = <span class="cstat-no" title="statement not covered" >serializePayload('json', cast&lt;IRequestContextCache&gt;({</span>
970
+ messages: snapshot.forwarded!.messages?.filter(<span class="fstat-no" title="function not covered" >(m</span>essage) =&gt; <span class="cstat-no" title="statement not covered" >message.location === 'outgoing')</span>,
971
+ outgoing: Object.assign(_.omit(snapshot.forwarded!.outgoing, ['data']), {
972
+ dataRaw: snapshot.forwarded!.outgoing?.dataRaw?.toString('base64'),
973
+ }),
974
+ }));
975
+ &nbsp;
976
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!serialized) {</span>
977
+ <span class="cstat-no" title="statement not covered" > return outgoing;</span>
978
+ }
979
+ &nbsp;
980
+ const zipped = <span class="cstat-no" title="statement not covered" >await gzip(serialized).catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; {</span>
981
+ <span class="cstat-no" title="statement not covered" > logger.error('Got error while zip payload', error?.stack ?? error);</span>
982
+ <span class="cstat-no" title="statement not covered" > return null;</span>
983
+ });
984
+ &nbsp;
985
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (zipped) {</span>
986
+ <span class="cstat-no" title="statement not covered" > await context.provider.databases.redis!.setex(</span>
987
+ &lt;string&gt;snapshot.cache.key,
988
+ snapshot.cache.ttl!,
989
+ zipped.toString('base64')
990
+ )
991
+ .then(<span class="fstat-no" title="function not covered" >() =</span>&gt; <span class="cstat-no" title="statement not covered" >logger.info(`Wrote cache [${snapshot.cache.key}] for [${snapshot.cache.ttl}] seconds`))</span>
992
+ .catch(<span class="fstat-no" title="function not covered" >(e</span>rror) =&gt; <span class="cstat-no" title="statement not covered" >logger.error('Got error while redis set', error?.stack ?? error))</span>;
993
+ }
994
+ }
995
+ &nbsp;
996
+ <span class="cstat-no" title="statement not covered" > return outgoing;</span>
997
+ }
998
+ }
999
+ &nbsp;</pre></td></tr></table></pre>
1000
+
1001
+ <div class='push'></div><!-- for sticky footer -->
1002
+ </div><!-- /wrapper -->
1003
+ <div class='footer quiet pad2 space-top1 center small'>
1004
+ Code coverage generated by
1005
+ <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
1006
+ at 2025-02-26T06:03:47.554Z
1007
+ </div>
1008
+ <script src="../../../prettify.js"></script>
1009
+ <script>
1010
+ window.onload = function () {
1011
+ prettyPrint();
1012
+ };
1013
+ </script>
1014
+ <script src="../../../sorter.js"></script>
1015
+ <script src="../../../block-navigation.js"></script>
1016
+ </body>
1017
+ </html>
1018
+