@makebelieve21213-packages/nest-common 1.0.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 (391) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +1905 -0
  3. package/dist/__tests__/index.spec.d.ts +2 -0
  4. package/dist/__tests__/index.spec.d.ts.map +1 -0
  5. package/dist/__tests__/index.spec.js +36 -0
  6. package/dist/__tests__/index.spec.js.map +1 -0
  7. package/dist/__tests__/mocks/logger-service.mock.d.ts +7 -0
  8. package/dist/__tests__/mocks/logger-service.mock.d.ts.map +1 -0
  9. package/dist/__tests__/mocks/logger-service.mock.js +16 -0
  10. package/dist/__tests__/mocks/logger-service.mock.js.map +1 -0
  11. package/dist/__tests__/setup.d.ts +2 -0
  12. package/dist/__tests__/setup.d.ts.map +1 -0
  13. package/dist/__tests__/setup.js +3 -0
  14. package/dist/__tests__/setup.js.map +1 -0
  15. package/dist/base/__tests__/base.controller.spec.d.ts +2 -0
  16. package/dist/base/__tests__/base.controller.spec.d.ts.map +1 -0
  17. package/dist/base/__tests__/base.controller.spec.js +50 -0
  18. package/dist/base/__tests__/base.controller.spec.js.map +1 -0
  19. package/dist/base/base.controller.d.ts +8 -0
  20. package/dist/base/base.controller.d.ts.map +1 -0
  21. package/dist/base/base.controller.js +15 -0
  22. package/dist/base/base.controller.js.map +1 -0
  23. package/dist/decorators/__tests__/api-key.decorator.spec.d.ts +2 -0
  24. package/dist/decorators/__tests__/api-key.decorator.spec.d.ts.map +1 -0
  25. package/dist/decorators/__tests__/api-key.decorator.spec.js +25 -0
  26. package/dist/decorators/__tests__/api-key.decorator.spec.js.map +1 -0
  27. package/dist/decorators/__tests__/permissions.decorator.spec.d.ts +2 -0
  28. package/dist/decorators/__tests__/permissions.decorator.spec.d.ts.map +1 -0
  29. package/dist/decorators/__tests__/permissions.decorator.spec.js +29 -0
  30. package/dist/decorators/__tests__/permissions.decorator.spec.js.map +1 -0
  31. package/dist/decorators/__tests__/public.decorator.spec.d.ts +2 -0
  32. package/dist/decorators/__tests__/public.decorator.spec.d.ts.map +1 -0
  33. package/dist/decorators/__tests__/public.decorator.spec.js +25 -0
  34. package/dist/decorators/__tests__/public.decorator.spec.js.map +1 -0
  35. package/dist/decorators/__tests__/roles.decorator.spec.d.ts +2 -0
  36. package/dist/decorators/__tests__/roles.decorator.spec.d.ts.map +1 -0
  37. package/dist/decorators/__tests__/roles.decorator.spec.js +29 -0
  38. package/dist/decorators/__tests__/roles.decorator.spec.js.map +1 -0
  39. package/dist/decorators/__tests__/serialize.decorator.spec.d.ts +2 -0
  40. package/dist/decorators/__tests__/serialize.decorator.spec.d.ts.map +1 -0
  41. package/dist/decorators/__tests__/serialize.decorator.spec.js +28 -0
  42. package/dist/decorators/__tests__/serialize.decorator.spec.js.map +1 -0
  43. package/dist/decorators/api-key.decorator.d.ts +3 -0
  44. package/dist/decorators/api-key.decorator.d.ts.map +1 -0
  45. package/dist/decorators/api-key.decorator.js +6 -0
  46. package/dist/decorators/api-key.decorator.js.map +1 -0
  47. package/dist/decorators/permissions.decorator.d.ts +3 -0
  48. package/dist/decorators/permissions.decorator.d.ts.map +1 -0
  49. package/dist/decorators/permissions.decorator.js +6 -0
  50. package/dist/decorators/permissions.decorator.js.map +1 -0
  51. package/dist/decorators/public.decorator.d.ts +3 -0
  52. package/dist/decorators/public.decorator.d.ts.map +1 -0
  53. package/dist/decorators/public.decorator.js +6 -0
  54. package/dist/decorators/public.decorator.js.map +1 -0
  55. package/dist/decorators/roles.decorator.d.ts +3 -0
  56. package/dist/decorators/roles.decorator.d.ts.map +1 -0
  57. package/dist/decorators/roles.decorator.js +6 -0
  58. package/dist/decorators/roles.decorator.js.map +1 -0
  59. package/dist/decorators/serialize.decorator.d.ts +3 -0
  60. package/dist/decorators/serialize.decorator.d.ts.map +1 -0
  61. package/dist/decorators/serialize.decorator.js +6 -0
  62. package/dist/decorators/serialize.decorator.js.map +1 -0
  63. package/dist/errors/__tests__/http.error.spec.d.ts +2 -0
  64. package/dist/errors/__tests__/http.error.spec.d.ts.map +1 -0
  65. package/dist/errors/__tests__/http.error.spec.js +667 -0
  66. package/dist/errors/__tests__/http.error.spec.js.map +1 -0
  67. package/dist/errors/__tests__/rpc.error.spec.d.ts +2 -0
  68. package/dist/errors/__tests__/rpc.error.spec.d.ts.map +1 -0
  69. package/dist/errors/__tests__/rpc.error.spec.js +336 -0
  70. package/dist/errors/__tests__/rpc.error.spec.js.map +1 -0
  71. package/dist/errors/__tests__/socket.error.spec.d.ts +2 -0
  72. package/dist/errors/__tests__/socket.error.spec.d.ts.map +1 -0
  73. package/dist/errors/__tests__/socket.error.spec.js +105 -0
  74. package/dist/errors/__tests__/socket.error.spec.js.map +1 -0
  75. package/dist/errors/http.error.d.ts +17 -0
  76. package/dist/errors/http.error.d.ts.map +1 -0
  77. package/dist/errors/http.error.js +170 -0
  78. package/dist/errors/http.error.js.map +1 -0
  79. package/dist/errors/nest-common.error.d.ts +7 -0
  80. package/dist/errors/nest-common.error.d.ts.map +1 -0
  81. package/dist/errors/nest-common.error.js +18 -0
  82. package/dist/errors/nest-common.error.js.map +1 -0
  83. package/dist/errors/rpc.error.d.ts +27 -0
  84. package/dist/errors/rpc.error.d.ts.map +1 -0
  85. package/dist/errors/rpc.error.js +170 -0
  86. package/dist/errors/rpc.error.js.map +1 -0
  87. package/dist/errors/socket.error.d.ts +20 -0
  88. package/dist/errors/socket.error.d.ts.map +1 -0
  89. package/dist/errors/socket.error.js +47 -0
  90. package/dist/errors/socket.error.js.map +1 -0
  91. package/dist/filters/__tests__/http-exception-handler.spec.d.ts +2 -0
  92. package/dist/filters/__tests__/http-exception-handler.spec.d.ts.map +1 -0
  93. package/dist/filters/__tests__/http-exception-handler.spec.js +86 -0
  94. package/dist/filters/__tests__/http-exception-handler.spec.js.map +1 -0
  95. package/dist/filters/__tests__/rpc-exception-handler.spec.d.ts +2 -0
  96. package/dist/filters/__tests__/rpc-exception-handler.spec.d.ts.map +1 -0
  97. package/dist/filters/__tests__/rpc-exception-handler.spec.js +220 -0
  98. package/dist/filters/__tests__/rpc-exception-handler.spec.js.map +1 -0
  99. package/dist/filters/__tests__/unified-exception.filter.spec.d.ts +2 -0
  100. package/dist/filters/__tests__/unified-exception.filter.spec.d.ts.map +1 -0
  101. package/dist/filters/__tests__/unified-exception.filter.spec.js +233 -0
  102. package/dist/filters/__tests__/unified-exception.filter.spec.js.map +1 -0
  103. package/dist/filters/__tests__/websocket-exception-handler.spec.d.ts +2 -0
  104. package/dist/filters/__tests__/websocket-exception-handler.spec.d.ts.map +1 -0
  105. package/dist/filters/__tests__/websocket-exception-handler.spec.js +78 -0
  106. package/dist/filters/__tests__/websocket-exception-handler.spec.js.map +1 -0
  107. package/dist/filters/http-exception-handler.d.ts +8 -0
  108. package/dist/filters/http-exception-handler.d.ts.map +1 -0
  109. package/dist/filters/http-exception-handler.js +37 -0
  110. package/dist/filters/http-exception-handler.js.map +1 -0
  111. package/dist/filters/rpc-exception-handler.d.ts +11 -0
  112. package/dist/filters/rpc-exception-handler.d.ts.map +1 -0
  113. package/dist/filters/rpc-exception-handler.js +87 -0
  114. package/dist/filters/rpc-exception-handler.js.map +1 -0
  115. package/dist/filters/unified-exception.filter.d.ts +12 -0
  116. package/dist/filters/unified-exception.filter.d.ts.map +1 -0
  117. package/dist/filters/unified-exception.filter.js +63 -0
  118. package/dist/filters/unified-exception.filter.js.map +1 -0
  119. package/dist/filters/websocket-exception-handler.d.ts +8 -0
  120. package/dist/filters/websocket-exception-handler.d.ts.map +1 -0
  121. package/dist/filters/websocket-exception-handler.js +47 -0
  122. package/dist/filters/websocket-exception-handler.js.map +1 -0
  123. package/dist/guards/__tests__/api-key.guard.spec.d.ts +2 -0
  124. package/dist/guards/__tests__/api-key.guard.spec.d.ts.map +1 -0
  125. package/dist/guards/__tests__/api-key.guard.spec.js +123 -0
  126. package/dist/guards/__tests__/api-key.guard.spec.js.map +1 -0
  127. package/dist/guards/__tests__/jwt-auth.guard.spec.d.ts +2 -0
  128. package/dist/guards/__tests__/jwt-auth.guard.spec.d.ts.map +1 -0
  129. package/dist/guards/__tests__/jwt-auth.guard.spec.js +61 -0
  130. package/dist/guards/__tests__/jwt-auth.guard.spec.js.map +1 -0
  131. package/dist/guards/__tests__/permissions.guard.spec.d.ts +2 -0
  132. package/dist/guards/__tests__/permissions.guard.spec.d.ts.map +1 -0
  133. package/dist/guards/__tests__/permissions.guard.spec.js +77 -0
  134. package/dist/guards/__tests__/permissions.guard.spec.js.map +1 -0
  135. package/dist/guards/__tests__/rate-limit.guard.spec.d.ts +2 -0
  136. package/dist/guards/__tests__/rate-limit.guard.spec.d.ts.map +1 -0
  137. package/dist/guards/__tests__/rate-limit.guard.spec.js +117 -0
  138. package/dist/guards/__tests__/rate-limit.guard.spec.js.map +1 -0
  139. package/dist/guards/__tests__/roles.guard.spec.d.ts +2 -0
  140. package/dist/guards/__tests__/roles.guard.spec.d.ts.map +1 -0
  141. package/dist/guards/__tests__/roles.guard.spec.js +83 -0
  142. package/dist/guards/__tests__/roles.guard.spec.js.map +1 -0
  143. package/dist/guards/__tests__/websocket-auth.guard.spec.d.ts +2 -0
  144. package/dist/guards/__tests__/websocket-auth.guard.spec.d.ts.map +1 -0
  145. package/dist/guards/__tests__/websocket-auth.guard.spec.js +72 -0
  146. package/dist/guards/__tests__/websocket-auth.guard.spec.js.map +1 -0
  147. package/dist/guards/api-key.guard.d.ts +10 -0
  148. package/dist/guards/api-key.guard.d.ts.map +1 -0
  149. package/dist/guards/api-key.guard.js +58 -0
  150. package/dist/guards/api-key.guard.js.map +1 -0
  151. package/dist/guards/jwt-auth.guard.d.ts +8 -0
  152. package/dist/guards/jwt-auth.guard.d.ts.map +1 -0
  153. package/dist/guards/jwt-auth.guard.js +41 -0
  154. package/dist/guards/jwt-auth.guard.js.map +1 -0
  155. package/dist/guards/permissions.guard.d.ts +8 -0
  156. package/dist/guards/permissions.guard.d.ts.map +1 -0
  157. package/dist/guards/permissions.guard.js +48 -0
  158. package/dist/guards/permissions.guard.js.map +1 -0
  159. package/dist/guards/rate-limit.guard.d.ts +16 -0
  160. package/dist/guards/rate-limit.guard.d.ts.map +1 -0
  161. package/dist/guards/rate-limit.guard.js +89 -0
  162. package/dist/guards/rate-limit.guard.js.map +1 -0
  163. package/dist/guards/roles.guard.d.ts +8 -0
  164. package/dist/guards/roles.guard.d.ts.map +1 -0
  165. package/dist/guards/roles.guard.js +48 -0
  166. package/dist/guards/roles.guard.js.map +1 -0
  167. package/dist/guards/websocket-auth.guard.d.ts +8 -0
  168. package/dist/guards/websocket-auth.guard.d.ts.map +1 -0
  169. package/dist/guards/websocket-auth.guard.js +41 -0
  170. package/dist/guards/websocket-auth.guard.js.map +1 -0
  171. package/dist/index.d.ts +46 -0
  172. package/dist/index.d.ts.map +1 -0
  173. package/dist/index.js +38 -0
  174. package/dist/index.js.map +1 -0
  175. package/dist/interceptors/__tests__/compression.interceptor.spec.d.ts +2 -0
  176. package/dist/interceptors/__tests__/compression.interceptor.spec.d.ts.map +1 -0
  177. package/dist/interceptors/__tests__/compression.interceptor.spec.js +93 -0
  178. package/dist/interceptors/__tests__/compression.interceptor.spec.js.map +1 -0
  179. package/dist/interceptors/__tests__/http-logging.interceptor.spec.d.ts +2 -0
  180. package/dist/interceptors/__tests__/http-logging.interceptor.spec.d.ts.map +1 -0
  181. package/dist/interceptors/__tests__/http-logging.interceptor.spec.js +135 -0
  182. package/dist/interceptors/__tests__/http-logging.interceptor.spec.js.map +1 -0
  183. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.d.ts +2 -0
  184. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.d.ts.map +1 -0
  185. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.js +39 -0
  186. package/dist/interceptors/__tests__/request-id-response.interceptor.spec.js.map +1 -0
  187. package/dist/interceptors/__tests__/response.interceptor.spec.d.ts +2 -0
  188. package/dist/interceptors/__tests__/response.interceptor.spec.d.ts.map +1 -0
  189. package/dist/interceptors/__tests__/response.interceptor.spec.js +95 -0
  190. package/dist/interceptors/__tests__/response.interceptor.spec.js.map +1 -0
  191. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.d.ts +2 -0
  192. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.d.ts.map +1 -0
  193. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.js +113 -0
  194. package/dist/interceptors/__tests__/rpc-logging.interceptor.spec.js.map +1 -0
  195. package/dist/interceptors/__tests__/serialize.interceptor.spec.d.ts +2 -0
  196. package/dist/interceptors/__tests__/serialize.interceptor.spec.d.ts.map +1 -0
  197. package/dist/interceptors/__tests__/serialize.interceptor.spec.js +114 -0
  198. package/dist/interceptors/__tests__/serialize.interceptor.spec.js.map +1 -0
  199. package/dist/interceptors/__tests__/unified.interceptor.spec.d.ts +2 -0
  200. package/dist/interceptors/__tests__/unified.interceptor.spec.d.ts.map +1 -0
  201. package/dist/interceptors/__tests__/unified.interceptor.spec.js +256 -0
  202. package/dist/interceptors/__tests__/unified.interceptor.spec.js.map +1 -0
  203. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.d.ts +2 -0
  204. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.d.ts.map +1 -0
  205. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.js +119 -0
  206. package/dist/interceptors/__tests__/websocket-logging.interceptor.spec.js.map +1 -0
  207. package/dist/interceptors/compression.interceptor.d.ts +10 -0
  208. package/dist/interceptors/compression.interceptor.d.ts.map +1 -0
  209. package/dist/interceptors/compression.interceptor.js +53 -0
  210. package/dist/interceptors/compression.interceptor.js.map +1 -0
  211. package/dist/interceptors/http-logging.interceptor.d.ts +9 -0
  212. package/dist/interceptors/http-logging.interceptor.d.ts.map +1 -0
  213. package/dist/interceptors/http-logging.interceptor.js +41 -0
  214. package/dist/interceptors/http-logging.interceptor.js.map +1 -0
  215. package/dist/interceptors/request-id-response.interceptor.d.ts +6 -0
  216. package/dist/interceptors/request-id-response.interceptor.d.ts.map +1 -0
  217. package/dist/interceptors/request-id-response.interceptor.js +27 -0
  218. package/dist/interceptors/request-id-response.interceptor.js.map +1 -0
  219. package/dist/interceptors/response.interceptor.d.ts +8 -0
  220. package/dist/interceptors/response.interceptor.d.ts.map +1 -0
  221. package/dist/interceptors/response.interceptor.js +42 -0
  222. package/dist/interceptors/response.interceptor.js.map +1 -0
  223. package/dist/interceptors/rpc-logging.interceptor.d.ts +9 -0
  224. package/dist/interceptors/rpc-logging.interceptor.d.ts.map +1 -0
  225. package/dist/interceptors/rpc-logging.interceptor.js +31 -0
  226. package/dist/interceptors/rpc-logging.interceptor.js.map +1 -0
  227. package/dist/interceptors/serialize.interceptor.d.ts +9 -0
  228. package/dist/interceptors/serialize.interceptor.d.ts.map +1 -0
  229. package/dist/interceptors/serialize.interceptor.js +48 -0
  230. package/dist/interceptors/serialize.interceptor.js.map +1 -0
  231. package/dist/interceptors/unified.interceptor.d.ts +12 -0
  232. package/dist/interceptors/unified.interceptor.d.ts.map +1 -0
  233. package/dist/interceptors/unified.interceptor.js +54 -0
  234. package/dist/interceptors/unified.interceptor.js.map +1 -0
  235. package/dist/interceptors/websocket-logging.interceptor.d.ts +9 -0
  236. package/dist/interceptors/websocket-logging.interceptor.d.ts.map +1 -0
  237. package/dist/interceptors/websocket-logging.interceptor.js +36 -0
  238. package/dist/interceptors/websocket-logging.interceptor.js.map +1 -0
  239. package/dist/pipes/__tests__/file-validation.pipe.spec.d.ts +2 -0
  240. package/dist/pipes/__tests__/file-validation.pipe.spec.d.ts.map +1 -0
  241. package/dist/pipes/__tests__/file-validation.pipe.spec.js +60 -0
  242. package/dist/pipes/__tests__/file-validation.pipe.spec.js.map +1 -0
  243. package/dist/pipes/__tests__/header-validation.pipe.spec.d.ts +2 -0
  244. package/dist/pipes/__tests__/header-validation.pipe.spec.d.ts.map +1 -0
  245. package/dist/pipes/__tests__/header-validation.pipe.spec.js +111 -0
  246. package/dist/pipes/__tests__/header-validation.pipe.spec.js.map +1 -0
  247. package/dist/pipes/__tests__/http-validation.pipe.spec.d.ts +2 -0
  248. package/dist/pipes/__tests__/http-validation.pipe.spec.d.ts.map +1 -0
  249. package/dist/pipes/__tests__/http-validation.pipe.spec.js +114 -0
  250. package/dist/pipes/__tests__/http-validation.pipe.spec.js.map +1 -0
  251. package/dist/pipes/__tests__/query-validation.pipe.spec.d.ts +2 -0
  252. package/dist/pipes/__tests__/query-validation.pipe.spec.d.ts.map +1 -0
  253. package/dist/pipes/__tests__/query-validation.pipe.spec.js +103 -0
  254. package/dist/pipes/__tests__/query-validation.pipe.spec.js.map +1 -0
  255. package/dist/pipes/__tests__/rpc-validation.pipe.spec.d.ts +2 -0
  256. package/dist/pipes/__tests__/rpc-validation.pipe.spec.d.ts.map +1 -0
  257. package/dist/pipes/__tests__/rpc-validation.pipe.spec.js +126 -0
  258. package/dist/pipes/__tests__/rpc-validation.pipe.spec.js.map +1 -0
  259. package/dist/pipes/file-validation.pipe.d.ts +10 -0
  260. package/dist/pipes/file-validation.pipe.d.ts.map +1 -0
  261. package/dist/pipes/file-validation.pipe.js +41 -0
  262. package/dist/pipes/file-validation.pipe.js.map +1 -0
  263. package/dist/pipes/header-validation.pipe.d.ts +8 -0
  264. package/dist/pipes/header-validation.pipe.d.ts.map +1 -0
  265. package/dist/pipes/header-validation.pipe.js +58 -0
  266. package/dist/pipes/header-validation.pipe.js.map +1 -0
  267. package/dist/pipes/http-validation.pipe.d.ts +8 -0
  268. package/dist/pipes/http-validation.pipe.d.ts.map +1 -0
  269. package/dist/pipes/http-validation.pipe.js +41 -0
  270. package/dist/pipes/http-validation.pipe.js.map +1 -0
  271. package/dist/pipes/query-validation.pipe.d.ts +8 -0
  272. package/dist/pipes/query-validation.pipe.d.ts.map +1 -0
  273. package/dist/pipes/query-validation.pipe.js +58 -0
  274. package/dist/pipes/query-validation.pipe.js.map +1 -0
  275. package/dist/pipes/rpc-validation.pipe.d.ts +8 -0
  276. package/dist/pipes/rpc-validation.pipe.d.ts.map +1 -0
  277. package/dist/pipes/rpc-validation.pipe.js +49 -0
  278. package/dist/pipes/rpc-validation.pipe.js.map +1 -0
  279. package/dist/types/circuit-breaker-types.d.ts +19 -0
  280. package/dist/types/circuit-breaker-types.d.ts.map +1 -0
  281. package/dist/types/circuit-breaker-types.js +8 -0
  282. package/dist/types/circuit-breaker-types.js.map +1 -0
  283. package/dist/types/compression-types.d.ts +22 -0
  284. package/dist/types/compression-types.d.ts.map +1 -0
  285. package/dist/types/compression-types.js +2 -0
  286. package/dist/types/compression-types.js.map +1 -0
  287. package/dist/types/context-types.d.ts +18 -0
  288. package/dist/types/context-types.d.ts.map +1 -0
  289. package/dist/types/context-types.js +8 -0
  290. package/dist/types/context-types.js.map +1 -0
  291. package/dist/types/cors-types.d.ts +11 -0
  292. package/dist/types/cors-types.d.ts.map +1 -0
  293. package/dist/types/cors-types.js +2 -0
  294. package/dist/types/cors-types.js.map +1 -0
  295. package/dist/types/error-types.d.ts +13 -0
  296. package/dist/types/error-types.d.ts.map +1 -0
  297. package/dist/types/error-types.js +15 -0
  298. package/dist/types/error-types.js.map +1 -0
  299. package/dist/types/file-types.d.ts +13 -0
  300. package/dist/types/file-types.d.ts.map +1 -0
  301. package/dist/types/file-types.js +2 -0
  302. package/dist/types/file-types.js.map +1 -0
  303. package/dist/types/file-validation-types.d.ts +10 -0
  304. package/dist/types/file-validation-types.d.ts.map +1 -0
  305. package/dist/types/file-validation-types.js +2 -0
  306. package/dist/types/file-validation-types.js.map +1 -0
  307. package/dist/types/get-service-path-types.d.ts +16 -0
  308. package/dist/types/get-service-path-types.d.ts.map +1 -0
  309. package/dist/types/get-service-path-types.js +2 -0
  310. package/dist/types/get-service-path-types.js.map +1 -0
  311. package/dist/types/guard-types.d.ts +5 -0
  312. package/dist/types/guard-types.d.ts.map +1 -0
  313. package/dist/types/guard-types.js +2 -0
  314. package/dist/types/guard-types.js.map +1 -0
  315. package/dist/types/http-response.d.ts +19 -0
  316. package/dist/types/http-response.d.ts.map +1 -0
  317. package/dist/types/http-response.js +2 -0
  318. package/dist/types/http-response.js.map +1 -0
  319. package/dist/types/rpc-types.d.ts +21 -0
  320. package/dist/types/rpc-types.d.ts.map +1 -0
  321. package/dist/types/rpc-types.js +17 -0
  322. package/dist/types/rpc-types.js.map +1 -0
  323. package/dist/types/versioning-types.d.ts +8 -0
  324. package/dist/types/versioning-types.d.ts.map +1 -0
  325. package/dist/types/versioning-types.js +2 -0
  326. package/dist/types/versioning-types.js.map +1 -0
  327. package/dist/utils/__tests__/circuit-breaker.spec.d.ts +2 -0
  328. package/dist/utils/__tests__/circuit-breaker.spec.d.ts.map +1 -0
  329. package/dist/utils/__tests__/circuit-breaker.spec.js +206 -0
  330. package/dist/utils/__tests__/circuit-breaker.spec.js.map +1 -0
  331. package/dist/utils/__tests__/compression.utils.spec.d.ts +2 -0
  332. package/dist/utils/__tests__/compression.utils.spec.d.ts.map +1 -0
  333. package/dist/utils/__tests__/compression.utils.spec.js +106 -0
  334. package/dist/utils/__tests__/compression.utils.spec.js.map +1 -0
  335. package/dist/utils/__tests__/context.utils.spec.d.ts +2 -0
  336. package/dist/utils/__tests__/context.utils.spec.d.ts.map +1 -0
  337. package/dist/utils/__tests__/context.utils.spec.js +112 -0
  338. package/dist/utils/__tests__/context.utils.spec.js.map +1 -0
  339. package/dist/utils/__tests__/cors.utils.spec.d.ts +2 -0
  340. package/dist/utils/__tests__/cors.utils.spec.d.ts.map +1 -0
  341. package/dist/utils/__tests__/cors.utils.spec.js +54 -0
  342. package/dist/utils/__tests__/cors.utils.spec.js.map +1 -0
  343. package/dist/utils/__tests__/env-validator.spec.d.ts +2 -0
  344. package/dist/utils/__tests__/env-validator.spec.d.ts.map +1 -0
  345. package/dist/utils/__tests__/env-validator.spec.js +88 -0
  346. package/dist/utils/__tests__/env-validator.spec.js.map +1 -0
  347. package/dist/utils/__tests__/file.utils.spec.d.ts +2 -0
  348. package/dist/utils/__tests__/file.utils.spec.d.ts.map +1 -0
  349. package/dist/utils/__tests__/file.utils.spec.js +95 -0
  350. package/dist/utils/__tests__/file.utils.spec.js.map +1 -0
  351. package/dist/utils/__tests__/get-service-path.spec.d.ts +2 -0
  352. package/dist/utils/__tests__/get-service-path.spec.d.ts.map +1 -0
  353. package/dist/utils/__tests__/get-service-path.spec.js +385 -0
  354. package/dist/utils/__tests__/get-service-path.spec.js.map +1 -0
  355. package/dist/utils/__tests__/versioning.utils.spec.d.ts +2 -0
  356. package/dist/utils/__tests__/versioning.utils.spec.d.ts.map +1 -0
  357. package/dist/utils/__tests__/versioning.utils.spec.js +66 -0
  358. package/dist/utils/__tests__/versioning.utils.spec.js.map +1 -0
  359. package/dist/utils/circuit-breaker.d.ts +15 -0
  360. package/dist/utils/circuit-breaker.d.ts.map +1 -0
  361. package/dist/utils/circuit-breaker.js +96 -0
  362. package/dist/utils/circuit-breaker.js.map +1 -0
  363. package/dist/utils/compression.utils.d.ts +3 -0
  364. package/dist/utils/compression.utils.d.ts.map +1 -0
  365. package/dist/utils/compression.utils.js +25 -0
  366. package/dist/utils/compression.utils.js.map +1 -0
  367. package/dist/utils/context.utils.d.ts +7 -0
  368. package/dist/utils/context.utils.d.ts.map +1 -0
  369. package/dist/utils/context.utils.js +24 -0
  370. package/dist/utils/context.utils.js.map +1 -0
  371. package/dist/utils/cors.utils.d.ts +4 -0
  372. package/dist/utils/cors.utils.d.ts.map +1 -0
  373. package/dist/utils/cors.utils.js +23 -0
  374. package/dist/utils/cors.utils.js.map +1 -0
  375. package/dist/utils/env-validator.d.ts +2 -0
  376. package/dist/utils/env-validator.d.ts.map +1 -0
  377. package/dist/utils/env-validator.js +22 -0
  378. package/dist/utils/env-validator.js.map +1 -0
  379. package/dist/utils/file.utils.d.ts +6 -0
  380. package/dist/utils/file.utils.d.ts.map +1 -0
  381. package/dist/utils/file.utils.js +42 -0
  382. package/dist/utils/file.utils.js.map +1 -0
  383. package/dist/utils/get-service-path.d.ts +9 -0
  384. package/dist/utils/get-service-path.d.ts.map +1 -0
  385. package/dist/utils/get-service-path.js +65 -0
  386. package/dist/utils/get-service-path.js.map +1 -0
  387. package/dist/utils/versioning.utils.d.ts +4 -0
  388. package/dist/utils/versioning.utils.d.ts.map +1 -0
  389. package/dist/utils/versioning.utils.js +30 -0
  390. package/dist/utils/versioning.utils.js.map +1 -0
  391. package/package.json +95 -0
