@d-es-ign/stryker-js-core 9.6.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 (631) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +96 -0
  3. package/bin/stryker +2 -0
  4. package/bin/stryker.js +6 -0
  5. package/dist/src/checker/checker-child-process-proxy.d.ts +16 -0
  6. package/dist/src/checker/checker-child-process-proxy.d.ts.map +1 -0
  7. package/dist/src/checker/checker-child-process-proxy.js +22 -0
  8. package/dist/src/checker/checker-child-process-proxy.js.map +1 -0
  9. package/dist/src/checker/checker-facade.d.ts +9 -0
  10. package/dist/src/checker/checker-facade.d.ts.map +1 -0
  11. package/dist/src/checker/checker-facade.js +52 -0
  12. package/dist/src/checker/checker-facade.js.map +1 -0
  13. package/dist/src/checker/checker-factory.d.ts +10 -0
  14. package/dist/src/checker/checker-factory.d.ts.map +1 -0
  15. package/dist/src/checker/checker-factory.js +10 -0
  16. package/dist/src/checker/checker-factory.js.map +1 -0
  17. package/dist/src/checker/checker-resource.d.ts +8 -0
  18. package/dist/src/checker/checker-resource.d.ts.map +1 -0
  19. package/dist/src/checker/checker-resource.js +2 -0
  20. package/dist/src/checker/checker-resource.js.map +1 -0
  21. package/dist/src/checker/checker-retry-decorator.d.ts +12 -0
  22. package/dist/src/checker/checker-retry-decorator.d.ts.map +1 -0
  23. package/dist/src/checker/checker-retry-decorator.js +37 -0
  24. package/dist/src/checker/checker-retry-decorator.js.map +1 -0
  25. package/dist/src/checker/checker-worker.d.ts +14 -0
  26. package/dist/src/checker/checker-worker.d.ts.map +1 -0
  27. package/dist/src/checker/checker-worker.js +41 -0
  28. package/dist/src/checker/checker-worker.js.map +1 -0
  29. package/dist/src/checker/index.d.ts +4 -0
  30. package/dist/src/checker/index.d.ts.map +1 -0
  31. package/dist/src/checker/index.js +4 -0
  32. package/dist/src/checker/index.js.map +1 -0
  33. package/dist/src/child-proxy/child-process-crashed-error.d.ts +8 -0
  34. package/dist/src/child-proxy/child-process-crashed-error.d.ts.map +1 -0
  35. package/dist/src/child-proxy/child-process-crashed-error.js +16 -0
  36. package/dist/src/child-proxy/child-process-crashed-error.js.map +1 -0
  37. package/dist/src/child-proxy/child-process-proxy-worker.d.ts +32 -0
  38. package/dist/src/child-proxy/child-process-proxy-worker.d.ts.map +1 -0
  39. package/dist/src/child-proxy/child-process-proxy-worker.js +148 -0
  40. package/dist/src/child-proxy/child-process-proxy-worker.js.map +1 -0
  41. package/dist/src/child-proxy/child-process-proxy.d.ts +45 -0
  42. package/dist/src/child-proxy/child-process-proxy.d.ts.map +1 -0
  43. package/dist/src/child-proxy/child-process-proxy.js +232 -0
  44. package/dist/src/child-proxy/child-process-proxy.js.map +1 -0
  45. package/dist/src/child-proxy/id-generator.d.ts +5 -0
  46. package/dist/src/child-proxy/id-generator.d.ts.map +1 -0
  47. package/dist/src/child-proxy/id-generator.js +7 -0
  48. package/dist/src/child-proxy/id-generator.js.map +1 -0
  49. package/dist/src/child-proxy/message-protocol.d.ts +71 -0
  50. package/dist/src/child-proxy/message-protocol.d.ts.map +1 -0
  51. package/dist/src/child-proxy/message-protocol.js +34 -0
  52. package/dist/src/child-proxy/message-protocol.js.map +1 -0
  53. package/dist/src/child-proxy/out-of-memory-error.d.ts +5 -0
  54. package/dist/src/child-proxy/out-of-memory-error.d.ts.map +1 -0
  55. package/dist/src/child-proxy/out-of-memory-error.js +11 -0
  56. package/dist/src/child-proxy/out-of-memory-error.js.map +1 -0
  57. package/dist/src/concurrent/concurrency-token-provider.d.ts +20 -0
  58. package/dist/src/concurrent/concurrency-token-provider.d.ts.map +1 -0
  59. package/dist/src/concurrent/concurrency-token-provider.js +68 -0
  60. package/dist/src/concurrent/concurrency-token-provider.js.map +1 -0
  61. package/dist/src/concurrent/index.d.ts +4 -0
  62. package/dist/src/concurrent/index.d.ts.map +1 -0
  63. package/dist/src/concurrent/index.js +4 -0
  64. package/dist/src/concurrent/index.js.map +1 -0
  65. package/dist/src/concurrent/pool.d.ts +49 -0
  66. package/dist/src/concurrent/pool.d.ts.map +1 -0
  67. package/dist/src/concurrent/pool.js +137 -0
  68. package/dist/src/concurrent/pool.js.map +1 -0
  69. package/dist/src/concurrent/resource-decorator.d.ts +14 -0
  70. package/dist/src/concurrent/resource-decorator.d.ts.map +1 -0
  71. package/dist/src/concurrent/resource-decorator.js +24 -0
  72. package/dist/src/concurrent/resource-decorator.js.map +1 -0
  73. package/dist/src/config/config-file-formats.d.ts +6 -0
  74. package/dist/src/config/config-file-formats.d.ts.map +1 -0
  75. package/dist/src/config/config-file-formats.js +23 -0
  76. package/dist/src/config/config-file-formats.js.map +1 -0
  77. package/dist/src/config/config-reader.d.ts +23 -0
  78. package/dist/src/config/config-reader.d.ts.map +1 -0
  79. package/dist/src/config/config-reader.js +141 -0
  80. package/dist/src/config/config-reader.js.map +1 -0
  81. package/dist/src/config/file-matcher.d.ts +10 -0
  82. package/dist/src/config/file-matcher.d.ts.map +1 -0
  83. package/dist/src/config/file-matcher.js +31 -0
  84. package/dist/src/config/file-matcher.js.map +1 -0
  85. package/dist/src/config/index.d.ts +6 -0
  86. package/dist/src/config/index.d.ts.map +1 -0
  87. package/dist/src/config/index.js +6 -0
  88. package/dist/src/config/index.js.map +1 -0
  89. package/dist/src/config/meta-schema-builder.d.ts +10 -0
  90. package/dist/src/config/meta-schema-builder.d.ts.map +1 -0
  91. package/dist/src/config/meta-schema-builder.js +30 -0
  92. package/dist/src/config/meta-schema-builder.js.map +1 -0
  93. package/dist/src/config/options-validator.d.ts +28 -0
  94. package/dist/src/config/options-validator.d.ts.map +1 -0
  95. package/dist/src/config/options-validator.js +213 -0
  96. package/dist/src/config/options-validator.js.map +1 -0
  97. package/dist/src/config/validation-errors.d.ts +7 -0
  98. package/dist/src/config/validation-errors.d.ts.map +1 -0
  99. package/dist/src/config/validation-errors.js +154 -0
  100. package/dist/src/config/validation-errors.js.map +1 -0
  101. package/dist/src/di/core-tokens.d.ts +40 -0
  102. package/dist/src/di/core-tokens.d.ts.map +1 -0
  103. package/dist/src/di/core-tokens.js +40 -0
  104. package/dist/src/di/core-tokens.js.map +1 -0
  105. package/dist/src/di/index.d.ts +4 -0
  106. package/dist/src/di/index.d.ts.map +1 -0
  107. package/dist/src/di/index.js +4 -0
  108. package/dist/src/di/index.js.map +1 -0
  109. package/dist/src/di/plugin-creator.d.ts +10 -0
  110. package/dist/src/di/plugin-creator.d.ts.map +1 -0
  111. package/dist/src/di/plugin-creator.js +51 -0
  112. package/dist/src/di/plugin-creator.js.map +1 -0
  113. package/dist/src/di/plugin-loader.d.ts +41 -0
  114. package/dist/src/di/plugin-loader.d.ts.map +1 -0
  115. package/dist/src/di/plugin-loader.js +153 -0
  116. package/dist/src/di/plugin-loader.js.map +1 -0
  117. package/dist/src/errors.d.ts +5 -0
  118. package/dist/src/errors.d.ts.map +1 -0
  119. package/dist/src/errors.js +13 -0
  120. package/dist/src/errors.js.map +1 -0
  121. package/dist/src/fs/file-system.d.ts +19 -0
  122. package/dist/src/fs/file-system.d.ts.map +1 -0
  123. package/dist/src/fs/file-system.js +52 -0
  124. package/dist/src/fs/file-system.js.map +1 -0
  125. package/dist/src/fs/index.d.ts +5 -0
  126. package/dist/src/fs/index.d.ts.map +1 -0
  127. package/dist/src/fs/index.js +5 -0
  128. package/dist/src/fs/index.js.map +1 -0
  129. package/dist/src/fs/project-file.d.ts +26 -0
  130. package/dist/src/fs/project-file.d.ts.map +1 -0
  131. package/dist/src/fs/project-file.js +87 -0
  132. package/dist/src/fs/project-file.js.map +1 -0
  133. package/dist/src/fs/project-reader.d.ts +51 -0
  134. package/dist/src/fs/project-reader.d.ts.map +1 -0
  135. package/dist/src/fs/project-reader.js +335 -0
  136. package/dist/src/fs/project-reader.js.map +1 -0
  137. package/dist/src/fs/project.d.ts +22 -0
  138. package/dist/src/fs/project.d.ts.map +1 -0
  139. package/dist/src/fs/project.js +65 -0
  140. package/dist/src/fs/project.js.map +1 -0
  141. package/dist/src/index.d.ts +5 -0
  142. package/dist/src/index.d.ts.map +1 -0
  143. package/dist/src/index.js +6 -0
  144. package/dist/src/index.js.map +1 -0
  145. package/dist/src/initializer/custom-initializers/angular-initializer.d.ts +17 -0
  146. package/dist/src/initializer/custom-initializers/angular-initializer.d.ts.map +1 -0
  147. package/dist/src/initializer/custom-initializers/angular-initializer.js +74 -0
  148. package/dist/src/initializer/custom-initializers/angular-initializer.js.map +1 -0
  149. package/dist/src/initializer/custom-initializers/custom-initializer.d.ts +13 -0
  150. package/dist/src/initializer/custom-initializers/custom-initializer.d.ts.map +1 -0
  151. package/dist/src/initializer/custom-initializers/custom-initializer.js +2 -0
  152. package/dist/src/initializer/custom-initializers/custom-initializer.js.map +1 -0
  153. package/dist/src/initializer/custom-initializers/index.d.ts +14 -0
  154. package/dist/src/initializer/custom-initializers/index.d.ts.map +1 -0
  155. package/dist/src/initializer/custom-initializers/index.js +16 -0
  156. package/dist/src/initializer/custom-initializers/index.js.map +1 -0
  157. package/dist/src/initializer/custom-initializers/react-initializer.d.ts +12 -0
  158. package/dist/src/initializer/custom-initializers/react-initializer.d.ts.map +1 -0
  159. package/dist/src/initializer/custom-initializers/react-initializer.js +25 -0
  160. package/dist/src/initializer/custom-initializers/react-initializer.js.map +1 -0
  161. package/dist/src/initializer/custom-initializers/svelte-initializer.d.ts +6 -0
  162. package/dist/src/initializer/custom-initializers/svelte-initializer.d.ts.map +1 -0
  163. package/dist/src/initializer/custom-initializers/svelte-initializer.js +33 -0
  164. package/dist/src/initializer/custom-initializers/svelte-initializer.js.map +1 -0
  165. package/dist/src/initializer/custom-initializers/vue-js-initializer.d.ts +11 -0
  166. package/dist/src/initializer/custom-initializers/vue-js-initializer.d.ts.map +1 -0
  167. package/dist/src/initializer/custom-initializers/vue-js-initializer.js +20 -0
  168. package/dist/src/initializer/custom-initializers/vue-js-initializer.js.map +1 -0
  169. package/dist/src/initializer/gitignore-writer.d.ts +7 -0
  170. package/dist/src/initializer/gitignore-writer.d.ts.map +1 -0
  171. package/dist/src/initializer/gitignore-writer.js +28 -0
  172. package/dist/src/initializer/gitignore-writer.js.map +1 -0
  173. package/dist/src/initializer/index.d.ts +6 -0
  174. package/dist/src/initializer/index.d.ts.map +1 -0
  175. package/dist/src/initializer/index.js +29 -0
  176. package/dist/src/initializer/index.js.map +1 -0
  177. package/dist/src/initializer/initializer-tokens.d.ts +9 -0
  178. package/dist/src/initializer/initializer-tokens.d.ts.map +1 -0
  179. package/dist/src/initializer/initializer-tokens.js +9 -0
  180. package/dist/src/initializer/initializer-tokens.js.map +1 -0
  181. package/dist/src/initializer/inquire.d.ts +12 -0
  182. package/dist/src/initializer/inquire.d.ts.map +1 -0
  183. package/dist/src/initializer/inquire.js +12 -0
  184. package/dist/src/initializer/inquire.js.map +1 -0
  185. package/dist/src/initializer/npm-client.d.ts +22 -0
  186. package/dist/src/initializer/npm-client.d.ts.map +1 -0
  187. package/dist/src/initializer/npm-client.js +65 -0
  188. package/dist/src/initializer/npm-client.js.map +1 -0
  189. package/dist/src/initializer/npm-registry.d.ts +13 -0
  190. package/dist/src/initializer/npm-registry.d.ts.map +1 -0
  191. package/dist/src/initializer/npm-registry.js +36 -0
  192. package/dist/src/initializer/npm-registry.js.map +1 -0
  193. package/dist/src/initializer/package-info.d.ts +10 -0
  194. package/dist/src/initializer/package-info.d.ts.map +1 -0
  195. package/dist/src/initializer/package-info.js +2 -0
  196. package/dist/src/initializer/package-info.js.map +1 -0
  197. package/dist/src/initializer/prompt-option.d.ts +6 -0
  198. package/dist/src/initializer/prompt-option.d.ts.map +1 -0
  199. package/dist/src/initializer/prompt-option.js +2 -0
  200. package/dist/src/initializer/prompt-option.js.map +1 -0
  201. package/dist/src/initializer/stryker-config-writer.d.ts +27 -0
  202. package/dist/src/initializer/stryker-config-writer.d.ts.map +1 -0
  203. package/dist/src/initializer/stryker-config-writer.js +106 -0
  204. package/dist/src/initializer/stryker-config-writer.js.map +1 -0
  205. package/dist/src/initializer/stryker-initializer.d.ts +45 -0
  206. package/dist/src/initializer/stryker-initializer.d.ts.map +1 -0
  207. package/dist/src/initializer/stryker-initializer.js +184 -0
  208. package/dist/src/initializer/stryker-initializer.js.map +1 -0
  209. package/dist/src/initializer/stryker-inquirer.d.ts +15 -0
  210. package/dist/src/initializer/stryker-inquirer.d.ts.map +1 -0
  211. package/dist/src/initializer/stryker-inquirer.js +72 -0
  212. package/dist/src/initializer/stryker-inquirer.js.map +1 -0
  213. package/dist/src/logging/index.d.ts +6 -0
  214. package/dist/src/logging/index.d.ts.map +1 -0
  215. package/dist/src/logging/index.js +5 -0
  216. package/dist/src/logging/index.js.map +1 -0
  217. package/dist/src/logging/logger-impl.d.ts +19 -0
  218. package/dist/src/logging/logger-impl.d.ts.map +1 -0
  219. package/dist/src/logging/logger-impl.js +64 -0
  220. package/dist/src/logging/logger-impl.js.map +1 -0
  221. package/dist/src/logging/logging-backend.d.ts +22 -0
  222. package/dist/src/logging/logging-backend.d.ts.map +1 -0
  223. package/dist/src/logging/logging-backend.js +65 -0
  224. package/dist/src/logging/logging-backend.js.map +1 -0
  225. package/dist/src/logging/logging-client.d.ts +16 -0
  226. package/dist/src/logging/logging-client.d.ts.map +1 -0
  227. package/dist/src/logging/logging-client.js +44 -0
  228. package/dist/src/logging/logging-client.js.map +1 -0
  229. package/dist/src/logging/logging-event.d.ts +23 -0
  230. package/dist/src/logging/logging-event.d.ts.map +1 -0
  231. package/dist/src/logging/logging-event.js +63 -0
  232. package/dist/src/logging/logging-event.js.map +1 -0
  233. package/dist/src/logging/logging-server.d.ts +15 -0
  234. package/dist/src/logging/logging-server.d.ts.map +1 -0
  235. package/dist/src/logging/logging-server.js +43 -0
  236. package/dist/src/logging/logging-server.js.map +1 -0
  237. package/dist/src/logging/logging-sink.d.ts +7 -0
  238. package/dist/src/logging/logging-sink.d.ts.map +1 -0
  239. package/dist/src/logging/logging-sink.js +2 -0
  240. package/dist/src/logging/logging-sink.js.map +1 -0
  241. package/dist/src/logging/priority.d.ts +12 -0
  242. package/dist/src/logging/priority.d.ts.map +1 -0
  243. package/dist/src/logging/priority.js +13 -0
  244. package/dist/src/logging/priority.js.map +1 -0
  245. package/dist/src/logging/provide-logging.d.ts +30 -0
  246. package/dist/src/logging/provide-logging.d.ts.map +1 -0
  247. package/dist/src/logging/provide-logging.js +45 -0
  248. package/dist/src/logging/provide-logging.js.map +1 -0
  249. package/dist/src/mutants/diff-statistics-collector.d.ts +14 -0
  250. package/dist/src/mutants/diff-statistics-collector.d.ts.map +1 -0
  251. package/dist/src/mutants/diff-statistics-collector.js +40 -0
  252. package/dist/src/mutants/diff-statistics-collector.js.map +1 -0
  253. package/dist/src/mutants/incremental-differ.d.ts +39 -0
  254. package/dist/src/mutants/incremental-differ.d.ts.map +1 -0
  255. package/dist/src/mutants/incremental-differ.js +547 -0
  256. package/dist/src/mutants/incremental-differ.js.map +1 -0
  257. package/dist/src/mutants/index.d.ts +4 -0
  258. package/dist/src/mutants/index.d.ts.map +1 -0
  259. package/dist/src/mutants/index.js +4 -0
  260. package/dist/src/mutants/index.js.map +1 -0
  261. package/dist/src/mutants/mutant-test-planner.d.ts +36 -0
  262. package/dist/src/mutants/mutant-test-planner.d.ts.map +1 -0
  263. package/dist/src/mutants/mutant-test-planner.js +237 -0
  264. package/dist/src/mutants/mutant-test-planner.js.map +1 -0
  265. package/dist/src/mutants/test-coverage.d.ts +22 -0
  266. package/dist/src/mutants/test-coverage.d.ts.map +1 -0
  267. package/dist/src/mutants/test-coverage.js +87 -0
  268. package/dist/src/mutants/test-coverage.js.map +1 -0
  269. package/dist/src/process/1-prepare-executor.d.ts +22 -0
  270. package/dist/src/process/1-prepare-executor.d.ts.map +1 -0
  271. package/dist/src/process/1-prepare-executor.js +86 -0
  272. package/dist/src/process/1-prepare-executor.js.map +1 -0
  273. package/dist/src/process/2-mutant-instrumenter-executor.d.ts +39 -0
  274. package/dist/src/process/2-mutant-instrumenter-executor.d.ts.map +1 -0
  275. package/dist/src/process/2-mutant-instrumenter-executor.js +58 -0
  276. package/dist/src/process/2-mutant-instrumenter-executor.js.map +1 -0
  277. package/dist/src/process/3-dry-run-executor.d.ts +50 -0
  278. package/dist/src/process/3-dry-run-executor.d.ts.map +1 -0
  279. package/dist/src/process/3-dry-run-executor.js +164 -0
  280. package/dist/src/process/3-dry-run-executor.js.map +1 -0
  281. package/dist/src/process/4-mutation-test-executor.d.ts +56 -0
  282. package/dist/src/process/4-mutation-test-executor.d.ts.map +1 -0
  283. package/dist/src/process/4-mutation-test-executor.js +152 -0
  284. package/dist/src/process/4-mutation-test-executor.js.map +1 -0
  285. package/dist/src/process/index.d.ts +5 -0
  286. package/dist/src/process/index.d.ts.map +1 -0
  287. package/dist/src/process/index.js +5 -0
  288. package/dist/src/process/index.js.map +1 -0
  289. package/dist/src/reporters/broadcast-reporter.d.ts +25 -0
  290. package/dist/src/reporters/broadcast-reporter.d.ts.map +1 -0
  291. package/dist/src/reporters/broadcast-reporter.js +74 -0
  292. package/dist/src/reporters/broadcast-reporter.js.map +1 -0
  293. package/dist/src/reporters/ci/circle-provider.d.ts +11 -0
  294. package/dist/src/reporters/ci/circle-provider.d.ts.map +1 -0
  295. package/dist/src/reporters/ci/circle-provider.js +33 -0
  296. package/dist/src/reporters/ci/circle-provider.js.map +1 -0
  297. package/dist/src/reporters/ci/github-actions-provider.d.ts +9 -0
  298. package/dist/src/reporters/ci/github-actions-provider.d.ts.map +1 -0
  299. package/dist/src/reporters/ci/github-actions-provider.js +21 -0
  300. package/dist/src/reporters/ci/github-actions-provider.js.map +1 -0
  301. package/dist/src/reporters/ci/provider.d.ts +22 -0
  302. package/dist/src/reporters/ci/provider.d.ts.map +1 -0
  303. package/dist/src/reporters/ci/provider.js +24 -0
  304. package/dist/src/reporters/ci/provider.js.map +1 -0
  305. package/dist/src/reporters/ci/travis-provider.d.ts +9 -0
  306. package/dist/src/reporters/ci/travis-provider.d.ts.map +1 -0
  307. package/dist/src/reporters/ci/travis-provider.js +19 -0
  308. package/dist/src/reporters/ci/travis-provider.js.map +1 -0
  309. package/dist/src/reporters/clear-text-reporter.d.ts +23 -0
  310. package/dist/src/reporters/clear-text-reporter.d.ts.map +1 -0
  311. package/dist/src/reporters/clear-text-reporter.js +174 -0
  312. package/dist/src/reporters/clear-text-reporter.js.map +1 -0
  313. package/dist/src/reporters/clear-text-score-table.d.ts +22 -0
  314. package/dist/src/reporters/clear-text-score-table.d.ts.map +1 -0
  315. package/dist/src/reporters/clear-text-score-table.js +191 -0
  316. package/dist/src/reporters/clear-text-score-table.js.map +1 -0
  317. package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.d.ts +19 -0
  318. package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.d.ts.map +1 -0
  319. package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.js +54 -0
  320. package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.js.map +1 -0
  321. package/dist/src/reporters/dashboard-reporter/dashboard-reporter.d.ts +21 -0
  322. package/dist/src/reporters/dashboard-reporter/dashboard-reporter.d.ts.map +1 -0
  323. package/dist/src/reporters/dashboard-reporter/dashboard-reporter.js +62 -0
  324. package/dist/src/reporters/dashboard-reporter/dashboard-reporter.js.map +1 -0
  325. package/dist/src/reporters/dashboard-reporter/index.d.ts +7 -0
  326. package/dist/src/reporters/dashboard-reporter/index.d.ts.map +1 -0
  327. package/dist/src/reporters/dashboard-reporter/index.js +15 -0
  328. package/dist/src/reporters/dashboard-reporter/index.js.map +1 -0
  329. package/dist/src/reporters/dashboard-reporter/report.d.ts +6 -0
  330. package/dist/src/reporters/dashboard-reporter/report.d.ts.map +1 -0
  331. package/dist/src/reporters/dashboard-reporter/report.js +2 -0
  332. package/dist/src/reporters/dashboard-reporter/report.js.map +1 -0
  333. package/dist/src/reporters/dashboard-reporter/tokens.d.ts +6 -0
  334. package/dist/src/reporters/dashboard-reporter/tokens.d.ts.map +1 -0
  335. package/dist/src/reporters/dashboard-reporter/tokens.js +6 -0
  336. package/dist/src/reporters/dashboard-reporter/tokens.js.map +1 -0
  337. package/dist/src/reporters/dots-reporter.d.ts +7 -0
  338. package/dist/src/reporters/dots-reporter.d.ts.map +1 -0
  339. package/dist/src/reporters/dots-reporter.js +29 -0
  340. package/dist/src/reporters/dots-reporter.js.map +1 -0
  341. package/dist/src/reporters/event-recorder-reporter.d.ts +22 -0
  342. package/dist/src/reporters/event-recorder-reporter.d.ts.map +1 -0
  343. package/dist/src/reporters/event-recorder-reporter.js +53 -0
  344. package/dist/src/reporters/event-recorder-reporter.js.map +1 -0
  345. package/dist/src/reporters/html-reporter.d.ts +14 -0
  346. package/dist/src/reporters/html-reporter.d.ts.map +1 -0
  347. package/dist/src/reporters/html-reporter.js +65 -0
  348. package/dist/src/reporters/html-reporter.js.map +1 -0
  349. package/dist/src/reporters/index.d.ts +6 -0
  350. package/dist/src/reporters/index.d.ts.map +1 -0
  351. package/dist/src/reporters/index.js +24 -0
  352. package/dist/src/reporters/index.js.map +1 -0
  353. package/dist/src/reporters/json-reporter.d.ts +15 -0
  354. package/dist/src/reporters/json-reporter.d.ts.map +1 -0
  355. package/dist/src/reporters/json-reporter.js +29 -0
  356. package/dist/src/reporters/json-reporter.js.map +1 -0
  357. package/dist/src/reporters/mutation-test-report-helper.d.ts +40 -0
  358. package/dist/src/reporters/mutation-test-report-helper.d.ts.map +1 -0
  359. package/dist/src/reporters/mutation-test-report-helper.js +298 -0
  360. package/dist/src/reporters/mutation-test-report-helper.js.map +1 -0
  361. package/dist/src/reporters/mutation-timings-reporter.d.ts +14 -0
  362. package/dist/src/reporters/mutation-timings-reporter.d.ts.map +1 -0
  363. package/dist/src/reporters/mutation-timings-reporter.js +49 -0
  364. package/dist/src/reporters/mutation-timings-reporter.js.map +1 -0
  365. package/dist/src/reporters/progress-append-only-reporter.d.ts +10 -0
  366. package/dist/src/reporters/progress-append-only-reporter.d.ts.map +1 -0
  367. package/dist/src/reporters/progress-append-only-reporter.js +25 -0
  368. package/dist/src/reporters/progress-append-only-reporter.js.map +1 -0
  369. package/dist/src/reporters/progress-bar.d.ts +8 -0
  370. package/dist/src/reporters/progress-bar.d.ts.map +1 -0
  371. package/dist/src/reporters/progress-bar.js +6 -0
  372. package/dist/src/reporters/progress-bar.js.map +1 -0
  373. package/dist/src/reporters/progress-keeper.d.ts +27 -0
  374. package/dist/src/reporters/progress-keeper.d.ts.map +1 -0
  375. package/dist/src/reporters/progress-keeper.js +77 -0
  376. package/dist/src/reporters/progress-keeper.js.map +1 -0
  377. package/dist/src/reporters/progress-reporter.d.ts +11 -0
  378. package/dist/src/reporters/progress-reporter.d.ts.map +1 -0
  379. package/dist/src/reporters/progress-reporter.js +40 -0
  380. package/dist/src/reporters/progress-reporter.js.map +1 -0
  381. package/dist/src/reporters/reporter-util.d.ts +5 -0
  382. package/dist/src/reporters/reporter-util.d.ts.map +1 -0
  383. package/dist/src/reporters/reporter-util.js +19 -0
  384. package/dist/src/reporters/reporter-util.js.map +1 -0
  385. package/dist/src/reporters/strict-reporter.d.ts +3 -0
  386. package/dist/src/reporters/strict-reporter.d.ts.map +1 -0
  387. package/dist/src/reporters/strict-reporter.js +2 -0
  388. package/dist/src/reporters/strict-reporter.js.map +1 -0
  389. package/dist/src/sandbox/create-preprocessor.d.ts +7 -0
  390. package/dist/src/sandbox/create-preprocessor.d.ts.map +1 -0
  391. package/dist/src/sandbox/create-preprocessor.js +16 -0
  392. package/dist/src/sandbox/create-preprocessor.js.map +1 -0
  393. package/dist/src/sandbox/disable-type-checks-preprocessor.d.ts +18 -0
  394. package/dist/src/sandbox/disable-type-checks-preprocessor.d.ts.map +1 -0
  395. package/dist/src/sandbox/disable-type-checks-preprocessor.js +43 -0
  396. package/dist/src/sandbox/disable-type-checks-preprocessor.js.map +1 -0
  397. package/dist/src/sandbox/file-preprocessor.d.ts +10 -0
  398. package/dist/src/sandbox/file-preprocessor.d.ts.map +1 -0
  399. package/dist/src/sandbox/file-preprocessor.js +2 -0
  400. package/dist/src/sandbox/file-preprocessor.js.map +1 -0
  401. package/dist/src/sandbox/index.d.ts +4 -0
  402. package/dist/src/sandbox/index.d.ts.map +1 -0
  403. package/dist/src/sandbox/index.js +3 -0
  404. package/dist/src/sandbox/index.js.map +1 -0
  405. package/dist/src/sandbox/multi-preprocessor.d.ts +8 -0
  406. package/dist/src/sandbox/multi-preprocessor.d.ts.map +1 -0
  407. package/dist/src/sandbox/multi-preprocessor.js +12 -0
  408. package/dist/src/sandbox/multi-preprocessor.js.map +1 -0
  409. package/dist/src/sandbox/sandbox.d.ts +43 -0
  410. package/dist/src/sandbox/sandbox.d.ts.map +1 -0
  411. package/dist/src/sandbox/sandbox.js +134 -0
  412. package/dist/src/sandbox/sandbox.js.map +1 -0
  413. package/dist/src/sandbox/ts-config-preprocessor.d.ts +46 -0
  414. package/dist/src/sandbox/ts-config-preprocessor.d.ts.map +1 -0
  415. package/dist/src/sandbox/ts-config-preprocessor.js +112 -0
  416. package/dist/src/sandbox/ts-config-preprocessor.js.map +1 -0
  417. package/dist/src/stryker-cli.d.ts +15 -0
  418. package/dist/src/stryker-cli.d.ts.map +1 -0
  419. package/dist/src/stryker-cli.js +168 -0
  420. package/dist/src/stryker-cli.js.map +1 -0
  421. package/dist/src/stryker-package.d.ts +5 -0
  422. package/dist/src/stryker-package.d.ts.map +1 -0
  423. package/dist/src/stryker-package.js +7 -0
  424. package/dist/src/stryker-package.js.map +1 -0
  425. package/dist/src/stryker-server.d.ts +40 -0
  426. package/dist/src/stryker-server.d.ts.map +1 -0
  427. package/dist/src/stryker-server.js +234 -0
  428. package/dist/src/stryker-server.js.map +1 -0
  429. package/dist/src/stryker.d.ts +31 -0
  430. package/dist/src/stryker.d.ts.map +1 -0
  431. package/dist/src/stryker.js +86 -0
  432. package/dist/src/stryker.js.map +1 -0
  433. package/dist/src/test-runner/child-process-test-runner-proxy.d.ts +19 -0
  434. package/dist/src/test-runner/child-process-test-runner-proxy.d.ts.map +1 -0
  435. package/dist/src/test-runner/child-process-test-runner-proxy.js +45 -0
  436. package/dist/src/test-runner/child-process-test-runner-proxy.js.map +1 -0
  437. package/dist/src/test-runner/child-process-test-runner-worker.d.ts +14 -0
  438. package/dist/src/test-runner/child-process-test-runner-worker.d.ts.map +1 -0
  439. package/dist/src/test-runner/child-process-test-runner-worker.js +45 -0
  440. package/dist/src/test-runner/child-process-test-runner-worker.js.map +1 -0
  441. package/dist/src/test-runner/command-test-runner.d.ts +31 -0
  442. package/dist/src/test-runner/command-test-runner.d.ts.map +1 -0
  443. package/dist/src/test-runner/command-test-runner.js +144 -0
  444. package/dist/src/test-runner/command-test-runner.js.map +1 -0
  445. package/dist/src/test-runner/index.d.ts +11 -0
  446. package/dist/src/test-runner/index.d.ts.map +1 -0
  447. package/dist/src/test-runner/index.js +18 -0
  448. package/dist/src/test-runner/index.js.map +1 -0
  449. package/dist/src/test-runner/max-test-runner-reuse-decorator.d.ts +14 -0
  450. package/dist/src/test-runner/max-test-runner-reuse-decorator.d.ts.map +1 -0
  451. package/dist/src/test-runner/max-test-runner-reuse-decorator.js +25 -0
  452. package/dist/src/test-runner/max-test-runner-reuse-decorator.js.map +1 -0
  453. package/dist/src/test-runner/reload-environment-decorator.d.ts +11 -0
  454. package/dist/src/test-runner/reload-environment-decorator.d.ts.map +1 -0
  455. package/dist/src/test-runner/reload-environment-decorator.js +56 -0
  456. package/dist/src/test-runner/reload-environment-decorator.js.map +1 -0
  457. package/dist/src/test-runner/retry-rejected-decorator.d.ts +15 -0
  458. package/dist/src/test-runner/retry-rejected-decorator.d.ts.map +1 -0
  459. package/dist/src/test-runner/retry-rejected-decorator.js +59 -0
  460. package/dist/src/test-runner/retry-rejected-decorator.js.map +1 -0
  461. package/dist/src/test-runner/test-runner-decorator.d.ts +8 -0
  462. package/dist/src/test-runner/test-runner-decorator.d.ts.map +1 -0
  463. package/dist/src/test-runner/test-runner-decorator.js +13 -0
  464. package/dist/src/test-runner/test-runner-decorator.js.map +1 -0
  465. package/dist/src/test-runner/timeout-decorator.d.ts +15 -0
  466. package/dist/src/test-runner/timeout-decorator.d.ts.map +1 -0
  467. package/dist/src/test-runner/timeout-decorator.js +51 -0
  468. package/dist/src/test-runner/timeout-decorator.js.map +1 -0
  469. package/dist/src/unexpected-exit-handler.d.ts +13 -0
  470. package/dist/src/unexpected-exit-handler.d.ts.map +1 -0
  471. package/dist/src/unexpected-exit-handler.js +28 -0
  472. package/dist/src/unexpected-exit-handler.js.map +1 -0
  473. package/dist/src/utils/file-utils.d.ts +30 -0
  474. package/dist/src/utils/file-utils.d.ts.map +1 -0
  475. package/dist/src/utils/file-utils.js +101 -0
  476. package/dist/src/utils/file-utils.js.map +1 -0
  477. package/dist/src/utils/index.d.ts +7 -0
  478. package/dist/src/utils/index.d.ts.map +1 -0
  479. package/dist/src/utils/index.js +7 -0
  480. package/dist/src/utils/index.js.map +1 -0
  481. package/dist/src/utils/json-rpc-event-deserializer.d.ts +5 -0
  482. package/dist/src/utils/json-rpc-event-deserializer.d.ts.map +1 -0
  483. package/dist/src/utils/json-rpc-event-deserializer.js +42 -0
  484. package/dist/src/utils/json-rpc-event-deserializer.js.map +1 -0
  485. package/dist/src/utils/object-utils.d.ts +37 -0
  486. package/dist/src/utils/object-utils.d.ts.map +1 -0
  487. package/dist/src/utils/object-utils.js +91 -0
  488. package/dist/src/utils/object-utils.js.map +1 -0
  489. package/dist/src/utils/string-builder.d.ts +9 -0
  490. package/dist/src/utils/string-builder.d.ts.map +1 -0
  491. package/dist/src/utils/string-builder.js +26 -0
  492. package/dist/src/utils/string-builder.js.map +1 -0
  493. package/dist/src/utils/string-utils.d.ts +12 -0
  494. package/dist/src/utils/string-utils.d.ts.map +1 -0
  495. package/dist/src/utils/string-utils.js +54 -0
  496. package/dist/src/utils/string-utils.js.map +1 -0
  497. package/dist/src/utils/temporary-directory.d.ts +18 -0
  498. package/dist/src/utils/temporary-directory.d.ts.map +1 -0
  499. package/dist/src/utils/temporary-directory.js +63 -0
  500. package/dist/src/utils/temporary-directory.js.map +1 -0
  501. package/dist/src/utils/timer.d.ts +14 -0
  502. package/dist/src/utils/timer.d.ts.map +1 -0
  503. package/dist/src/utils/timer.js +53 -0
  504. package/dist/src/utils/timer.js.map +1 -0
  505. package/package.json +106 -0
  506. package/schema/stryker-schema.json +855 -0
  507. package/src/checker/checker-child-process-proxy.ts +67 -0
  508. package/src/checker/checker-facade.ts +90 -0
  509. package/src/checker/checker-factory.ts +46 -0
  510. package/src/checker/checker-resource.ts +12 -0
  511. package/src/checker/checker-retry-decorator.ts +57 -0
  512. package/src/checker/checker-worker.ts +62 -0
  513. package/src/checker/index.ts +3 -0
  514. package/src/child-proxy/child-process-crashed-error.ts +16 -0
  515. package/src/child-proxy/child-process-proxy-worker.ts +203 -0
  516. package/src/child-proxy/child-process-proxy.ts +353 -0
  517. package/src/child-proxy/id-generator.ts +6 -0
  518. package/src/child-proxy/message-protocol.ts +87 -0
  519. package/src/child-proxy/out-of-memory-error.ts +11 -0
  520. package/src/concurrent/concurrency-token-provider.ts +106 -0
  521. package/src/concurrent/index.ts +3 -0
  522. package/src/concurrent/pool.ts +209 -0
  523. package/src/concurrent/resource-decorator.ts +28 -0
  524. package/src/config/config-file-formats.ts +31 -0
  525. package/src/config/config-reader.ts +193 -0
  526. package/src/config/file-matcher.ts +36 -0
  527. package/src/config/index.ts +5 -0
  528. package/src/config/meta-schema-builder.ts +50 -0
  529. package/src/config/options-validator.ts +317 -0
  530. package/src/config/validation-errors.ts +192 -0
  531. package/src/di/core-tokens.ts +39 -0
  532. package/src/di/index.ts +4 -0
  533. package/src/di/plugin-creator.ts +102 -0
  534. package/src/di/plugin-loader.ts +245 -0
  535. package/src/errors.ts +12 -0
  536. package/src/fs/file-system.ts +63 -0
  537. package/src/fs/index.ts +4 -0
  538. package/src/fs/project-file.ts +100 -0
  539. package/src/fs/project-reader.ts +493 -0
  540. package/src/fs/project.ts +98 -0
  541. package/src/index.ts +7 -0
  542. package/src/initializer/custom-initializers/angular-initializer.ts +95 -0
  543. package/src/initializer/custom-initializers/custom-initializer.ts +14 -0
  544. package/src/initializer/custom-initializers/index.ts +31 -0
  545. package/src/initializer/custom-initializers/react-initializer.ts +35 -0
  546. package/src/initializer/custom-initializers/svelte-initializer.ts +40 -0
  547. package/src/initializer/custom-initializers/vue-js-initializer.ts +30 -0
  548. package/src/initializer/gitignore-writer.ts +33 -0
  549. package/src/initializer/index.ts +35 -0
  550. package/src/initializer/initializer-tokens.ts +8 -0
  551. package/src/initializer/inquire.ts +17 -0
  552. package/src/initializer/npm-client.ts +103 -0
  553. package/src/initializer/npm-registry.ts +48 -0
  554. package/src/initializer/package-info.ts +10 -0
  555. package/src/initializer/prompt-option.ts +6 -0
  556. package/src/initializer/stryker-config-writer.ts +158 -0
  557. package/src/initializer/stryker-initializer.ts +278 -0
  558. package/src/initializer/stryker-inquirer.ts +101 -0
  559. package/src/logging/index.ts +5 -0
  560. package/src/logging/logger-impl.ts +81 -0
  561. package/src/logging/logging-backend.ts +90 -0
  562. package/src/logging/logging-client.ts +56 -0
  563. package/src/logging/logging-event.ts +94 -0
  564. package/src/logging/logging-server.ts +56 -0
  565. package/src/logging/logging-sink.ts +7 -0
  566. package/src/logging/priority.ts +15 -0
  567. package/src/logging/provide-logging.ts +70 -0
  568. package/src/mutants/diff-statistics-collector.ts +47 -0
  569. package/src/mutants/incremental-differ.ts +771 -0
  570. package/src/mutants/index.ts +3 -0
  571. package/src/mutants/mutant-test-planner.ts +357 -0
  572. package/src/mutants/test-coverage.ts +125 -0
  573. package/src/process/1-prepare-executor.ts +133 -0
  574. package/src/process/2-mutant-instrumenter-executor.ts +122 -0
  575. package/src/process/3-dry-run-executor.ts +262 -0
  576. package/src/process/4-mutation-test-executor.ts +272 -0
  577. package/src/process/index.ts +4 -0
  578. package/src/reporters/broadcast-reporter.ts +129 -0
  579. package/src/reporters/ci/circle-provider.ts +50 -0
  580. package/src/reporters/ci/github-actions-provider.ts +22 -0
  581. package/src/reporters/ci/provider.ts +42 -0
  582. package/src/reporters/ci/travis-provider.ts +24 -0
  583. package/src/reporters/clear-text-reporter.ts +245 -0
  584. package/src/reporters/clear-text-score-table.ts +305 -0
  585. package/src/reporters/dashboard-reporter/dashboard-reporter-client.ts +89 -0
  586. package/src/reporters/dashboard-reporter/dashboard-reporter.ts +97 -0
  587. package/src/reporters/dashboard-reporter/index.ts +30 -0
  588. package/src/reporters/dashboard-reporter/report.ts +6 -0
  589. package/src/reporters/dashboard-reporter/tokens.ts +5 -0
  590. package/src/reporters/dots-reporter.ts +33 -0
  591. package/src/reporters/event-recorder-reporter.ts +88 -0
  592. package/src/reporters/html-reporter.ts +87 -0
  593. package/src/reporters/index.ts +48 -0
  594. package/src/reporters/json-reporter.ts +45 -0
  595. package/src/reporters/mutation-test-report-helper.ts +425 -0
  596. package/src/reporters/mutation-timings-reporter.ts +78 -0
  597. package/src/reporters/progress-append-only-reporter.ts +36 -0
  598. package/src/reporters/progress-bar.ts +6 -0
  599. package/src/reporters/progress-keeper.ts +113 -0
  600. package/src/reporters/progress-reporter.ts +62 -0
  601. package/src/reporters/reporter-util.ts +20 -0
  602. package/src/reporters/strict-reporter.ts +3 -0
  603. package/src/sandbox/create-preprocessor.ts +27 -0
  604. package/src/sandbox/disable-type-checks-preprocessor.ts +70 -0
  605. package/src/sandbox/file-preprocessor.ts +10 -0
  606. package/src/sandbox/index.ts +3 -0
  607. package/src/sandbox/multi-preprocessor.ts +13 -0
  608. package/src/sandbox/sandbox.ts +198 -0
  609. package/src/sandbox/ts-config-preprocessor.ts +168 -0
  610. package/src/stryker-cli.ts +363 -0
  611. package/src/stryker-package.ts +19 -0
  612. package/src/stryker-server.ts +334 -0
  613. package/src/stryker.ts +126 -0
  614. package/src/test-runner/child-process-test-runner-proxy.ts +94 -0
  615. package/src/test-runner/child-process-test-runner-worker.ts +66 -0
  616. package/src/test-runner/command-test-runner.ts +190 -0
  617. package/src/test-runner/index.ts +74 -0
  618. package/src/test-runner/max-test-runner-reuse-decorator.ts +41 -0
  619. package/src/test-runner/reload-environment-decorator.ts +72 -0
  620. package/src/test-runner/retry-rejected-decorator.ts +79 -0
  621. package/src/test-runner/test-runner-decorator.ts +22 -0
  622. package/src/test-runner/timeout-decorator.ts +71 -0
  623. package/src/unexpected-exit-handler.ts +36 -0
  624. package/src/utils/file-utils.ts +113 -0
  625. package/src/utils/index.ts +6 -0
  626. package/src/utils/json-rpc-event-deserializer.ts +48 -0
  627. package/src/utils/object-utils.ts +106 -0
  628. package/src/utils/string-builder.ts +30 -0
  629. package/src/utils/string-utils.ts +61 -0
  630. package/src/utils/temporary-directory.ts +83 -0
  631. package/src/utils/timer.ts +58 -0
