nestlens 0.1.0

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 (359) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +145 -0
  3. package/dist/__tests__/api/api.controller.spec.d.ts +2 -0
  4. package/dist/__tests__/api/api.controller.spec.d.ts.map +1 -0
  5. package/dist/__tests__/api/api.controller.spec.js +982 -0
  6. package/dist/__tests__/api/api.controller.spec.js.map +1 -0
  7. package/dist/__tests__/api/api.guard.spec.d.ts +2 -0
  8. package/dist/__tests__/api/api.guard.spec.d.ts.map +1 -0
  9. package/dist/__tests__/api/api.guard.spec.js +572 -0
  10. package/dist/__tests__/api/api.guard.spec.js.map +1 -0
  11. package/dist/__tests__/api/dashboard.controller.spec.d.ts +2 -0
  12. package/dist/__tests__/api/dashboard.controller.spec.d.ts.map +1 -0
  13. package/dist/__tests__/api/dashboard.controller.spec.js +474 -0
  14. package/dist/__tests__/api/dashboard.controller.spec.js.map +1 -0
  15. package/dist/__tests__/api/tag.controller.spec.d.ts +2 -0
  16. package/dist/__tests__/api/tag.controller.spec.d.ts.map +1 -0
  17. package/dist/__tests__/api/tag.controller.spec.js +280 -0
  18. package/dist/__tests__/api/tag.controller.spec.js.map +1 -0
  19. package/dist/__tests__/collector.service.spec.d.ts +2 -0
  20. package/dist/__tests__/collector.service.spec.d.ts.map +1 -0
  21. package/dist/__tests__/collector.service.spec.js +240 -0
  22. package/dist/__tests__/collector.service.spec.js.map +1 -0
  23. package/dist/__tests__/core/collector.service.spec.d.ts +2 -0
  24. package/dist/__tests__/core/collector.service.spec.d.ts.map +1 -0
  25. package/dist/__tests__/core/collector.service.spec.js +526 -0
  26. package/dist/__tests__/core/collector.service.spec.js.map +1 -0
  27. package/dist/__tests__/core/family-hash.service.spec.d.ts +2 -0
  28. package/dist/__tests__/core/family-hash.service.spec.d.ts.map +1 -0
  29. package/dist/__tests__/core/family-hash.service.spec.js +1117 -0
  30. package/dist/__tests__/core/family-hash.service.spec.js.map +1 -0
  31. package/dist/__tests__/core/pruning.service.spec.d.ts +2 -0
  32. package/dist/__tests__/core/pruning.service.spec.d.ts.map +1 -0
  33. package/dist/__tests__/core/pruning.service.spec.js +224 -0
  34. package/dist/__tests__/core/pruning.service.spec.js.map +1 -0
  35. package/dist/__tests__/core/storage/sqlite.storage.spec.d.ts +2 -0
  36. package/dist/__tests__/core/storage/sqlite.storage.spec.d.ts.map +1 -0
  37. package/dist/__tests__/core/storage/sqlite.storage.spec.js +853 -0
  38. package/dist/__tests__/core/storage/sqlite.storage.spec.js.map +1 -0
  39. package/dist/__tests__/core/tag.service.spec.d.ts +2 -0
  40. package/dist/__tests__/core/tag.service.spec.d.ts.map +1 -0
  41. package/dist/__tests__/core/tag.service.spec.js +994 -0
  42. package/dist/__tests__/core/tag.service.spec.js.map +1 -0
  43. package/dist/__tests__/family-hash.service.spec.d.ts +2 -0
  44. package/dist/__tests__/family-hash.service.spec.d.ts.map +1 -0
  45. package/dist/__tests__/family-hash.service.spec.js +325 -0
  46. package/dist/__tests__/family-hash.service.spec.js.map +1 -0
  47. package/dist/__tests__/filters/api-filters.spec.d.ts +2 -0
  48. package/dist/__tests__/filters/api-filters.spec.d.ts.map +1 -0
  49. package/dist/__tests__/filters/api-filters.spec.js +172 -0
  50. package/dist/__tests__/filters/api-filters.spec.js.map +1 -0
  51. package/dist/__tests__/filters/entry-factories.d.ts +20 -0
  52. package/dist/__tests__/filters/entry-factories.d.ts.map +1 -0
  53. package/dist/__tests__/filters/entry-factories.js +288 -0
  54. package/dist/__tests__/filters/entry-factories.js.map +1 -0
  55. package/dist/__tests__/filters/filter-contract.spec.d.ts +2 -0
  56. package/dist/__tests__/filters/filter-contract.spec.d.ts.map +1 -0
  57. package/dist/__tests__/filters/filter-contract.spec.js +230 -0
  58. package/dist/__tests__/filters/filter-contract.spec.js.map +1 -0
  59. package/dist/__tests__/filters/filter-test-data.d.ts +26 -0
  60. package/dist/__tests__/filters/filter-test-data.d.ts.map +1 -0
  61. package/dist/__tests__/filters/filter-test-data.js +374 -0
  62. package/dist/__tests__/filters/filter-test-data.js.map +1 -0
  63. package/dist/__tests__/filters/storage-filters.spec.d.ts +2 -0
  64. package/dist/__tests__/filters/storage-filters.spec.d.ts.map +1 -0
  65. package/dist/__tests__/filters/storage-filters.spec.js +699 -0
  66. package/dist/__tests__/filters/storage-filters.spec.js.map +1 -0
  67. package/dist/__tests__/filters/test-utils.d.ts +23 -0
  68. package/dist/__tests__/filters/test-utils.d.ts.map +1 -0
  69. package/dist/__tests__/filters/test-utils.js +54 -0
  70. package/dist/__tests__/filters/test-utils.js.map +1 -0
  71. package/dist/__tests__/nestlens.module.spec.d.ts +2 -0
  72. package/dist/__tests__/nestlens.module.spec.d.ts.map +1 -0
  73. package/dist/__tests__/nestlens.module.spec.js +620 -0
  74. package/dist/__tests__/nestlens.module.spec.js.map +1 -0
  75. package/dist/__tests__/pruning.service.spec.d.ts +2 -0
  76. package/dist/__tests__/pruning.service.spec.d.ts.map +1 -0
  77. package/dist/__tests__/pruning.service.spec.js +142 -0
  78. package/dist/__tests__/pruning.service.spec.js.map +1 -0
  79. package/dist/__tests__/setup.d.ts +7 -0
  80. package/dist/__tests__/setup.d.ts.map +1 -0
  81. package/dist/__tests__/setup.js +24 -0
  82. package/dist/__tests__/setup.js.map +1 -0
  83. package/dist/__tests__/tag.service.spec.d.ts +2 -0
  84. package/dist/__tests__/tag.service.spec.d.ts.map +1 -0
  85. package/dist/__tests__/tag.service.spec.js +482 -0
  86. package/dist/__tests__/tag.service.spec.js.map +1 -0
  87. package/dist/__tests__/watchers/batch.watcher.spec.d.ts +2 -0
  88. package/dist/__tests__/watchers/batch.watcher.spec.d.ts.map +1 -0
  89. package/dist/__tests__/watchers/batch.watcher.spec.js +515 -0
  90. package/dist/__tests__/watchers/batch.watcher.spec.js.map +1 -0
  91. package/dist/__tests__/watchers/cache.watcher.spec.d.ts +2 -0
  92. package/dist/__tests__/watchers/cache.watcher.spec.d.ts.map +1 -0
  93. package/dist/__tests__/watchers/cache.watcher.spec.js +395 -0
  94. package/dist/__tests__/watchers/cache.watcher.spec.js.map +1 -0
  95. package/dist/__tests__/watchers/command.watcher.spec.d.ts +2 -0
  96. package/dist/__tests__/watchers/command.watcher.spec.d.ts.map +1 -0
  97. package/dist/__tests__/watchers/command.watcher.spec.js +598 -0
  98. package/dist/__tests__/watchers/command.watcher.spec.js.map +1 -0
  99. package/dist/__tests__/watchers/dump.watcher.spec.d.ts +2 -0
  100. package/dist/__tests__/watchers/dump.watcher.spec.d.ts.map +1 -0
  101. package/dist/__tests__/watchers/dump.watcher.spec.js +724 -0
  102. package/dist/__tests__/watchers/dump.watcher.spec.js.map +1 -0
  103. package/dist/__tests__/watchers/event.watcher.spec.d.ts +2 -0
  104. package/dist/__tests__/watchers/event.watcher.spec.d.ts.map +1 -0
  105. package/dist/__tests__/watchers/event.watcher.spec.js +316 -0
  106. package/dist/__tests__/watchers/event.watcher.spec.js.map +1 -0
  107. package/dist/__tests__/watchers/exception.watcher.spec.d.ts +2 -0
  108. package/dist/__tests__/watchers/exception.watcher.spec.d.ts.map +1 -0
  109. package/dist/__tests__/watchers/exception.watcher.spec.js +495 -0
  110. package/dist/__tests__/watchers/exception.watcher.spec.js.map +1 -0
  111. package/dist/__tests__/watchers/gate.watcher.spec.d.ts +2 -0
  112. package/dist/__tests__/watchers/gate.watcher.spec.d.ts.map +1 -0
  113. package/dist/__tests__/watchers/gate.watcher.spec.js +683 -0
  114. package/dist/__tests__/watchers/gate.watcher.spec.js.map +1 -0
  115. package/dist/__tests__/watchers/http-client.watcher.spec.d.ts +2 -0
  116. package/dist/__tests__/watchers/http-client.watcher.spec.d.ts.map +1 -0
  117. package/dist/__tests__/watchers/http-client.watcher.spec.js +888 -0
  118. package/dist/__tests__/watchers/http-client.watcher.spec.js.map +1 -0
  119. package/dist/__tests__/watchers/job.watcher.spec.d.ts +2 -0
  120. package/dist/__tests__/watchers/job.watcher.spec.d.ts.map +1 -0
  121. package/dist/__tests__/watchers/job.watcher.spec.js +513 -0
  122. package/dist/__tests__/watchers/job.watcher.spec.js.map +1 -0
  123. package/dist/__tests__/watchers/log.watcher.spec.d.ts +2 -0
  124. package/dist/__tests__/watchers/log.watcher.spec.d.ts.map +1 -0
  125. package/dist/__tests__/watchers/log.watcher.spec.js +428 -0
  126. package/dist/__tests__/watchers/log.watcher.spec.js.map +1 -0
  127. package/dist/__tests__/watchers/mail.watcher.spec.d.ts +2 -0
  128. package/dist/__tests__/watchers/mail.watcher.spec.d.ts.map +1 -0
  129. package/dist/__tests__/watchers/mail.watcher.spec.js +425 -0
  130. package/dist/__tests__/watchers/mail.watcher.spec.js.map +1 -0
  131. package/dist/__tests__/watchers/model.watcher.spec.d.ts +2 -0
  132. package/dist/__tests__/watchers/model.watcher.spec.d.ts.map +1 -0
  133. package/dist/__tests__/watchers/model.watcher.spec.js +675 -0
  134. package/dist/__tests__/watchers/model.watcher.spec.js.map +1 -0
  135. package/dist/__tests__/watchers/notification.watcher.spec.d.ts +2 -0
  136. package/dist/__tests__/watchers/notification.watcher.spec.d.ts.map +1 -0
  137. package/dist/__tests__/watchers/notification.watcher.spec.js +595 -0
  138. package/dist/__tests__/watchers/notification.watcher.spec.js.map +1 -0
  139. package/dist/__tests__/watchers/query/types.spec.d.ts +2 -0
  140. package/dist/__tests__/watchers/query/types.spec.d.ts.map +1 -0
  141. package/dist/__tests__/watchers/query/types.spec.js +292 -0
  142. package/dist/__tests__/watchers/query/types.spec.js.map +1 -0
  143. package/dist/__tests__/watchers/query.watcher.spec.d.ts +2 -0
  144. package/dist/__tests__/watchers/query.watcher.spec.d.ts.map +1 -0
  145. package/dist/__tests__/watchers/query.watcher.spec.js +597 -0
  146. package/dist/__tests__/watchers/query.watcher.spec.js.map +1 -0
  147. package/dist/__tests__/watchers/redis.watcher.spec.d.ts +2 -0
  148. package/dist/__tests__/watchers/redis.watcher.spec.d.ts.map +1 -0
  149. package/dist/__tests__/watchers/redis.watcher.spec.js +634 -0
  150. package/dist/__tests__/watchers/redis.watcher.spec.js.map +1 -0
  151. package/dist/__tests__/watchers/request.watcher.spec.d.ts +2 -0
  152. package/dist/__tests__/watchers/request.watcher.spec.d.ts.map +1 -0
  153. package/dist/__tests__/watchers/request.watcher.spec.js +1017 -0
  154. package/dist/__tests__/watchers/request.watcher.spec.js.map +1 -0
  155. package/dist/__tests__/watchers/schedule.watcher.spec.d.ts +2 -0
  156. package/dist/__tests__/watchers/schedule.watcher.spec.d.ts.map +1 -0
  157. package/dist/__tests__/watchers/schedule.watcher.spec.js +338 -0
  158. package/dist/__tests__/watchers/schedule.watcher.spec.js.map +1 -0
  159. package/dist/__tests__/watchers/view.watcher.spec.d.ts +2 -0
  160. package/dist/__tests__/watchers/view.watcher.spec.d.ts.map +1 -0
  161. package/dist/__tests__/watchers/view.watcher.spec.js +564 -0
  162. package/dist/__tests__/watchers/view.watcher.spec.js.map +1 -0
  163. package/dist/api/api.controller.d.ts +193 -0
  164. package/dist/api/api.controller.d.ts.map +1 -0
  165. package/dist/api/api.controller.js +562 -0
  166. package/dist/api/api.controller.js.map +1 -0
  167. package/dist/api/api.guard.d.ts +77 -0
  168. package/dist/api/api.guard.d.ts.map +1 -0
  169. package/dist/api/api.guard.js +294 -0
  170. package/dist/api/api.guard.js.map +1 -0
  171. package/dist/api/dashboard.controller.d.ts +49 -0
  172. package/dist/api/dashboard.controller.d.ts.map +1 -0
  173. package/dist/api/dashboard.controller.js +472 -0
  174. package/dist/api/dashboard.controller.js.map +1 -0
  175. package/dist/api/index.d.ts +5 -0
  176. package/dist/api/index.d.ts.map +1 -0
  177. package/dist/api/index.js +21 -0
  178. package/dist/api/index.js.map +1 -0
  179. package/dist/api/tag.controller.d.ts +65 -0
  180. package/dist/api/tag.controller.d.ts.map +1 -0
  181. package/dist/api/tag.controller.js +149 -0
  182. package/dist/api/tag.controller.js.map +1 -0
  183. package/dist/core/collector.service.d.ts +80 -0
  184. package/dist/core/collector.service.d.ts.map +1 -0
  185. package/dist/core/collector.service.js +255 -0
  186. package/dist/core/collector.service.js.map +1 -0
  187. package/dist/core/family-hash.service.d.ts +64 -0
  188. package/dist/core/family-hash.service.d.ts.map +1 -0
  189. package/dist/core/family-hash.service.js +281 -0
  190. package/dist/core/family-hash.service.js.map +1 -0
  191. package/dist/core/index.d.ts +4 -0
  192. package/dist/core/index.d.ts.map +1 -0
  193. package/dist/core/index.js +20 -0
  194. package/dist/core/index.js.map +1 -0
  195. package/dist/core/pruning.service.d.ts +16 -0
  196. package/dist/core/pruning.service.d.ts.map +1 -0
  197. package/dist/core/pruning.service.js +71 -0
  198. package/dist/core/pruning.service.js.map +1 -0
  199. package/dist/core/storage/index.d.ts +3 -0
  200. package/dist/core/storage/index.d.ts.map +1 -0
  201. package/dist/core/storage/index.js +19 -0
  202. package/dist/core/storage/index.js.map +1 -0
  203. package/dist/core/storage/sqlite.storage.d.ts +60 -0
  204. package/dist/core/storage/sqlite.storage.d.ts.map +1 -0
  205. package/dist/core/storage/sqlite.storage.js +929 -0
  206. package/dist/core/storage/sqlite.storage.js.map +1 -0
  207. package/dist/core/storage/storage.interface.d.ts +122 -0
  208. package/dist/core/storage/storage.interface.d.ts.map +1 -0
  209. package/dist/core/storage/storage.interface.js +5 -0
  210. package/dist/core/storage/storage.interface.js.map +1 -0
  211. package/dist/core/tag.service.d.ts +71 -0
  212. package/dist/core/tag.service.d.ts.map +1 -0
  213. package/dist/core/tag.service.js +568 -0
  214. package/dist/core/tag.service.js.map +1 -0
  215. package/dist/dashboard/public/assets/BatchesPage-DFT4fKlJ.js +1 -0
  216. package/dist/dashboard/public/assets/CachePage-CRy1Tjb8.js +1 -0
  217. package/dist/dashboard/public/assets/ClickableBadge-CV5J3THx.js +1 -0
  218. package/dist/dashboard/public/assets/CommandsPage-DdRnTm-W.js +1 -0
  219. package/dist/dashboard/public/assets/DashboardPage-CjaRZXYy.js +26 -0
  220. package/dist/dashboard/public/assets/DataTable-B6o9H8lh.js +88 -0
  221. package/dist/dashboard/public/assets/DumpsPage-DO8y1RTg.js +1 -0
  222. package/dist/dashboard/public/assets/EntryDetailPage-By-YcAGL.js +125 -0
  223. package/dist/dashboard/public/assets/EventsPage-u-r4AiT4.js +1 -0
  224. package/dist/dashboard/public/assets/ExceptionsPage-DXUcARr1.js +6 -0
  225. package/dist/dashboard/public/assets/GatesPage-DpeP7CDZ.js +1 -0
  226. package/dist/dashboard/public/assets/HttpClientPage-BJ4-5E6t.js +1 -0
  227. package/dist/dashboard/public/assets/JobsPage-Dv3KaX2x.js +1 -0
  228. package/dist/dashboard/public/assets/LogsPage-D0Q3yDb1.js +1 -0
  229. package/dist/dashboard/public/assets/MailPage-Bf8C6WF6.js +1 -0
  230. package/dist/dashboard/public/assets/ModelsPage-BMHncI5y.js +1 -0
  231. package/dist/dashboard/public/assets/NotificationsPage-D5-I-Oxb.js +1 -0
  232. package/dist/dashboard/public/assets/QueriesPage-oNp0i6Gt.js +1 -0
  233. package/dist/dashboard/public/assets/RedisPage-_GeS2OD8.js +1 -0
  234. package/dist/dashboard/public/assets/RequestsPage-BCwqu9US.js +1 -0
  235. package/dist/dashboard/public/assets/SchedulePage-CR0P-oX6.js +1 -0
  236. package/dist/dashboard/public/assets/ViewsPage-Dsy5ECRA.js +1 -0
  237. package/dist/dashboard/public/assets/calendar-DfK3x-6B.js +6 -0
  238. package/dist/dashboard/public/assets/circle-check-big-DcsYW8y8.js +6 -0
  239. package/dist/dashboard/public/assets/format-BFldcnCk.js +1 -0
  240. package/dist/dashboard/public/assets/index-DmeA1maE.css +1 -0
  241. package/dist/dashboard/public/assets/index-rkbGYdU7.js +351 -0
  242. package/dist/dashboard/public/assets/types-Cldoe2db.js +1 -0
  243. package/dist/dashboard/public/assets/vendor-B2nVRih0.js +43 -0
  244. package/dist/dashboard/public/assets/zap-DqtRi0JM.js +6 -0
  245. package/dist/dashboard/public/index.html +15 -0
  246. package/dist/dashboard/public/nestlens-icon.svg +9 -0
  247. package/dist/index.d.ts +22 -0
  248. package/dist/index.d.ts.map +1 -0
  249. package/dist/index.js +69 -0
  250. package/dist/index.js.map +1 -0
  251. package/dist/nestlens.config.d.ts +216 -0
  252. package/dist/nestlens.config.d.ts.map +1 -0
  253. package/dist/nestlens.config.js +57 -0
  254. package/dist/nestlens.config.js.map +1 -0
  255. package/dist/nestlens.module.d.ts +10 -0
  256. package/dist/nestlens.module.d.ts.map +1 -0
  257. package/dist/nestlens.module.js +211 -0
  258. package/dist/nestlens.module.js.map +1 -0
  259. package/dist/types/entry.types.d.ts +368 -0
  260. package/dist/types/entry.types.d.ts.map +1 -0
  261. package/dist/types/entry.types.js +3 -0
  262. package/dist/types/entry.types.js.map +1 -0
  263. package/dist/types/index.d.ts +4 -0
  264. package/dist/types/index.d.ts.map +1 -0
  265. package/dist/types/index.js +20 -0
  266. package/dist/types/index.js.map +1 -0
  267. package/dist/types/request.types.d.ts +9 -0
  268. package/dist/types/request.types.d.ts.map +1 -0
  269. package/dist/types/request.types.js +3 -0
  270. package/dist/types/request.types.js.map +1 -0
  271. package/dist/types/tag.types.d.ts +32 -0
  272. package/dist/types/tag.types.d.ts.map +1 -0
  273. package/dist/types/tag.types.js +3 -0
  274. package/dist/types/tag.types.js.map +1 -0
  275. package/dist/watchers/batch.watcher.d.ts +48 -0
  276. package/dist/watchers/batch.watcher.d.ts.map +1 -0
  277. package/dist/watchers/batch.watcher.js +185 -0
  278. package/dist/watchers/batch.watcher.js.map +1 -0
  279. package/dist/watchers/cache.watcher.d.ts +19 -0
  280. package/dist/watchers/cache.watcher.d.ts.map +1 -0
  281. package/dist/watchers/cache.watcher.js +158 -0
  282. package/dist/watchers/cache.watcher.js.map +1 -0
  283. package/dist/watchers/command.watcher.d.ts +32 -0
  284. package/dist/watchers/command.watcher.d.ts.map +1 -0
  285. package/dist/watchers/command.watcher.js +174 -0
  286. package/dist/watchers/command.watcher.js.map +1 -0
  287. package/dist/watchers/dump.watcher.d.ts +52 -0
  288. package/dist/watchers/dump.watcher.d.ts.map +1 -0
  289. package/dist/watchers/dump.watcher.js +234 -0
  290. package/dist/watchers/dump.watcher.js.map +1 -0
  291. package/dist/watchers/event.watcher.d.ts +20 -0
  292. package/dist/watchers/event.watcher.d.ts.map +1 -0
  293. package/dist/watchers/event.watcher.js +123 -0
  294. package/dist/watchers/event.watcher.js.map +1 -0
  295. package/dist/watchers/exception.watcher.d.ts +15 -0
  296. package/dist/watchers/exception.watcher.d.ts.map +1 -0
  297. package/dist/watchers/exception.watcher.js +117 -0
  298. package/dist/watchers/exception.watcher.js.map +1 -0
  299. package/dist/watchers/gate.watcher.d.ts +40 -0
  300. package/dist/watchers/gate.watcher.d.ts.map +1 -0
  301. package/dist/watchers/gate.watcher.js +200 -0
  302. package/dist/watchers/gate.watcher.js.map +1 -0
  303. package/dist/watchers/http-client.watcher.d.ts +34 -0
  304. package/dist/watchers/http-client.watcher.d.ts.map +1 -0
  305. package/dist/watchers/http-client.watcher.js +259 -0
  306. package/dist/watchers/http-client.watcher.js.map +1 -0
  307. package/dist/watchers/index.d.ts +19 -0
  308. package/dist/watchers/index.d.ts.map +1 -0
  309. package/dist/watchers/index.js +35 -0
  310. package/dist/watchers/index.js.map +1 -0
  311. package/dist/watchers/job.watcher.d.ts +27 -0
  312. package/dist/watchers/job.watcher.d.ts.map +1 -0
  313. package/dist/watchers/job.watcher.js +190 -0
  314. package/dist/watchers/job.watcher.js.map +1 -0
  315. package/dist/watchers/log.watcher.d.ts +26 -0
  316. package/dist/watchers/log.watcher.d.ts.map +1 -0
  317. package/dist/watchers/log.watcher.js +122 -0
  318. package/dist/watchers/log.watcher.js.map +1 -0
  319. package/dist/watchers/mail.watcher.d.ts +26 -0
  320. package/dist/watchers/mail.watcher.d.ts.map +1 -0
  321. package/dist/watchers/mail.watcher.js +154 -0
  322. package/dist/watchers/mail.watcher.js.map +1 -0
  323. package/dist/watchers/model.watcher.d.ts +54 -0
  324. package/dist/watchers/model.watcher.d.ts.map +1 -0
  325. package/dist/watchers/model.watcher.js +343 -0
  326. package/dist/watchers/model.watcher.js.map +1 -0
  327. package/dist/watchers/notification.watcher.d.ts +48 -0
  328. package/dist/watchers/notification.watcher.d.ts.map +1 -0
  329. package/dist/watchers/notification.watcher.js +215 -0
  330. package/dist/watchers/notification.watcher.js.map +1 -0
  331. package/dist/watchers/query/index.d.ts +3 -0
  332. package/dist/watchers/query/index.d.ts.map +1 -0
  333. package/dist/watchers/query/index.js +19 -0
  334. package/dist/watchers/query/index.js.map +1 -0
  335. package/dist/watchers/query/query.watcher.d.ts +27 -0
  336. package/dist/watchers/query/query.watcher.d.ts.map +1 -0
  337. package/dist/watchers/query/query.watcher.js +167 -0
  338. package/dist/watchers/query/query.watcher.js.map +1 -0
  339. package/dist/watchers/query/types.d.ts +60 -0
  340. package/dist/watchers/query/types.d.ts.map +1 -0
  341. package/dist/watchers/query/types.js +55 -0
  342. package/dist/watchers/query/types.js.map +1 -0
  343. package/dist/watchers/redis.watcher.d.ts +43 -0
  344. package/dist/watchers/redis.watcher.d.ts.map +1 -0
  345. package/dist/watchers/redis.watcher.js +225 -0
  346. package/dist/watchers/redis.watcher.js.map +1 -0
  347. package/dist/watchers/request.watcher.d.ts +21 -0
  348. package/dist/watchers/request.watcher.d.ts.map +1 -0
  349. package/dist/watchers/request.watcher.js +287 -0
  350. package/dist/watchers/request.watcher.js.map +1 -0
  351. package/dist/watchers/schedule.watcher.d.ts +25 -0
  352. package/dist/watchers/schedule.watcher.d.ts.map +1 -0
  353. package/dist/watchers/schedule.watcher.js +168 -0
  354. package/dist/watchers/schedule.watcher.js.map +1 -0
  355. package/dist/watchers/view.watcher.d.ts +51 -0
  356. package/dist/watchers/view.watcher.d.ts.map +1 -0
  357. package/dist/watchers/view.watcher.js +219 -0
  358. package/dist/watchers/view.watcher.js.map +1 -0
  359. package/package.json +86 -0