@@ -0,0 +1,220 @@
1
+ import { createLoggerServiceMock } from "../../__tests__/mocks/logger-service.mock.js";
2
+ import RpcError from "../../errors/rpc.error.js";
3
+ import RpcExceptionFilter from "../../filters/rpc-exception-handler.js";
4
+ import { ContextType } from "../../types/context-types.js";
5
+ describe("RpcExceptionFilter", () => {
6
+ let handler;
7
+ let mockLoggerService;
8
+ let mockArgumentsHost;
9
+ let mockRmqContext;
10
+ let mockChannel;
11
+ let mockMessage;
12
+ beforeEach(() => {
13
+ mockLoggerService = createLoggerServiceMock();
14
+ mockChannel = {
15
+ nack: jest.fn(),
16
+ publish: jest.fn(),
17
+ ack: jest.fn(),
18
+ };
19
+ mockMessage = {
20
+ properties: {
21
+ headers: {},
22
+ },
23
+ fields: {
24
+ routingKey: "test.routing.key",
25
+ },
26
+ content: Buffer.from("test content"),
27
+ };
28
+ mockRmqContext = {
29
+ getChannelRef: jest.fn().mockReturnValue(mockChannel),
30
+ getMessage: jest.fn().mockReturnValue(mockMessage),
31
+ getPattern: jest.fn().mockReturnValue("test.pattern"),
32
+ };
33
+ mockArgumentsHost = {
34
+ getType: jest.fn().mockReturnValue(ContextType.RPC),
35
+ switchToRpc: jest.fn().mockReturnValue({
36
+ getContext: jest.fn().mockReturnValue(mockRmqContext),
37
+ }),
38
+ };
39
+ handler = new RpcExceptionFilter(mockLoggerService);
40
+ });
41
+ describe("конструктор", () => {
42
+ it("должен установить контекст логгера", () => {
43
+ const exception = new Error("Test error");
44
+ handler.handleException(exception, mockArgumentsHost);
45
+ expect(mockLoggerService.setContext).toHaveBeenCalledWith("RpcExceptionFilter");
46
+ });
47
+ it("должен использовать дефолтный dlxExchange если не передан", () => {
48
+ const newHandler = new RpcExceptionFilter(mockLoggerService);
49
+ expect(newHandler).toBeInstanceOf(RpcExceptionFilter);
50
+ });
51
+ it("должен использовать кастомный dlxExchange если передан", () => {
52
+ const customDlxExchange = "custom.dlx.exchange";
53
+ const newHandler = new RpcExceptionFilter(mockLoggerService, customDlxExchange);
54
+ expect(newHandler).toBeInstanceOf(RpcExceptionFilter);
55
+ });
56
+ it("должен использовать дефолтный dlxExchange если передан undefined", () => {
57
+ const newHandler = new RpcExceptionFilter(mockLoggerService, undefined);
58
+ expect(newHandler).toBeInstanceOf(RpcExceptionFilter);
59
+ // Проверяем, что используется дефолтный dlxExchange
60
+ const exception = new Error("Test error");
61
+ const rpcError = RpcError.fromUnknown(exception);
62
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
63
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
64
+ expect(() => {
65
+ newHandler.handleException(exception, mockArgumentsHost);
66
+ }).toThrow(rpcError);
67
+ expect(mockChannel.publish).toHaveBeenCalledWith("events_exchange.dlx", expect.any(String), expect.any(Buffer), expect.any(Object));
68
+ });
69
+ it("должен покрыть строку 16 - параметр loggerService конструктора", () => {
70
+ // Явно создаем экземпляр с моком логгера для покрытия параметра конструктора
71
+ const testLoggerService = createLoggerServiceMock();
72
+ const testHandler = new RpcExceptionFilter(testLoggerService);
73
+ expect(testHandler).toBeInstanceOf(RpcExceptionFilter);
74
+ // Вызываем метод, чтобы убедиться, что мок используется
75
+ const exception = new Error("Test error");
76
+ testHandler.handleException(exception, mockArgumentsHost);
77
+ expect(testLoggerService.setContext).toHaveBeenCalled();
78
+ });
79
+ it("должен покрыть строку 13 - параметр loggerService конструктора при создании без dlxExchange", () => {
80
+ // Покрываем строку 13 - параметр loggerService конструктора
81
+ const testLoggerService = createLoggerServiceMock();
82
+ const testHandler = new RpcExceptionFilter(testLoggerService);
83
+ expect(testHandler).toBeInstanceOf(RpcExceptionFilter);
84
+ // Проверяем, что дефолтный dlxExchange установлен
85
+ const exception = new Error("Test error");
86
+ const rpcError = RpcError.fromUnknown(exception);
87
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
88
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
89
+ expect(() => {
90
+ testHandler.handleException(exception, mockArgumentsHost);
91
+ }).toThrow(rpcError);
92
+ expect(mockChannel.publish).toHaveBeenCalledWith("events_exchange.dlx", expect.any(String), expect.any(Buffer), expect.any(Object));
93
+ });
94
+ });
95
+ describe("handleException", () => {
96
+ it("должен пробросить исключение если ctx отсутствует", () => {
97
+ mockArgumentsHost.switchToRpc.mockReturnValue({
98
+ getContext: jest.fn().mockReturnValue(undefined),
99
+ });
100
+ const exception = new Error("Test error");
101
+ expect(() => {
102
+ handler.handleException(exception, mockArgumentsHost);
103
+ }).toThrow("Test error");
104
+ });
105
+ it("должен отправить постоянную ошибку в DLX сразу", () => {
106
+ const exception = new Error("Bad request");
107
+ const rpcError = RpcError.fromUnknown(exception);
108
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
109
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
110
+ expect(() => {
111
+ handler.handleException(exception, mockArgumentsHost);
112
+ }).toThrow(rpcError);
113
+ expect(mockChannel.publish).toHaveBeenCalledWith("events_exchange.dlx", "test.routing.key", Buffer.from("test content"), {
114
+ headers: {},
115
+ });
116
+ expect(mockChannel.ack).toHaveBeenCalledWith(mockMessage);
117
+ });
118
+ it("должен requeue временную ошибку если retries < MAX_RETRIES", () => {
119
+ const exception = new Error("Timeout");
120
+ const rpcError = RpcError.fromUnknown(exception);
121
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
122
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(true);
123
+ mockMessage.properties.headers = {};
124
+ handler.handleException(exception, mockArgumentsHost);
125
+ expect(mockChannel.nack).toHaveBeenCalledWith(mockMessage, false, false);
126
+ });
127
+ it("должен отправить временную ошибку в DLX если retries >= MAX_RETRIES", () => {
128
+ const exception = new Error("Timeout");
129
+ const rpcError = RpcError.fromUnknown(exception);
130
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
131
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(true);
132
+ mockMessage.properties.headers = {
133
+ "x-death": [{ count: 2 }],
134
+ };
135
+ expect(() => {
136
+ handler.handleException(exception, mockArgumentsHost);
137
+ }).toThrow(rpcError);
138
+ expect(mockChannel.publish).toHaveBeenCalled();
139
+ expect(mockChannel.ack).toHaveBeenCalled();
140
+ });
141
+ it("должен использовать 'unknown' pattern если getPattern возвращает undefined", () => {
142
+ mockRmqContext.getPattern.mockReturnValue(undefined);
143
+ const exception = new Error("Test error");
144
+ const rpcError = RpcError.fromUnknown(exception);
145
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
146
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
147
+ expect(() => {
148
+ handler.handleException(exception, mockArgumentsHost);
149
+ }).toThrow(rpcError);
150
+ expect(mockLoggerService.error).toHaveBeenCalledWith(expect.stringContaining("[unknown]"));
151
+ });
152
+ it("должен логировать stack trace если exception имеет stack", () => {
153
+ const exception = new Error("Test error");
154
+ exception.stack = "Error: Test error\n at test.js:1:1";
155
+ const rpcError = RpcError.fromUnknown(exception);
156
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
157
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
158
+ expect(() => {
159
+ handler.handleException(exception, mockArgumentsHost);
160
+ }).toThrow(rpcError);
161
+ expect(mockLoggerService.error).toHaveBeenCalledWith(expect.stringContaining("Stack: Error: Test error"));
162
+ });
163
+ it("должен логировать пустой stack если exception является Error но stack отсутствует", () => {
164
+ const exception = new Error("Test error");
165
+ delete exception.stack;
166
+ const rpcError = RpcError.fromUnknown(exception);
167
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
168
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
169
+ expect(() => {
170
+ handler.handleException(exception, mockArgumentsHost);
171
+ }).toThrow(rpcError);
172
+ expect(mockLoggerService.error).toHaveBeenCalledWith(expect.stringContaining("Stack: "));
173
+ });
174
+ it("должен логировать пустой stack если exception не является Error", () => {
175
+ const exception = "String error";
176
+ const rpcError = RpcError.fromUnknown(exception);
177
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
178
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
179
+ expect(() => {
180
+ handler.handleException(exception, mockArgumentsHost);
181
+ }).toThrow(rpcError);
182
+ expect(mockLoggerService.error).toHaveBeenCalledWith(expect.stringContaining("Stack: "));
183
+ });
184
+ it("должен использовать pattern как fallback для routingKey если fields.routingKey отсутствует", () => {
185
+ delete mockMessage.fields?.routingKey;
186
+ const exception = new Error("Test error");
187
+ const rpcError = RpcError.fromUnknown(exception);
188
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
189
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
190
+ expect(() => {
191
+ handler.handleException(exception, mockArgumentsHost);
192
+ }).toThrow(rpcError);
193
+ expect(mockChannel.publish).toHaveBeenCalledWith("events_exchange.dlx", "test.pattern", expect.any(Buffer), expect.any(Object));
194
+ });
195
+ it("должен использовать пустой Buffer как fallback для content если content отсутствует", () => {
196
+ delete mockMessage.content;
197
+ const exception = new Error("Test error");
198
+ const rpcError = RpcError.fromUnknown(exception);
199
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
200
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
201
+ expect(() => {
202
+ handler.handleException(exception, mockArgumentsHost);
203
+ }).toThrow(rpcError);
204
+ expect(mockChannel.publish).toHaveBeenCalledWith("events_exchange.dlx", expect.any(String), Buffer.from(""), expect.any(Object));
205
+ });
206
+ it("должен использовать кастомный dlxExchange если передан в конструктор", () => {
207
+ const customDlxExchange = "custom.dlx.exchange";
208
+ const customHandler = new RpcExceptionFilter(mockLoggerService, customDlxExchange);
209
+ const exception = new Error("Test error");
210
+ const rpcError = RpcError.fromUnknown(exception);
211
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
212
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
213
+ expect(() => {
214
+ customHandler.handleException(exception, mockArgumentsHost);
215
+ }).toThrow(rpcError);
216
+ expect(mockChannel.publish).toHaveBeenCalledWith(customDlxExchange, expect.any(String), expect.any(Buffer), expect.any(Object));
217
+ });
218
+ });
219
+ });
220
+ //# sourceMappingURL=rpc-exception-handler.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rpc-exception-handler.spec.js","sourceRoot":"","sources":["../../../src/filters/__tests__/rpc-exception-handler.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=unified-exception.filter.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unified-exception.filter.spec.d.ts","sourceRoot":"","sources":["../../../src/filters/__tests__/unified-exception.filter.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,233 @@
1
+ import { HttpException, HttpStatus } from "@nestjs/common";
2
+ import { createLoggerServiceMock } from "../../__tests__/mocks/logger-service.mock.js";
3
+ import RpcError from "../../errors/rpc.error.js";
4
+ import HttpExceptionFilter from "../../filters/http-exception-handler.js";
5
+ import RpcExceptionFilter from "../../filters/rpc-exception-handler.js";
6
+ import UnifiedExceptionFilter from "../../filters/unified-exception.filter.js";
7
+ import { ContextType } from "../../types/context-types.js";
8
+ describe("UnifiedExceptionFilter", () => {
9
+ let filter;
10
+ let mockLoggerService;
11
+ let mockArgumentsHost;
12
+ let mockResponse;
13
+ let mockRequest;
14
+ let mockRmqContext;
15
+ let mockChannel;
16
+ let mockMessage;
17
+ beforeEach(() => {
18
+ mockLoggerService = createLoggerServiceMock();
19
+ mockResponse = {
20
+ status: jest.fn().mockReturnThis(),
21
+ json: jest.fn(),
22
+ };
23
+ mockRequest = { url: "/test" };
24
+ mockChannel = {
25
+ nack: jest.fn(),
26
+ publish: jest.fn(),
27
+ ack: jest.fn(),
28
+ };
29
+ mockMessage = {
30
+ properties: {
31
+ headers: {},
32
+ },
33
+ fields: {
34
+ routingKey: "test.routing.key",
35
+ },
36
+ content: Buffer.from("test content"),
37
+ };
38
+ mockRmqContext = {
39
+ getChannelRef: jest.fn().mockReturnValue(mockChannel),
40
+ getMessage: jest.fn().mockReturnValue(mockMessage),
41
+ getPattern: jest.fn().mockReturnValue("test.pattern"),
42
+ };
43
+ mockArgumentsHost = {
44
+ getType: jest.fn(),
45
+ switchToHttp: jest.fn().mockReturnValue({
46
+ getResponse: jest.fn().mockReturnValue(mockResponse),
47
+ getRequest: jest.fn().mockReturnValue(mockRequest),
48
+ }),
49
+ switchToRpc: jest.fn().mockReturnValue({
50
+ getContext: jest.fn().mockReturnValue(mockRmqContext),
51
+ }),
52
+ switchToWs: jest.fn().mockReturnValue({
53
+ getClient: jest.fn().mockReturnValue({
54
+ emit: jest.fn(),
55
+ }),
56
+ }),
57
+ };
58
+ filter = new UnifiedExceptionFilter(mockLoggerService);
59
+ });
60
+ describe("конструктор", () => {
61
+ it("должен установить контекст логгера", () => {
62
+ expect(mockLoggerService.setContext).toHaveBeenCalledWith("UnifiedExceptionFilter");
63
+ });
64
+ it("должен использовать дефолтный dlxExchange если не передан", () => {
65
+ const newFilter = new UnifiedExceptionFilter(mockLoggerService);
66
+ expect(newFilter).toBeInstanceOf(UnifiedExceptionFilter);
67
+ });
68
+ it("должен использовать кастомный dlxExchange если передан", () => {
69
+ const customDlxExchange = "custom.dlx.exchange";
70
+ const newFilter = new UnifiedExceptionFilter(mockLoggerService, customDlxExchange);
71
+ expect(newFilter).toBeInstanceOf(UnifiedExceptionFilter);
72
+ });
73
+ it("должен использовать дефолтный dlxExchange если передан undefined", () => {
74
+ const newFilter = new UnifiedExceptionFilter(mockLoggerService, undefined);
75
+ expect(newFilter).toBeInstanceOf(UnifiedExceptionFilter);
76
+ // Проверяем, что используется дефолтный dlxExchange в RpcExceptionFilter
77
+ mockArgumentsHost.getType.mockReturnValue(ContextType.RPC);
78
+ const exception = new Error("RPC error");
79
+ const rpcError = RpcError.fromUnknown(exception);
80
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
81
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
82
+ expect(() => {
83
+ newFilter.catch(exception, mockArgumentsHost);
84
+ }).toThrow(rpcError);
85
+ expect(mockChannel.publish).toHaveBeenCalledWith("events_exchange.dlx", expect.any(String), expect.any(Buffer), expect.any(Object));
86
+ });
87
+ it("должен передать кастомный dlxExchange в RpcExceptionFilter", () => {
88
+ const customDlxExchange = "custom.dlx.exchange";
89
+ const customFilter = new UnifiedExceptionFilter(mockLoggerService, customDlxExchange);
90
+ mockArgumentsHost.getType.mockReturnValue(ContextType.RPC);
91
+ const exception = new Error("RPC error");
92
+ const rpcError = RpcError.fromUnknown(exception);
93
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
94
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
95
+ expect(() => {
96
+ customFilter.catch(exception, mockArgumentsHost);
97
+ }).toThrow(rpcError);
98
+ expect(mockChannel.publish).toHaveBeenCalledWith(customDlxExchange, expect.any(String), expect.any(Buffer), expect.any(Object));
99
+ });
100
+ it("должен создать RpcExceptionFilter с моком логгера для покрытия строки 16", () => {
101
+ // Явно создаем RpcExceptionFilter с моком логгера
102
+ // для покрытия строки параметра конструктора
103
+ const rpcFilter = new RpcExceptionFilter(mockLoggerService);
104
+ expect(rpcFilter).toBeInstanceOf(RpcExceptionFilter);
105
+ });
106
+ it("должен создать HttpExceptionFilter с моком логгера для покрытия строки параметра конструктора", () => {
107
+ // Явно создаем HttpExceptionFilter с моком логгера
108
+ // для покрытия строки параметра конструктора
109
+ const httpFilter = new HttpExceptionFilter(mockLoggerService);
110
+ expect(httpFilter).toBeInstanceOf(HttpExceptionFilter);
111
+ });
112
+ it("должен покрыть строку 20 - параметр loggerService конструктора UnifiedExceptionFilter", () => {
113
+ // Явно создаем экземпляр с моком логгера для покрытия параметра конструктора
114
+ const testLoggerService = createLoggerServiceMock();
115
+ const testFilter = new UnifiedExceptionFilter(testLoggerService);
116
+ expect(testFilter).toBeInstanceOf(UnifiedExceptionFilter);
117
+ // Вызываем метод, чтобы убедиться, что мок используется
118
+ mockArgumentsHost.getType.mockReturnValue(ContextType.HTTP);
119
+ const exception = new HttpException("Test error", HttpStatus.BAD_REQUEST);
120
+ testFilter.catch(exception, mockArgumentsHost);
121
+ expect(testLoggerService.setContext).toHaveBeenCalled();
122
+ });
123
+ it("должен покрыть строку 21 - параметр loggerService конструктора при создании с dlxExchange", () => {
124
+ // Покрываем строку 21 - параметр loggerService конструктора при создании с dlxExchange
125
+ const testLoggerService = createLoggerServiceMock();
126
+ const customDlxExchange = "custom.dlx.exchange";
127
+ const testFilter = new UnifiedExceptionFilter(testLoggerService, customDlxExchange);
128
+ expect(testFilter).toBeInstanceOf(UnifiedExceptionFilter);
129
+ // Вызываем метод, чтобы убедиться, что мок используется
130
+ mockArgumentsHost.getType.mockReturnValue(ContextType.RPC);
131
+ const exception = new Error("RPC error");
132
+ const rpcError = RpcError.fromUnknown(exception);
133
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
134
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
135
+ expect(() => {
136
+ testFilter.catch(exception, mockArgumentsHost);
137
+ }).toThrow(rpcError);
138
+ expect(testLoggerService.setContext).toHaveBeenCalled();
139
+ });
140
+ });
141
+ describe("catch", () => {
142
+ describe("HTTP контекст", () => {
143
+ beforeEach(() => {
144
+ mockArgumentsHost.getType.mockReturnValue(ContextType.HTTP);
145
+ });
146
+ it("должен обработать HTTP ошибку через HttpExceptionFilter", () => {
147
+ const exception = new HttpException("Test error", HttpStatus.BAD_REQUEST);
148
+ filter.catch(exception, mockArgumentsHost);
149
+ expect(mockResponse.status).toHaveBeenCalledWith(400);
150
+ expect(mockResponse.json).toHaveBeenCalledWith(expect.objectContaining({
151
+ statusCode: 400,
152
+ error: "HttpError",
153
+ message: "Test error",
154
+ path: "/test",
155
+ }));
156
+ });
157
+ it("должен обработать обычный Error как InternalServerError", () => {
158
+ const exception = new Error("Unexpected error");
159
+ filter.catch(exception, mockArgumentsHost);
160
+ expect(mockResponse.status).toHaveBeenCalledWith(500);
161
+ expect(mockResponse.json).toHaveBeenCalledWith(expect.objectContaining({
162
+ statusCode: 500,
163
+ error: "HttpError",
164
+ message: "Unexpected error",
165
+ }));
166
+ });
167
+ });
168
+ describe("RPC контекст", () => {
169
+ beforeEach(() => {
170
+ mockArgumentsHost.getType.mockReturnValue(ContextType.RPC);
171
+ });
172
+ it("должен обработать RPC ошибку через RpcExceptionFilter", () => {
173
+ const exception = new Error("RPC error");
174
+ const rpcError = RpcError.fromUnknown(exception);
175
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
176
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(false);
177
+ expect(() => {
178
+ filter.catch(exception, mockArgumentsHost);
179
+ }).toThrow(rpcError);
180
+ expect(mockChannel.publish).toHaveBeenCalled();
181
+ expect(mockChannel.ack).toHaveBeenCalled();
182
+ });
183
+ it("должен requeue временную ошибку если retries < MAX_RETRIES", () => {
184
+ const exception = new Error("Timeout");
185
+ const rpcError = RpcError.fromUnknown(exception);
186
+ jest.spyOn(RpcError, "fromUnknown").mockReturnValue(rpcError);
187
+ jest.spyOn(rpcError, "isTransient").mockReturnValue(true);
188
+ mockMessage.properties.headers = {};
189
+ filter.catch(exception, mockArgumentsHost);
190
+ expect(mockChannel.nack).toHaveBeenCalledWith(mockMessage, false, false);
191
+ });
192
+ });
193
+ describe("WebSocket контекст", () => {
194
+ beforeEach(() => {
195
+ mockArgumentsHost.getType.mockReturnValue(ContextType.WS);
196
+ });
197
+ it("должен обработать WebSocket ошибку через WebSocketExceptionHandler", () => {
198
+ const mockClient = {
199
+ emit: jest.fn(),
200
+ };
201
+ mockArgumentsHost.switchToWs.mockReturnValue({
202
+ getClient: jest.fn().mockReturnValue(mockClient),
203
+ });
204
+ const exception = new Error("WebSocket error");
205
+ filter.catch(exception, mockArgumentsHost);
206
+ expect(mockClient.emit).toHaveBeenCalledWith("exception", expect.objectContaining({
207
+ status: "error",
208
+ message: expect.any(String),
209
+ }));
210
+ });
211
+ });
212
+ describe("неизвестный контекст", () => {
213
+ it("должен пробросить исключение для неизвестного контекста", () => {
214
+ mockArgumentsHost.getType.mockReturnValue("unknown");
215
+ const exception = new Error("Unknown context error");
216
+ expect(() => {
217
+ filter.catch(exception, mockArgumentsHost);
218
+ }).toThrow(exception);
219
+ expect(mockResponse.status).not.toHaveBeenCalled();
220
+ expect(mockResponse.json).not.toHaveBeenCalled();
221
+ expect(mockChannel.publish).not.toHaveBeenCalled();
222
+ });
223
+ it("должен пробросить исключение для пустого контекста", () => {
224
+ mockArgumentsHost.getType.mockReturnValue("");
225
+ const exception = new Error("Empty context error");
226
+ expect(() => {
227
+ filter.catch(exception, mockArgumentsHost);
228
+ }).toThrow(exception);
229
+ });
230
+ });
231
+ });
232
+ });
233
+ //# sourceMappingURL=unified-exception.filter.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unified-exception.filter.spec.js","sourceRoot":"","sources":["../../../src/filters/__tests__/unified-exception.filter.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=websocket-exception-handler.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket-exception-handler.spec.d.ts","sourceRoot":"","sources":["../../../src/filters/__tests__/websocket-exception-handler.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,78 @@
1
+ import { WsException } from "@nestjs/websockets";
2
+ import { createLoggerServiceMock } from "../../__tests__/mocks/logger-service.mock.js";
3
+ import SocketError from "../../errors/socket.error.js";
4
+ import WebSocketExceptionHandler from "../../filters/websocket-exception-handler.js";
5
+ describe("WebSocketExceptionHandler", () => {
6
+ let handler;
7
+ let mockLoggerService;
8
+ let mockArgumentsHost;
9
+ let mockClient;
10
+ beforeEach(() => {
11
+ mockLoggerService = createLoggerServiceMock();
12
+ mockClient = {
13
+ emit: jest.fn(),
14
+ id: "test-client-id",
15
+ };
16
+ mockArgumentsHost = {
17
+ switchToWs: jest.fn().mockReturnValue({
18
+ getClient: jest.fn().mockReturnValue(mockClient),
19
+ getData: jest.fn().mockReturnValue({ test: "data" }),
20
+ }),
21
+ };
22
+ handler = new WebSocketExceptionHandler(mockLoggerService);
23
+ });
24
+ it("should handle SocketError", () => {
25
+ const error = new SocketError("Socket error");
26
+ handler.handleException(error, mockArgumentsHost);
27
+ expect(mockLoggerService.setContext).toHaveBeenCalledWith(WebSocketExceptionHandler.name);
28
+ expect(mockLoggerService.error).toHaveBeenCalled();
29
+ expect(mockClient.emit).toHaveBeenCalledWith("exception", {
30
+ status: "error",
31
+ message: "Socket error",
32
+ code: "SOCKET_ERROR",
33
+ timestamp: expect.any(String),
34
+ });
35
+ });
36
+ it("should handle WsException", () => {
37
+ const error = new WsException("WebSocket error");
38
+ handler.handleException(error, mockArgumentsHost);
39
+ expect(mockLoggerService.error).toHaveBeenCalled();
40
+ expect(mockClient.emit).toHaveBeenCalledWith("exception", {
41
+ status: "error",
42
+ message: "WebSocket error",
43
+ code: "WS_EXCEPTION",
44
+ timestamp: expect.any(String),
45
+ });
46
+ });
47
+ it("should handle generic Error", () => {
48
+ const error = new Error("Generic error");
49
+ handler.handleException(error, mockArgumentsHost);
50
+ expect(mockLoggerService.error).toHaveBeenCalled();
51
+ expect(mockClient.emit).toHaveBeenCalledWith("exception", {
52
+ status: "error",
53
+ message: "Generic error",
54
+ code: "ERROR",
55
+ timestamp: expect.any(String),
56
+ });
57
+ });
58
+ it("should handle unknown error", () => {
59
+ const error = "Unknown error string";
60
+ handler.handleException(error, mockArgumentsHost);
61
+ expect(mockLoggerService.error).toHaveBeenCalled();
62
+ expect(mockClient.emit).toHaveBeenCalledWith("exception", {
63
+ status: "error",
64
+ message: "Unknown error string",
65
+ code: "INTERNAL_ERROR",
66
+ timestamp: expect.any(String),
67
+ });
68
+ });
69
+ it("should log stack trace when available", () => {
70
+ const error = new Error("Error with stack");
71
+ error.stack = "Error: Error with stack\n at test.js:1:1";
72
+ handler.handleException(error, mockArgumentsHost);
73
+ expect(mockLoggerService.error).toHaveBeenCalledTimes(2);
74
+ expect(mockLoggerService.error).toHaveBeenCalledWith(expect.stringContaining("Error with stack"));
75
+ expect(mockLoggerService.error).toHaveBeenCalledWith("Stack trace: Error: Error with stack\n at test.js:1:1");
76
+ });
77
+ });
78
+ //# sourceMappingURL=websocket-exception-handler.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket-exception-handler.spec.js","sourceRoot":"","sources":["../../../src/filters/__tests__/websocket-exception-handler.spec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { LoggerService } from "@makebelieve21213-packages/logger";
2
+ import type { ArgumentsHost } from "@nestjs/common";
3
+ export default class HttpExceptionFilter {
4
+ private readonly loggerService;
5
+ constructor(loggerService: LoggerService);
6
+ handleException(exception: Error | unknown, host: ArgumentsHost): void;
7
+ }
8
+ //# sourceMappingURL=http-exception-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-exception-handler.d.ts","sourceRoot":"","sources":["../../src/filters/http-exception-handler.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAKpD,MAAM,CAAC,OAAO,OAAO,mBAAmB;IAC3B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAAb,aAAa,EAAE,aAAa;IAGzD,eAAe,CAAC,SAAS,EAAE,KAAK,GAAG,OAAO,EAAE,IAAI,EAAE,aAAa,GAAG,IAAI;CAoCtE"}