@@ -0,0 +1,72 @@
1
+ import { CommandTestRunner } from '../test-runner/command-test-runner.js';
2
+ import { inquire } from './inquire.js';
3
+ export class StrykerInquirer {
4
+ async promptPresets(options) {
5
+ const preset = await inquire.select({
6
+ choices: [
7
+ ...options.map(({ name }) => ({
8
+ value: name,
9
+ })),
10
+ inquire.separator(),
11
+ { value: 'None/other' },
12
+ ],
13
+ message: 'Are you using one of these frameworks? Then select a preset configuration.',
14
+ });
15
+ return options.find((_) => _.name === preset);
16
+ }
17
+ async promptTestRunners(options) {
18
+ if (options.length) {
19
+ const testRunner = await inquire.select({
20
+ choices: [
21
+ ...options.map(({ name }) => ({ value: name })),
22
+ inquire.separator(),
23
+ { value: CommandTestRunner.runnerName },
24
+ ],
25
+ message: 'Which test runner do you want to use? If your test runner isn\'t listed here, you can choose "command" (it uses your `npm test` command, but will come with a big performance penalty)',
26
+ });
27
+ return (options.find(({ name }) => name === testRunner) ?? {
28
+ name: CommandTestRunner.runnerName,
29
+ pkg: null,
30
+ });
31
+ }
32
+ else {
33
+ return { name: CommandTestRunner.runnerName, pkg: null };
34
+ }
35
+ }
36
+ async promptBuildCommand() {
37
+ const buildCommand = await inquire.input({
38
+ message: 'What build command should be executed just before running your tests? For example: "npm run build" or "tsc -b" (leave empty when this is not needed).',
39
+ default: 'none',
40
+ });
41
+ return { name: buildCommand !== 'none' ? buildCommand : '', pkg: null };
42
+ }
43
+ async promptReporters(options) {
44
+ const defaults = ['html', 'clear-text', 'progress'];
45
+ const reporters = await inquire.checkbox({
46
+ choices: options.map(({ name }) => ({
47
+ value: name,
48
+ checked: defaults.includes(name),
49
+ })),
50
+ message: 'Which reporter(s) do you want to use?',
51
+ });
52
+ return options.filter((option) => reporters.some((reporterName) => option.name === reporterName));
53
+ }
54
+ async promptPackageManager(options) {
55
+ const packageManager = await inquire.select({
56
+ choices: options.map((_) => ({ value: _.name })),
57
+ default: 'npm',
58
+ message: 'Which package manager do you want to use?',
59
+ });
60
+ return options.find(({ name }) => name === packageManager);
61
+ }
62
+ async promptJsonConfigFormat() {
63
+ const json = 'JSON';
64
+ const configFormat = await inquire.select({
65
+ choices: [{ value: json }, { value: 'JavaScript' }],
66
+ default: json,
67
+ message: 'What file type do you want for your config file?',
68
+ });
69
+ return configFormat === json;
70
+ }
71
+ }
72
+ //# sourceMappingURL=stryker-inquirer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stryker-inquirer.js","sourceRoot":"","sources":["../../../src/initializer/stryker-inquirer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export * from './logging-backend.js';
2
+ export type { LoggingServerAddress, LoggingServer } from './logging-server.js';
3
+ export * from './provide-logging.js';
4
+ export * from './logging-sink.js';
5
+ export * from './priority.js';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/logging/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,YAAY,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC/E,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,eAAe,CAAC"}
@@ -0,0 +1,5 @@
1
+ export * from './logging-backend.js';
2
+ export * from './provide-logging.js';
3
+ export * from './logging-sink.js';
4
+ export * from './priority.js';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/logging/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AAErC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,eAAe,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { Logger } from '@stryker-mutator/api/logging';
2
+ import { LoggingSink } from './logging-sink.js';
3
+ export declare class LoggerImpl implements Logger {
4
+ #private;
5
+ constructor(categoryName: string, loggingBackend: LoggingSink);
6
+ isTraceEnabled(): boolean;
7
+ isDebugEnabled(): boolean;
8
+ isInfoEnabled(): boolean;
9
+ isWarnEnabled(): boolean;
10
+ isErrorEnabled(): boolean;
11
+ isFatalEnabled(): boolean;
12
+ trace(message: string, ...args: any[]): void;
13
+ debug(message: string, ...args: any[]): void;
14
+ info(message: string, ...args: any[]): void;
15
+ warn(message: string, ...args: any[]): void;
16
+ error(message: string, ...args: any[]): void;
17
+ fatal(message: string, ...args: any[]): void;
18
+ }
19
+ //# sourceMappingURL=logger-impl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger-impl.d.ts","sourceRoot":"","sources":["../../../src/logging/logger-impl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,8BAA8B,CAAC;AAGtD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,qBAAa,UAAW,YAAW,MAAM;;gBAI3B,YAAY,EAAE,MAAM,EAAE,cAAc,EAAE,WAAW;IAK7D,cAAc,IAAI,OAAO;IAGzB,cAAc,IAAI,OAAO;IAGzB,aAAa,IAAI,OAAO;IAGxB,aAAa,IAAI,OAAO;IAGxB,cAAc,IAAI,OAAO;IAGzB,cAAc,IAAI,OAAO;IAGzB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAQ5C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAQ5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAQ3C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAQ3C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAQ5C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;CAQ7C"}
@@ -0,0 +1,64 @@
1
+ import { LoggingEvent } from './logging-event.js';
2
+ export class LoggerImpl {
3
+ #categoryName;
4
+ #loggingBackend;
5
+ constructor(categoryName, loggingBackend) {
6
+ this.#categoryName = categoryName;
7
+ this.#loggingBackend = loggingBackend;
8
+ }
9
+ isTraceEnabled() {
10
+ return this.#loggingBackend.isEnabled("trace" /* LogLevel.Trace */);
11
+ }
12
+ isDebugEnabled() {
13
+ return this.#loggingBackend.isEnabled("debug" /* LogLevel.Debug */);
14
+ }
15
+ isInfoEnabled() {
16
+ return this.#loggingBackend.isEnabled("info" /* LogLevel.Information */);
17
+ }
18
+ isWarnEnabled() {
19
+ return this.#loggingBackend.isEnabled("warn" /* LogLevel.Warning */);
20
+ }
21
+ isErrorEnabled() {
22
+ return this.#loggingBackend.isEnabled("error" /* LogLevel.Error */);
23
+ }
24
+ isFatalEnabled() {
25
+ return this.#loggingBackend.isEnabled("fatal" /* LogLevel.Fatal */);
26
+ }
27
+ trace(message, ...args) {
28
+ this.#loggingBackend.log(LoggingEvent.create(this.#categoryName, "trace" /* LogLevel.Trace */, [
29
+ message,
30
+ ...args,
31
+ ]));
32
+ }
33
+ debug(message, ...args) {
34
+ this.#loggingBackend.log(LoggingEvent.create(this.#categoryName, "debug" /* LogLevel.Debug */, [
35
+ message,
36
+ ...args,
37
+ ]));
38
+ }
39
+ info(message, ...args) {
40
+ this.#loggingBackend.log(LoggingEvent.create(this.#categoryName, "info" /* LogLevel.Information */, [
41
+ message,
42
+ ...args,
43
+ ]));
44
+ }
45
+ warn(message, ...args) {
46
+ this.#loggingBackend.log(LoggingEvent.create(this.#categoryName, "warn" /* LogLevel.Warning */, [
47
+ message,
48
+ ...args,
49
+ ]));
50
+ }
51
+ error(message, ...args) {
52
+ this.#loggingBackend.log(LoggingEvent.create(this.#categoryName, "error" /* LogLevel.Error */, [
53
+ message,
54
+ ...args,
55
+ ]));
56
+ }
57
+ fatal(message, ...args) {
58
+ this.#loggingBackend.log(LoggingEvent.create(this.#categoryName, "fatal" /* LogLevel.Fatal */, [
59
+ message,
60
+ ...args,
61
+ ]));
62
+ }
63
+ }
64
+ //# sourceMappingURL=logger-impl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger-impl.js","sourceRoot":"","sources":["../../../src/logging/logger-impl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAGlD,MAAM,OAAO,UAAU;IACrB,aAAa,CAAC;IACd,eAAe,CAAC;IAEhB,YAAY,YAAoB,EAAE,cAA2B;QAC3D,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAClC,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;IACxC,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,8BAAgB,CAAC;IACxD,CAAC;IACD,cAAc;QACZ,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,8BAAgB,CAAC;IACxD,CAAC;IACD,aAAa;QACX,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,mCAAsB,CAAC;IAC9D,CAAC;IACD,aAAa;QACX,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,+BAAkB,CAAC;IAC1D,CAAC;IACD,cAAc;QACZ,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,8BAAgB,CAAC;IACxD,CAAC;IACD,cAAc;QACZ,OAAO,IAAI,CAAC,eAAe,CAAC,SAAS,8BAAgB,CAAC;IACxD,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,GAAG,IAAW;QACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,gCAAkB;YACtD,OAAO;YACP,GAAG,IAAI;SACR,CAAC,CACH,CAAC;IACJ,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,GAAG,IAAW;QACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,gCAAkB;YACtD,OAAO;YACP,GAAG,IAAI;SACR,CAAC,CACH,CAAC;IACJ,CAAC;IACD,IAAI,CAAC,OAAe,EAAE,GAAG,IAAW;QAClC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,qCAAwB;YAC5D,OAAO;YACP,GAAG,IAAI;SACR,CAAC,CACH,CAAC;IACJ,CAAC;IACD,IAAI,CAAC,OAAe,EAAE,GAAG,IAAW;QAClC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,iCAAoB;YACxD,OAAO;YACP,GAAG,IAAI;SACR,CAAC,CACH,CAAC;IACJ,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,GAAG,IAAW;QACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,gCAAkB;YACtD,OAAO;YACP,GAAG,IAAI;SACR,CAAC,CACH,CAAC;IACJ,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,GAAG,IAAW;QACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,gCAAkB;YACtD,OAAO;YACP,GAAG,IAAI;SACR,CAAC,CACH,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,22 @@
1
+ import { LogLevel, PartialStrykerOptions } from '@stryker-mutator/api/core';
2
+ import { LoggingEvent } from './logging-event.js';
3
+ import { Disposable } from 'typed-inject';
4
+ import { LoggingSink } from './logging-sink.js';
5
+ /**
6
+ * The logging backend that handles the actual logging. So to both a file and the stdout, stderr.
7
+ */
8
+ export declare class LoggingBackend implements LoggingSink, Disposable {
9
+ #private;
10
+ activeStdoutLevel: LogLevel;
11
+ activeFileLevel: LogLevel;
12
+ showColors: boolean;
13
+ static readonly inject: readonly ["loggerConsoleOut"];
14
+ constructor(consoleOut: NodeJS.WritableStream);
15
+ log(event: LoggingEvent): void;
16
+ isEnabled(level: LogLevel): boolean;
17
+ get activeLogLevel(): LogLevel;
18
+ get priority(): 0 | 1 | 2 | 3 | 4 | 5 | 6;
19
+ configure({ logLevel, fileLogLevel, allowConsoleColors, }: PartialStrykerOptions): void;
20
+ dispose(): Promise<void>;
21
+ }
22
+ //# sourceMappingURL=logging-backend.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-backend.d.ts","sourceRoot":"","sources":["../../../src/logging/logging-backend.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAC5E,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAMhD;;GAEG;AACH,qBAAa,cAAe,YAAW,WAAW,EAAE,UAAU;;IAC5D,iBAAiB,EAAE,QAAQ,CAAwB;IACnD,eAAe,EAAE,QAAQ,CAAgB;IACzC,UAAU,UAAQ;IAGlB,MAAM,CAAC,QAAQ,CAAC,MAAM,gCAA0C;gBAEpD,UAAU,EAAE,MAAM,CAAC,cAAc;IAI7C,GAAG,CAAC,KAAK,EAAE,YAAY;IAevB,SAAS,CAAC,KAAK,EAAE,QAAQ;IAKzB,IAAI,cAAc,aAEjB;IAED,IAAI,QAAQ,8BAEX;IAED,SAAS,CAAC,EACR,QAAQ,EACR,YAAY,EACZ,kBAAkB,GACnB,EAAE,qBAAqB;IA0BlB,OAAO;CAKd"}
@@ -0,0 +1,65 @@
1
+ import fs from 'fs';
2
+ import { promisify } from 'util';
3
+ import { logLevelPriority, minPriority } from './priority.js';
4
+ import { coreTokens } from '../di/index.js';
5
+ const LOG_FILE_NAME = 'stryker.log';
6
+ /**
7
+ * The logging backend that handles the actual logging. So to both a file and the stdout, stderr.
8
+ */
9
+ export class LoggingBackend {
10
+ activeStdoutLevel = "info" /* LogLevel.Information */;
11
+ activeFileLevel = "off" /* LogLevel.Off */;
12
+ showColors = true;
13
+ #consoleOut;
14
+ static inject = [coreTokens.loggerConsoleOut];
15
+ constructor(consoleOut) {
16
+ this.#consoleOut = consoleOut;
17
+ }
18
+ log(event) {
19
+ const eventPriority = logLevelPriority[event.level];
20
+ if (eventPriority >= logLevelPriority[this.activeStdoutLevel]) {
21
+ this.#consoleOut.write(`${this.showColors ? event.formatColorized() : event.format()}\n`);
22
+ }
23
+ if (eventPriority >= logLevelPriority[this.activeFileLevel] &&
24
+ !this.#fileStream.errored) {
25
+ this.#fileStream.write(`${event.format()}\n`);
26
+ }
27
+ }
28
+ isEnabled(level) {
29
+ const priority = logLevelPriority[level];
30
+ return priority >= this.priority;
31
+ }
32
+ get activeLogLevel() {
33
+ return minPriority(this.activeStdoutLevel, this.activeFileLevel);
34
+ }
35
+ get priority() {
36
+ return logLevelPriority[this.activeLogLevel];
37
+ }
38
+ configure({ logLevel, fileLogLevel, allowConsoleColors, }) {
39
+ if (logLevel) {
40
+ this.activeStdoutLevel = logLevel;
41
+ }
42
+ if (fileLogLevel) {
43
+ this.activeFileLevel = fileLogLevel;
44
+ }
45
+ if (allowConsoleColors !== undefined) {
46
+ this.showColors = allowConsoleColors;
47
+ }
48
+ }
49
+ #_fileStream;
50
+ get #fileStream() {
51
+ if (!this.#_fileStream) {
52
+ this.#_fileStream = fs.createWriteStream(LOG_FILE_NAME, { flags: 'a' });
53
+ this.#_fileStream.on('error', (error) => {
54
+ console.error(`An error occurred while writing to "${LOG_FILE_NAME}"`, error);
55
+ });
56
+ }
57
+ return this.#_fileStream;
58
+ }
59
+ async dispose() {
60
+ if (this.#_fileStream) {
61
+ await promisify(this.#_fileStream.end).bind(this.#_fileStream)();
62
+ }
63
+ }
64
+ }
65
+ //# sourceMappingURL=logging-backend.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-backend.js","sourceRoot":"","sources":["../../../src/logging/logging-backend.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { Disposable } from '@stryker-mutator/api/plugin';
2
+ import { LoggingServerAddress, LoggingSink } from '../logging/index.js';
3
+ import { LogLevel } from '@stryker-mutator/api/core';
4
+ import { LoggingEvent } from './logging-event.js';
5
+ export declare class LoggingClient implements LoggingSink, Disposable {
6
+ #private;
7
+ private logLevel;
8
+ private loggingServerAddress;
9
+ static readonly inject: readonly ["loggerActiveLevel", "loggingServerAddress"];
10
+ constructor(logLevel: LogLevel, loggingServerAddress: LoggingServerAddress);
11
+ openConnection(): Promise<void>;
12
+ log(event: LoggingEvent): void;
13
+ isEnabled(level: LogLevel): boolean;
14
+ dispose(): Promise<void>;
15
+ }
16
+ //# sourceMappingURL=logging-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-client.d.ts","sourceRoot":"","sources":["../../../src/logging/logging-client.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,oBAAoB,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAMlD,qBAAa,aAAc,YAAW,WAAW,EAAE,UAAU;;IAQzD,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,oBAAoB;IAN9B,MAAM,CAAC,QAAQ,CAAC,MAAM,yDAGX;gBAED,QAAQ,EAAE,QAAQ,EAClB,oBAAoB,EAAE,oBAAoB;IAGpD,cAAc;IAcd,GAAG,CAAC,KAAK,EAAE,YAAY,GAAG,IAAI;IAU9B,SAAS,CAAC,KAAK,EAAE,QAAQ,GAAG,OAAO;IAI7B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;CAK/B"}
@@ -0,0 +1,44 @@
1
+ import net from 'net';
2
+ import { promisify } from 'util';
3
+ import { DELIMITER } from './logging-server.js';
4
+ import { logLevelPriority } from './priority.js';
5
+ import { coreTokens } from '../di/index.js';
6
+ export class LoggingClient {
7
+ logLevel;
8
+ loggingServerAddress;
9
+ #socket;
10
+ static inject = [
11
+ coreTokens.loggerActiveLevel,
12
+ coreTokens.loggingServerAddress,
13
+ ];
14
+ constructor(logLevel, loggingServerAddress) {
15
+ this.logLevel = logLevel;
16
+ this.loggingServerAddress = loggingServerAddress;
17
+ }
18
+ openConnection() {
19
+ return new Promise((res, rej) => {
20
+ this.#socket = net.createConnection(this.loggingServerAddress.port, 'localhost', res);
21
+ this.#socket.on('error', (error) => {
22
+ console.error('Error occurred in logging client', error);
23
+ rej(error);
24
+ });
25
+ });
26
+ }
27
+ log(event) {
28
+ if (!this.#socket) {
29
+ throw new Error(`Cannot use the logging client before it is connected, please call '${LoggingClient.name}.prototype.${LoggingClient.prototype.openConnection.name}' first`);
30
+ }
31
+ if (this.isEnabled(event.level) && this.#socket.writable) {
32
+ this.#socket.write(JSON.stringify(event.serialize()) + DELIMITER);
33
+ }
34
+ }
35
+ isEnabled(level) {
36
+ return logLevelPriority[level] >= logLevelPriority[this.logLevel];
37
+ }
38
+ async dispose() {
39
+ if (this.#socket) {
40
+ await promisify(this.#socket.end).bind(this.#socket)();
41
+ }
42
+ }
43
+ }
44
+ //# sourceMappingURL=logging-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-client.js","sourceRoot":"","sources":["../../../src/logging/logging-client.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,KAAK,CAAC;AAKtB,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,MAAM,OAAO,aAAa;IAQd;IACA;IARV,OAAO,CAAc;IAErB,MAAM,CAAU,MAAM,GAAG;QACvB,UAAU,CAAC,iBAAiB;QAC5B,UAAU,CAAC,oBAAoB;KACvB,CAAC;IACX,YACU,QAAkB,EAClB,oBAA0C;QAD1C,aAAQ,GAAR,QAAQ,CAAU;QAClB,yBAAoB,GAApB,oBAAoB,CAAsB;IACjD,CAAC;IAEJ,cAAc;QACZ,OAAO,IAAI,OAAO,CAAO,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YACpC,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,gBAAgB,CACjC,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAC9B,WAAW,EACX,GAAG,CACJ,CAAC;YACF,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBACjC,OAAO,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;gBACzD,GAAG,CAAC,KAAK,CAAC,CAAC;YACb,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,GAAG,CAAC,KAAmB;QACrB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CACb,sEAAsE,aAAa,CAAC,IAAI,cAAc,aAAa,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,SAAS,CAC3J,CAAC;QACJ,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YACzD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IACD,SAAS,CAAC,KAAe;QACvB,OAAO,gBAAgB,CAAC,KAAK,CAAC,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpE,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;QACzD,CAAC;IACH,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { LogLevel } from '@stryker-mutator/api/core';
2
+ export declare class LoggingEvent {
3
+ #private;
4
+ readonly startTime: Date;
5
+ readonly categoryName: string;
6
+ readonly data: Array<unknown>;
7
+ readonly level: LogLevel;
8
+ readonly pid: number;
9
+ private constructor();
10
+ static create(categoryName: string, level: LogLevel, data: Array<unknown>): LoggingEvent;
11
+ format(): string;
12
+ formatColorized(): string;
13
+ static deserialize(ser: SerializedLoggingEvent): LoggingEvent;
14
+ serialize(): SerializedLoggingEvent;
15
+ }
16
+ export interface SerializedLoggingEvent {
17
+ startTime: string;
18
+ categoryName: string;
19
+ message: string;
20
+ level: LogLevel;
21
+ pid: number;
22
+ }
23
+ //# sourceMappingURL=logging-event.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-event.d.ts","sourceRoot":"","sources":["../../../src/logging/logging-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AASrD,qBAAa,YAAY;;IACvB,QAAQ,CAAC,SAAS,OAAC;IACnB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;IAC9B,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC;IACzB,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC;IAErB,OAAO;IAcP,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;IAIzE,MAAM,IAAI,MAAM;IAIhB,eAAe,IAAI,MAAM;IAkBzB,MAAM,CAAC,WAAW,CAAC,GAAG,EAAE,sBAAsB,GAAG,YAAY;IAU7D,SAAS,IAAI,sBAAsB;CASpC;AAED,MAAM,WAAW,sBAAsB;IACrC,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,QAAQ,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;CACb"}
@@ -0,0 +1,63 @@
1
+ import util from 'util';
2
+ const pattern = [
3
+ '[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)',
4
+ '(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-nq-uy=><~]))',
5
+ ].join('|');
6
+ const ansiRegex = new RegExp(pattern, 'g');
7
+ export class LoggingEvent {
8
+ startTime;
9
+ categoryName;
10
+ data;
11
+ level;
12
+ pid;
13
+ constructor(categoryName, level, data, startTime, pid) {
14
+ this.startTime = startTime;
15
+ this.categoryName = categoryName;
16
+ this.data = data;
17
+ this.level = level;
18
+ this.pid = pid;
19
+ }
20
+ static create(categoryName, level, data) {
21
+ return new LoggingEvent(categoryName, level, data, new Date(), process.pid);
22
+ }
23
+ format() {
24
+ return `${this.#formatPrefix()} ${this.#formatMessage().replace(ansiRegex, '')}`;
25
+ }
26
+ formatColorized() {
27
+ return `${this.#colorizedStart()}${this.#formatPrefix()}${this.#colorizedEnd()} ${this.#formatMessage()}`;
28
+ }
29
+ #formatPrefix() {
30
+ return `${this.startTime.toTimeString().slice(0, 8)} (${this.pid}) ${this.level.toUpperCase()} ${this.categoryName}`;
31
+ }
32
+ #formatMessage() {
33
+ return util.format(...this.data);
34
+ }
35
+ #colorizedStart() {
36
+ return `\x1B[${styles[this.level]}m`;
37
+ }
38
+ #colorizedEnd() {
39
+ return '\x1B[39m';
40
+ }
41
+ static deserialize(ser) {
42
+ return new LoggingEvent(ser.categoryName, ser.level, [ser.message], new Date(ser.startTime), ser.pid);
43
+ }
44
+ serialize() {
45
+ return {
46
+ startTime: this.startTime.toJSON(),
47
+ categoryName: this.categoryName,
48
+ message: this.#formatMessage(),
49
+ level: this.level,
50
+ pid: this.pid,
51
+ };
52
+ }
53
+ }
54
+ const styles = Object.freeze({
55
+ trace: 34, // blue
56
+ debug: 36, // cyan
57
+ info: 32, // green
58
+ warn: 33, // yellow
59
+ error: 91, // red
60
+ fatal: 35, // magenta
61
+ off: 90, // grey
62
+ });
63
+ //# sourceMappingURL=logging-event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-event.js","sourceRoot":"","sources":["../../../src/logging/logging-event.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { LoggingSink } from './logging-sink.js';
2
+ import { Disposable } from '@stryker-mutator/api/plugin';
3
+ export interface LoggingServerAddress {
4
+ port: number;
5
+ }
6
+ export declare const DELIMITER = "__STRYKER_CORE__";
7
+ export declare class LoggingServer implements Disposable {
8
+ #private;
9
+ private readonly loggingSink;
10
+ static readonly inject: readonly ["loggingSink"];
11
+ constructor(loggingSink: LoggingSink);
12
+ listen(): Promise<LoggingServerAddress>;
13
+ dispose(): Promise<void>;
14
+ }
15
+ //# sourceMappingURL=logging-server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-server.d.ts","sourceRoot":"","sources":["../../../src/logging/logging-server.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAIzD,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;CACd;AAED,eAAO,MAAM,SAAS,qBAAqB,CAAC;AAE5C,qBAAa,aAAc,YAAW,UAAU;;IAIlC,OAAO,CAAC,QAAQ,CAAC,WAAW;IAHxC,MAAM,CAAC,QAAQ,CAAC,MAAM,2BAAqC;gBAG9B,WAAW,EAAE,WAAW;IA0B9C,MAAM;IAQA,OAAO;CAGrB"}
@@ -0,0 +1,43 @@
1
+ import { coreTokens } from '../di/index.js';
2
+ import { LoggingEvent } from './logging-event.js';
3
+ import net from 'node:net';
4
+ import { promisify } from 'node:util';
5
+ export const DELIMITER = '__STRYKER_CORE__';
6
+ export class LoggingServer {
7
+ loggingSink;
8
+ static inject = [coreTokens.loggingSink];
9
+ #server;
10
+ constructor(loggingSink) {
11
+ this.loggingSink = loggingSink;
12
+ this.#server = net.createServer((socket) => {
13
+ socket.setEncoding('utf-8');
14
+ let dataSoFar = '';
15
+ socket.on('data', (data) => {
16
+ dataSoFar += data;
17
+ let index;
18
+ while ((index = dataSoFar.indexOf(DELIMITER)) !== -1) {
19
+ const logEvent = JSON.parse(dataSoFar.substring(0, index));
20
+ dataSoFar = dataSoFar.substring(index + DELIMITER.length);
21
+ this.loggingSink.log(LoggingEvent.deserialize(logEvent));
22
+ }
23
+ });
24
+ socket.on('error', (error) => {
25
+ this.loggingSink.log(LoggingEvent.create(LoggingServer.name, "debug" /* LogLevel.Debug */, [
26
+ 'An worker log process hung up unexpectedly',
27
+ error,
28
+ ]));
29
+ });
30
+ });
31
+ }
32
+ listen() {
33
+ return new Promise((res) => {
34
+ this.#server.listen(() => {
35
+ res({ port: this.#server.address().port });
36
+ });
37
+ });
38
+ }
39
+ async dispose() {
40
+ await promisify(this.#server.close).bind(this.#server)();
41
+ }
42
+ }
43
+ //# sourceMappingURL=logging-server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-server.js","sourceRoot":"","sources":["../../../src/logging/logging-server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAA0B,MAAM,oBAAoB,CAAC;AAE1E,OAAO,GAAG,MAAM,UAAU,CAAC;AAE3B,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAOtC,MAAM,CAAC,MAAM,SAAS,GAAG,kBAAkB,CAAC;AAE5C,MAAM,OAAO,aAAa;IAIK;IAH7B,MAAM,CAAU,MAAM,GAAG,CAAC,UAAU,CAAC,WAAW,CAAU,CAAC;IAC3D,OAAO,CAAC;IAER,YAA6B,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;QACnD,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE,EAAE;YACzC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC5B,IAAI,SAAS,GAAG,EAAE,CAAC;YACnB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;gBACjC,SAAS,IAAI,IAAI,CAAC;gBAClB,IAAI,KAAK,CAAC;gBACV,OAAO,CAAC,KAAK,GAAG,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;oBACrD,MAAM,QAAQ,GAA2B,IAAI,CAAC,KAAK,CACjD,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,CAC9B,CAAC;oBACF,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;oBAC1D,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAC3D,CAAC;YACH,CAAC,CAAC,CAAC;YACH,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC3B,IAAI,CAAC,WAAW,CAAC,GAAG,CAClB,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,gCAAkB;oBACtD,4CAA4C;oBAC5C,KAAK;iBACN,CAAC,CACH,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,MAAM;QACX,OAAO,IAAI,OAAO,CAAuB,CAAC,GAAG,EAAE,EAAE;YAC/C,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE;gBACvB,GAAG,CAAC,EAAE,IAAI,EAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAsB,CAAC,IAAI,EAAE,CAAC,CAAC;YAClE,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,KAAK,CAAC,OAAO;QAClB,MAAM,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;IAC3D,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { LogLevel } from '@stryker-mutator/api/core';
2
+ import { LoggingEvent } from './logging-event.js';
3
+ export interface LoggingSink {
4
+ log(event: LoggingEvent): void;
5
+ isEnabled(level: LogLevel): boolean;
6
+ }
7
+ //# sourceMappingURL=logging-sink.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-sink.d.ts","sourceRoot":"","sources":["../../../src/logging/logging-sink.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,MAAM,WAAW,WAAW;IAC1B,GAAG,CAAC,KAAK,EAAE,YAAY,GAAG,IAAI,CAAC;IAC/B,SAAS,CAAC,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC;CACrC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=logging-sink.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-sink.js","sourceRoot":"","sources":["../../../src/logging/logging-sink.ts"],"names":[],"mappings":""}
@@ -0,0 +1,12 @@
1
+ import { LogLevel } from '@stryker-mutator/api/core';
2
+ export declare const logLevelPriority: Readonly<{
3
+ trace: 0;
4
+ debug: 1;
5
+ info: 2;
6
+ warn: 3;
7
+ error: 4;
8
+ fatal: 5;
9
+ off: 6;
10
+ }>;
11
+ export declare function minPriority(a: LogLevel, b: LogLevel): LogLevel;
12
+ //# sourceMappingURL=priority.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"priority.d.ts","sourceRoot":"","sources":["../../../src/logging/priority.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAErD,eAAO,MAAM,gBAAgB;;;;;;;;EAQ3B,CAAC;AAEH,wBAAgB,WAAW,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAE9D"}
@@ -0,0 +1,13 @@
1
+ export const logLevelPriority = Object.freeze({
2
+ ["trace" /* LogLevel.Trace */]: 0,
3
+ ["debug" /* LogLevel.Debug */]: 1,
4
+ ["info" /* LogLevel.Information */]: 2,
5
+ ["warn" /* LogLevel.Warning */]: 3,
6
+ ["error" /* LogLevel.Error */]: 4,
7
+ ["fatal" /* LogLevel.Fatal */]: 5,
8
+ ["off" /* LogLevel.Off */]: 6,
9
+ });
10
+ export function minPriority(a, b) {
11
+ return logLevelPriority[a] < logLevelPriority[b] ? a : b;
12
+ }
13
+ //# sourceMappingURL=priority.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"priority.js","sourceRoot":"","sources":["../../../src/logging/priority.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC;IAC5C,8BAAgB,EAAE,CAAC;IACnB,8BAAgB,EAAE,CAAC;IACnB,mCAAsB,EAAE,CAAC;IACzB,+BAAkB,EAAE,CAAC;IACrB,8BAAgB,EAAE,CAAC;IACnB,8BAAgB,EAAE,CAAC;IACnB,0BAAc,EAAE,CAAC;CAClB,CAAC,CAAC;AAEH,MAAM,UAAU,WAAW,CAAC,CAAW,EAAE,CAAW;IAClD,OAAO,gBAAgB,CAAC,CAAC,CAAC,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC3D,CAAC"}
@@ -0,0 +1,30 @@
1
+ import { Injector } from 'typed-inject';
2
+ import { LoggingSink } from './logging-sink.js';
3
+ import { Logger } from '@stryker-mutator/api/logging';
4
+ import { coreTokens } from '../di/index.js';
5
+ import { LoggingServer, LoggingServerAddress } from './logging-server.js';
6
+ import { LoggingBackend } from './logging-backend.js';
7
+ import { LoggingClient } from './logging-client.js';
8
+ import { LogLevel } from '@stryker-mutator/api/core';
9
+ export declare function provideLogging<T extends {
10
+ [coreTokens.loggingSink]: LoggingSink;
11
+ }>(injector: Injector<T>): Injector<{ [K_1 in "getLogger" | "logger" | keyof T | "loggingServer"]: K_1 extends "loggingServer" ? LoggingServer : K_1 extends "getLogger" | "logger" | keyof T ? ({ [K_4 in "getLogger" | "logger" | keyof T]: K_4 extends "logger" ? Logger : K_4 extends "getLogger" | keyof T ? ({ [K_6 in "getLogger" | keyof T]: K_6 extends "getLogger" ? (categoryName?: string) => Logger : K_6 extends keyof T ? T[K_6] : never; } extends infer T_3 ? { [K_5 in keyof T_3]: T_3[K_5]; } : never)[K_4] : never; } extends infer T_2 ? { [K_3 in keyof T_2]: T_2[K_3]; } : never)[K_1] : never; } extends infer T_1 ? { [K in keyof T_1]: T_1[K]; } : never>;
12
+ export declare namespace provideLogging {
13
+ var inject: readonly ["loggingSink", "$injector"];
14
+ }
15
+ export declare function provideLoggingBackend(injector: Injector, loggerConsoleOut: NodeJS.WriteStream): Promise<Injector<{
16
+ loggerConsoleOut: NodeJS.WriteStream;
17
+ loggingSink: LoggingBackend;
18
+ loggingServerAddress: LoggingServerAddress;
19
+ loggingServer: LoggingServer;
20
+ }>>;
21
+ export declare namespace provideLoggingBackend {
22
+ var inject: readonly ["$injector"];
23
+ }
24
+ export type LoggingProvider = ReturnType<typeof provideLogging>;
25
+ export declare function provideLoggingClient(injector: Injector, loggingServerAddress: LoggingServerAddress, activeLogLevel: LogLevel): Promise<Injector<{
26
+ loggingSink: LoggingClient;
27
+ loggerActiveLevel: LogLevel;
28
+ loggingServerAddress: LoggingServerAddress;
29
+ }>>;
30
+ //# sourceMappingURL=provide-logging.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provide-logging.d.ts","sourceRoot":"","sources":["../../../src/logging/provide-logging.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,MAAM,EAAuB,MAAM,8BAA8B,CAAC;AAC3E,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC1E,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAiBrD,wBAAgB,cAAc,CAC5B,CAAC,SAAS;IAAE,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,WAAW,CAAA;CAAE,EACnD,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,uWAhBE,MAAM,KAAG,MAAM,oQAqBvC;yBAPe,cAAc;;;AAa9B,wBAAsB,qBAAqB,CACzC,QAAQ,EAAE,QAAQ,EAClB,gBAAgB,EAAE,MAAM,CAAC,WAAW;;;;;IAYrC;yBAdqB,qBAAqB;;;AAiB3C,MAAM,MAAM,eAAe,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAEhE,wBAAsB,oBAAoB,CACxC,QAAQ,EAAE,QAAQ,EAClB,oBAAoB,EAAE,oBAAoB,EAC1C,cAAc,EAAE,QAAQ;;;;IAQzB"}