@@ -0,0 +1,280 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ /**
4
+ * TagController Tests
5
+ *
6
+ * Tests for the tag management API endpoints.
7
+ * Follows AAA (Arrange-Act-Assert) pattern.
8
+ */
9
+ const testing_1 = require("@nestjs/testing");
10
+ const tag_controller_1 = require("../../api/tag.controller");
11
+ const tag_service_1 = require("../../core/tag.service");
12
+ const nestlens_config_1 = require("../../nestlens.config");
13
+ describe('TagController', () => {
14
+ let controller;
15
+ let mockTagService;
16
+ beforeEach(async () => {
17
+ mockTagService = {
18
+ getAllTags: jest.fn(),
19
+ findByTags: jest.fn(),
20
+ getEntryTags: jest.fn(),
21
+ addTags: jest.fn(),
22
+ removeTags: jest.fn(),
23
+ getMonitoredTagsWithCounts: jest.fn(),
24
+ addMonitoredTag: jest.fn(),
25
+ removeMonitoredTag: jest.fn(),
26
+ autoTag: jest.fn(),
27
+ };
28
+ const module = await testing_1.Test.createTestingModule({
29
+ controllers: [tag_controller_1.TagController],
30
+ providers: [
31
+ { provide: tag_service_1.TagService, useValue: mockTagService },
32
+ {
33
+ provide: nestlens_config_1.NESTLENS_CONFIG,
34
+ useValue: {
35
+ enabled: true,
36
+ authorization: { allowedEnvironments: ['test'] },
37
+ },
38
+ },
39
+ ],
40
+ }).compile();
41
+ controller = module.get(tag_controller_1.TagController);
42
+ });
43
+ // ============================================================================
44
+ // getAllTags
45
+ // ============================================================================
46
+ describe('getAllTags', () => {
47
+ it('should return all tags with counts', async () => {
48
+ // Arrange
49
+ const mockTags = [
50
+ { tag: 'ERROR', count: 10 },
51
+ { tag: 'SUCCESS', count: 50 },
52
+ { tag: 'SLOW', count: 5 },
53
+ ];
54
+ mockTagService.getAllTags.mockResolvedValue(mockTags);
55
+ // Act
56
+ const result = await controller.getAllTags();
57
+ // Assert
58
+ expect(result).toEqual({ data: mockTags });
59
+ expect(mockTagService.getAllTags).toHaveBeenCalledTimes(1);
60
+ });
61
+ it('should return empty array when no tags exist', async () => {
62
+ // Arrange
63
+ mockTagService.getAllTags.mockResolvedValue([]);
64
+ // Act
65
+ const result = await controller.getAllTags();
66
+ // Assert
67
+ expect(result).toEqual({ data: [] });
68
+ });
69
+ });
70
+ // ============================================================================
71
+ // getEntriesByTags
72
+ // ============================================================================
73
+ describe('getEntriesByTags', () => {
74
+ it('should find entries by single tag with default logic', async () => {
75
+ // Arrange
76
+ const mockEntries = [
77
+ { id: 1, type: 'request', payload: {} },
78
+ { id: 2, type: 'request', payload: {} },
79
+ ];
80
+ mockTagService.findByTags.mockResolvedValue(mockEntries);
81
+ // Act
82
+ const result = await controller.getEntriesByTags('ERROR', undefined, undefined);
83
+ // Assert
84
+ expect(result).toEqual({ data: mockEntries });
85
+ expect(mockTagService.findByTags).toHaveBeenCalledWith(['ERROR'], 'OR', 50);
86
+ });
87
+ it('should find entries by multiple tags with AND logic', async () => {
88
+ // Arrange
89
+ const mockEntries = [{ id: 1, type: 'request', payload: {} }];
90
+ mockTagService.findByTags.mockResolvedValue(mockEntries);
91
+ // Act
92
+ const result = await controller.getEntriesByTags('ERROR,SLOW', 'AND', undefined);
93
+ // Assert
94
+ expect(result).toEqual({ data: mockEntries });
95
+ expect(mockTagService.findByTags).toHaveBeenCalledWith(['ERROR', 'SLOW'], 'AND', 50);
96
+ });
97
+ it('should find entries by multiple tags with OR logic', async () => {
98
+ // Arrange
99
+ const mockEntries = [
100
+ { id: 1, type: 'request', payload: {} },
101
+ { id: 2, type: 'exception', payload: {} },
102
+ ];
103
+ mockTagService.findByTags.mockResolvedValue(mockEntries);
104
+ // Act
105
+ const result = await controller.getEntriesByTags('ERROR,SLOW', 'OR', undefined);
106
+ // Assert
107
+ expect(result).toEqual({ data: mockEntries });
108
+ expect(mockTagService.findByTags).toHaveBeenCalledWith(['ERROR', 'SLOW'], 'OR', 50);
109
+ });
110
+ it('should respect custom limit', async () => {
111
+ // Arrange
112
+ mockTagService.findByTags.mockResolvedValue([]);
113
+ // Act
114
+ await controller.getEntriesByTags('ERROR', undefined, '100');
115
+ // Assert
116
+ expect(mockTagService.findByTags).toHaveBeenCalledWith(['ERROR'], 'OR', 100);
117
+ });
118
+ it('should trim whitespace from tags', async () => {
119
+ // Arrange
120
+ mockTagService.findByTags.mockResolvedValue([]);
121
+ // Act
122
+ await controller.getEntriesByTags(' ERROR , SLOW ', undefined, undefined);
123
+ // Assert
124
+ expect(mockTagService.findByTags).toHaveBeenCalledWith(['ERROR', 'SLOW'], 'OR', 50);
125
+ });
126
+ it('should filter empty tags', async () => {
127
+ // Arrange
128
+ mockTagService.findByTags.mockResolvedValue([]);
129
+ // Act
130
+ await controller.getEntriesByTags('ERROR,,SLOW,', undefined, undefined);
131
+ // Assert
132
+ expect(mockTagService.findByTags).toHaveBeenCalledWith(['ERROR', 'SLOW'], 'OR', 50);
133
+ });
134
+ });
135
+ // ============================================================================
136
+ // getEntryTags
137
+ // ============================================================================
138
+ describe('getEntryTags', () => {
139
+ it('should return tags for a specific entry', async () => {
140
+ // Arrange
141
+ const mockTags = ['ERROR', 'POST', '5XX'];
142
+ mockTagService.getEntryTags.mockResolvedValue(mockTags);
143
+ // Act
144
+ const result = await controller.getEntryTags(123);
145
+ // Assert
146
+ expect(result).toEqual({ data: mockTags });
147
+ expect(mockTagService.getEntryTags).toHaveBeenCalledWith(123);
148
+ });
149
+ it('should return empty array for entry with no tags', async () => {
150
+ // Arrange
151
+ mockTagService.getEntryTags.mockResolvedValue([]);
152
+ // Act
153
+ const result = await controller.getEntryTags(456);
154
+ // Assert
155
+ expect(result).toEqual({ data: [] });
156
+ });
157
+ });
158
+ // ============================================================================
159
+ // addTagsToEntry
160
+ // ============================================================================
161
+ describe('addTagsToEntry', () => {
162
+ it('should add tags to an entry and return updated tags', async () => {
163
+ // Arrange
164
+ const updatedTags = ['ERROR', 'CUSTOM', 'NEW-TAG'];
165
+ mockTagService.addTags.mockResolvedValue(undefined);
166
+ mockTagService.getEntryTags.mockResolvedValue(updatedTags);
167
+ // Act
168
+ const result = await controller.addTagsToEntry(123, { tags: ['CUSTOM', 'NEW-TAG'] });
169
+ // Assert
170
+ expect(result).toEqual({ success: true, data: updatedTags });
171
+ expect(mockTagService.addTags).toHaveBeenCalledWith(123, ['CUSTOM', 'NEW-TAG']);
172
+ expect(mockTagService.getEntryTags).toHaveBeenCalledWith(123);
173
+ });
174
+ it('should add single tag', async () => {
175
+ // Arrange
176
+ mockTagService.addTags.mockResolvedValue(undefined);
177
+ mockTagService.getEntryTags.mockResolvedValue(['SINGLE']);
178
+ // Act
179
+ const result = await controller.addTagsToEntry(1, { tags: ['SINGLE'] });
180
+ // Assert
181
+ expect(result).toEqual({ success: true, data: ['SINGLE'] });
182
+ expect(mockTagService.addTags).toHaveBeenCalledWith(1, ['SINGLE']);
183
+ });
184
+ it('should handle adding multiple tags', async () => {
185
+ // Arrange
186
+ const tags = ['TAG1', 'TAG2', 'TAG3'];
187
+ mockTagService.addTags.mockResolvedValue(undefined);
188
+ mockTagService.getEntryTags.mockResolvedValue(tags);
189
+ // Act
190
+ const result = await controller.addTagsToEntry(1, { tags });
191
+ // Assert
192
+ expect(result.data).toEqual(tags);
193
+ });
194
+ });
195
+ // ============================================================================
196
+ // removeTagsFromEntry
197
+ // ============================================================================
198
+ describe('removeTagsFromEntry', () => {
199
+ it('should remove tags from an entry and return remaining tags', async () => {
200
+ // Arrange
201
+ const remainingTags = ['ERROR'];
202
+ mockTagService.removeTags.mockResolvedValue(undefined);
203
+ mockTagService.getEntryTags.mockResolvedValue(remainingTags);
204
+ // Act
205
+ const result = await controller.removeTagsFromEntry(123, { tags: ['CUSTOM'] });
206
+ // Assert
207
+ expect(result).toEqual({ success: true, data: remainingTags });
208
+ expect(mockTagService.removeTags).toHaveBeenCalledWith(123, ['CUSTOM']);
209
+ expect(mockTagService.getEntryTags).toHaveBeenCalledWith(123);
210
+ });
211
+ it('should return empty array when all tags removed', async () => {
212
+ // Arrange
213
+ mockTagService.removeTags.mockResolvedValue(undefined);
214
+ mockTagService.getEntryTags.mockResolvedValue([]);
215
+ // Act
216
+ const result = await controller.removeTagsFromEntry(1, { tags: ['ONLY-TAG'] });
217
+ // Assert
218
+ expect(result).toEqual({ success: true, data: [] });
219
+ });
220
+ });
221
+ // ============================================================================
222
+ // Monitored Tags
223
+ // ============================================================================
224
+ describe('getMonitoredTags', () => {
225
+ it('should return all monitored tags with counts', async () => {
226
+ // Arrange
227
+ const mockMonitoredTags = [
228
+ { id: 1, tag: 'PRODUCTION-ERROR', createdAt: '2024-01-01', count: 25 },
229
+ { id: 2, tag: 'CRITICAL', createdAt: '2024-01-02', count: 5 },
230
+ ];
231
+ mockTagService.getMonitoredTagsWithCounts.mockResolvedValue(mockMonitoredTags);
232
+ // Act
233
+ const result = await controller.getMonitoredTags();
234
+ // Assert
235
+ expect(result).toEqual({ data: mockMonitoredTags });
236
+ expect(mockTagService.getMonitoredTagsWithCounts).toHaveBeenCalledTimes(1);
237
+ });
238
+ it('should return empty array when no monitored tags', async () => {
239
+ // Arrange
240
+ mockTagService.getMonitoredTagsWithCounts.mockResolvedValue([]);
241
+ // Act
242
+ const result = await controller.getMonitoredTags();
243
+ // Assert
244
+ expect(result).toEqual({ data: [] });
245
+ });
246
+ });
247
+ describe('addMonitoredTag', () => {
248
+ it('should add a monitored tag', async () => {
249
+ // Arrange
250
+ const mockTag = { id: 1, tag: 'CRITICAL', createdAt: '2024-01-01T00:00:00Z' };
251
+ mockTagService.addMonitoredTag.mockResolvedValue(mockTag);
252
+ // Act
253
+ const result = await controller.addMonitoredTag({ tag: 'CRITICAL' });
254
+ // Assert
255
+ expect(result).toEqual({ success: true, data: mockTag });
256
+ expect(mockTagService.addMonitoredTag).toHaveBeenCalledWith('CRITICAL');
257
+ });
258
+ });
259
+ describe('removeMonitoredTag', () => {
260
+ it('should remove a monitored tag', async () => {
261
+ // Arrange
262
+ mockTagService.removeMonitoredTag.mockResolvedValue(undefined);
263
+ // Act
264
+ const result = await controller.removeMonitoredTag('CRITICAL');
265
+ // Assert
266
+ expect(result).toEqual({ success: true });
267
+ expect(mockTagService.removeMonitoredTag).toHaveBeenCalledWith('CRITICAL');
268
+ });
269
+ it('should handle URL-encoded tag names', async () => {
270
+ // Arrange
271
+ mockTagService.removeMonitoredTag.mockResolvedValue(undefined);
272
+ // Act
273
+ const result = await controller.removeMonitoredTag('USER%3A123');
274
+ // Assert
275
+ expect(result).toEqual({ success: true });
276
+ expect(mockTagService.removeMonitoredTag).toHaveBeenCalledWith('USER%3A123');
277
+ });
278
+ });
279
+ });
280
+ //# sourceMappingURL=tag.controller.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tag.controller.spec.js","sourceRoot":"","sources":["../../../src/__tests__/api/tag.controller.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=collector.service.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collector.service.spec.d.ts","sourceRoot":"","sources":["../../src/__tests__/collector.service.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,240 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const testing_1 = require("@nestjs/testing");
4
+ const collector_service_1 = require("../core/collector.service");
5
+ const storage_interface_1 = require("../core/storage/storage.interface");
6
+ const tag_service_1 = require("../core/tag.service");
7
+ const family_hash_service_1 = require("../core/family-hash.service");
8
+ const nestlens_config_1 = require("../nestlens.config");
9
+ describe('CollectorService', () => {
10
+ let service;
11
+ let mockStorage;
12
+ let mockTagService;
13
+ let mockFamilyHashService;
14
+ const createMockRequestPayload = (overrides = {}) => ({
15
+ method: 'GET',
16
+ url: '/api/test',
17
+ path: '/api/test',
18
+ query: {},
19
+ params: {},
20
+ headers: {},
21
+ statusCode: 200,
22
+ duration: 100,
23
+ memory: 0,
24
+ ...overrides,
25
+ });
26
+ const createMockEntry = (overrides = {}) => ({
27
+ id: 1,
28
+ type: 'request',
29
+ payload: createMockRequestPayload(),
30
+ requestId: 'test-request-id',
31
+ createdAt: new Date().toISOString(),
32
+ ...overrides,
33
+ });
34
+ beforeEach(async () => {
35
+ // Create mock storage with all required methods
36
+ mockStorage = {
37
+ initialize: jest.fn(),
38
+ save: jest.fn(),
39
+ saveBatch: jest.fn(),
40
+ find: jest.fn(),
41
+ findWithCursor: jest.fn(),
42
+ findById: jest.fn(),
43
+ count: jest.fn(),
44
+ getLatestSequence: jest.fn(),
45
+ hasEntriesAfter: jest.fn(),
46
+ getStats: jest.fn(),
47
+ getStorageStats: jest.fn(),
48
+ prune: jest.fn(),
49
+ pruneByType: jest.fn(),
50
+ clear: jest.fn(),
51
+ close: jest.fn(),
52
+ addTags: jest.fn(),
53
+ removeTags: jest.fn(),
54
+ getEntryTags: jest.fn(),
55
+ getAllTags: jest.fn(),
56
+ findByTags: jest.fn(),
57
+ addMonitoredTag: jest.fn(),
58
+ removeMonitoredTag: jest.fn(),
59
+ getMonitoredTags: jest.fn(),
60
+ resolveEntry: jest.fn(),
61
+ unresolveEntry: jest.fn(),
62
+ updateFamilyHash: jest.fn(),
63
+ findByFamilyHash: jest.fn(),
64
+ getGroupedByFamilyHash: jest.fn(),
65
+ };
66
+ // Create mock tag service
67
+ mockTagService = {
68
+ autoTag: jest.fn(),
69
+ };
70
+ // Create mock family hash service
71
+ mockFamilyHashService = {
72
+ generateFamilyHash: jest.fn(),
73
+ };
74
+ const module = await testing_1.Test.createTestingModule({
75
+ providers: [
76
+ collector_service_1.CollectorService,
77
+ { provide: storage_interface_1.STORAGE, useValue: mockStorage },
78
+ { provide: nestlens_config_1.NESTLENS_CONFIG, useValue: {} },
79
+ { provide: tag_service_1.TagService, useValue: mockTagService },
80
+ { provide: family_hash_service_1.FamilyHashService, useValue: mockFamilyHashService },
81
+ ],
82
+ }).compile();
83
+ service = module.get(collector_service_1.CollectorService);
84
+ });
85
+ afterEach(async () => {
86
+ // Clean up timer
87
+ await service.shutdown();
88
+ });
89
+ describe('collect', () => {
90
+ it('should add entry to buffer', async () => {
91
+ await service.collect('request', createMockRequestPayload());
92
+ // Buffer should have one entry (access via flush)
93
+ expect(mockStorage.saveBatch).not.toHaveBeenCalled();
94
+ });
95
+ it('should flush when buffer reaches BUFFER_SIZE', async () => {
96
+ mockStorage.saveBatch.mockResolvedValue([]);
97
+ // Add 100 entries to trigger flush
98
+ for (let i = 0; i < 100; i++) {
99
+ await service.collect('request', createMockRequestPayload({
100
+ path: `/api/test/${i}`,
101
+ url: `/api/test/${i}`,
102
+ }));
103
+ }
104
+ expect(mockStorage.saveBatch).toHaveBeenCalled();
105
+ });
106
+ });
107
+ describe('collectImmediate', () => {
108
+ it('should save entry immediately', async () => {
109
+ const savedEntry = createMockEntry();
110
+ mockStorage.save.mockResolvedValue(savedEntry);
111
+ mockFamilyHashService.generateFamilyHash.mockReturnValue('test-hash');
112
+ const result = await service.collectImmediate('request', createMockRequestPayload());
113
+ expect(mockStorage.save).toHaveBeenCalled();
114
+ expect(result).toEqual(savedEntry);
115
+ });
116
+ it('should apply auto-tagging after save', async () => {
117
+ const savedEntry = createMockEntry();
118
+ mockStorage.save.mockResolvedValue(savedEntry);
119
+ mockFamilyHashService.generateFamilyHash.mockReturnValue('test-hash');
120
+ await service.collectImmediate('request', createMockRequestPayload());
121
+ expect(mockFamilyHashService.generateFamilyHash).toHaveBeenCalledWith(savedEntry);
122
+ expect(mockStorage.updateFamilyHash).toHaveBeenCalledWith(savedEntry.id, 'test-hash');
123
+ expect(mockTagService.autoTag).toHaveBeenCalledWith(savedEntry);
124
+ });
125
+ it('should throw error if save fails', async () => {
126
+ mockStorage.save.mockRejectedValue(new Error('Save failed'));
127
+ await expect(service.collectImmediate('request', createMockRequestPayload())).rejects.toThrow('Save failed');
128
+ });
129
+ });
130
+ describe('flush', () => {
131
+ it('should save all buffered entries', async () => {
132
+ const savedEntries = [createMockEntry({ id: 1 }), createMockEntry({ id: 2 })];
133
+ mockStorage.saveBatch.mockResolvedValue(savedEntries);
134
+ await service.collect('request', createMockRequestPayload({ path: '/api/test1', url: '/api/test1' }));
135
+ await service.collect('request', createMockRequestPayload({
136
+ method: 'POST',
137
+ path: '/api/test2',
138
+ url: '/api/test2',
139
+ statusCode: 201,
140
+ duration: 150,
141
+ }));
142
+ await service.flush();
143
+ expect(mockStorage.saveBatch).toHaveBeenCalled();
144
+ const savedBatch = mockStorage.saveBatch.mock.calls[0][0];
145
+ expect(savedBatch).toHaveLength(2);
146
+ });
147
+ it('should not call storage if buffer is empty', async () => {
148
+ await service.flush();
149
+ expect(mockStorage.saveBatch).not.toHaveBeenCalled();
150
+ });
151
+ it('should restore buffer on save failure', async () => {
152
+ mockStorage.saveBatch.mockRejectedValue(new Error('Batch save failed'));
153
+ await service.collect('request', createMockRequestPayload());
154
+ await service.flush();
155
+ // Try flush again - buffer should still have the entry
156
+ mockStorage.saveBatch.mockResolvedValue([createMockEntry()]);
157
+ await service.flush();
158
+ // First flush: 3 attempts (retry logic with maxRetries=3)
159
+ // Second flush: 1 successful attempt
160
+ // Total: 4 calls
161
+ expect(mockStorage.saveBatch).toHaveBeenCalledTimes(4);
162
+ });
163
+ });
164
+ describe('shutdown', () => {
165
+ it('should flush remaining entries on shutdown', async () => {
166
+ mockStorage.saveBatch.mockResolvedValue([createMockEntry()]);
167
+ await service.collect('request', createMockRequestPayload());
168
+ await service.shutdown();
169
+ expect(mockStorage.saveBatch).toHaveBeenCalled();
170
+ });
171
+ });
172
+ describe('entry types', () => {
173
+ it('should handle exception entries', async () => {
174
+ const savedEntry = {
175
+ id: 1,
176
+ type: 'exception',
177
+ payload: {
178
+ name: 'Error',
179
+ message: 'Test error',
180
+ stack: 'Error: Test error\n at test.ts:1:1',
181
+ },
182
+ requestId: 'test-request-id',
183
+ createdAt: new Date().toISOString(),
184
+ };
185
+ mockStorage.save.mockResolvedValue(savedEntry);
186
+ const result = await service.collectImmediate('exception', {
187
+ name: 'Error',
188
+ message: 'Test error',
189
+ stack: 'Error: Test error\n at test.ts:1:1',
190
+ });
191
+ expect(result).not.toBeNull();
192
+ expect(result.type).toBe('exception');
193
+ });
194
+ it('should handle log entries', async () => {
195
+ const savedEntry = {
196
+ id: 1,
197
+ type: 'log',
198
+ payload: {
199
+ level: 'error',
200
+ message: 'Test log message',
201
+ context: 'TestContext',
202
+ },
203
+ requestId: 'test-request-id',
204
+ createdAt: new Date().toISOString(),
205
+ };
206
+ mockStorage.save.mockResolvedValue(savedEntry);
207
+ const result = await service.collectImmediate('log', {
208
+ level: 'error',
209
+ message: 'Test log message',
210
+ context: 'TestContext',
211
+ });
212
+ expect(result).not.toBeNull();
213
+ expect(result.type).toBe('log');
214
+ });
215
+ it('should handle query entries', async () => {
216
+ const savedEntry = {
217
+ id: 1,
218
+ type: 'query',
219
+ payload: {
220
+ query: 'SELECT * FROM users',
221
+ duration: 50,
222
+ slow: false,
223
+ source: 'typeorm',
224
+ },
225
+ requestId: 'test-request-id',
226
+ createdAt: new Date().toISOString(),
227
+ };
228
+ mockStorage.save.mockResolvedValue(savedEntry);
229
+ const result = await service.collectImmediate('query', {
230
+ query: 'SELECT * FROM users',
231
+ duration: 50,
232
+ slow: false,
233
+ source: 'typeorm',
234
+ });
235
+ expect(result).not.toBeNull();
236
+ expect(result.type).toBe('query');
237
+ });
238
+ });
239
+ });
240
+ //# sourceMappingURL=collector.service.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collector.service.spec.js","sourceRoot":"","sources":["../../src/__tests__/collector.service.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=collector.service.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"collector.service.spec.d.ts","sourceRoot":"","sources":["../../../src/__tests__/core/collector.service.spec.ts"],"names":[],"mappings":""}