@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.
- package/LICENSE +201 -0
- package/README.md +96 -0
- package/bin/stryker +2 -0
- package/bin/stryker.js +6 -0
- package/dist/src/checker/checker-child-process-proxy.d.ts +16 -0
- package/dist/src/checker/checker-child-process-proxy.d.ts.map +1 -0
- package/dist/src/checker/checker-child-process-proxy.js +22 -0
- package/dist/src/checker/checker-child-process-proxy.js.map +1 -0
- package/dist/src/checker/checker-facade.d.ts +9 -0
- package/dist/src/checker/checker-facade.d.ts.map +1 -0
- package/dist/src/checker/checker-facade.js +52 -0
- package/dist/src/checker/checker-facade.js.map +1 -0
- package/dist/src/checker/checker-factory.d.ts +10 -0
- package/dist/src/checker/checker-factory.d.ts.map +1 -0
- package/dist/src/checker/checker-factory.js +10 -0
- package/dist/src/checker/checker-factory.js.map +1 -0
- package/dist/src/checker/checker-resource.d.ts +8 -0
- package/dist/src/checker/checker-resource.d.ts.map +1 -0
- package/dist/src/checker/checker-resource.js +2 -0
- package/dist/src/checker/checker-resource.js.map +1 -0
- package/dist/src/checker/checker-retry-decorator.d.ts +12 -0
- package/dist/src/checker/checker-retry-decorator.d.ts.map +1 -0
- package/dist/src/checker/checker-retry-decorator.js +37 -0
- package/dist/src/checker/checker-retry-decorator.js.map +1 -0
- package/dist/src/checker/checker-worker.d.ts +14 -0
- package/dist/src/checker/checker-worker.d.ts.map +1 -0
- package/dist/src/checker/checker-worker.js +41 -0
- package/dist/src/checker/checker-worker.js.map +1 -0
- package/dist/src/checker/index.d.ts +4 -0
- package/dist/src/checker/index.d.ts.map +1 -0
- package/dist/src/checker/index.js +4 -0
- package/dist/src/checker/index.js.map +1 -0
- package/dist/src/child-proxy/child-process-crashed-error.d.ts +8 -0
- package/dist/src/child-proxy/child-process-crashed-error.d.ts.map +1 -0
- package/dist/src/child-proxy/child-process-crashed-error.js +16 -0
- package/dist/src/child-proxy/child-process-crashed-error.js.map +1 -0
- package/dist/src/child-proxy/child-process-proxy-worker.d.ts +32 -0
- package/dist/src/child-proxy/child-process-proxy-worker.d.ts.map +1 -0
- package/dist/src/child-proxy/child-process-proxy-worker.js +148 -0
- package/dist/src/child-proxy/child-process-proxy-worker.js.map +1 -0
- package/dist/src/child-proxy/child-process-proxy.d.ts +45 -0
- package/dist/src/child-proxy/child-process-proxy.d.ts.map +1 -0
- package/dist/src/child-proxy/child-process-proxy.js +232 -0
- package/dist/src/child-proxy/child-process-proxy.js.map +1 -0
- package/dist/src/child-proxy/id-generator.d.ts +5 -0
- package/dist/src/child-proxy/id-generator.d.ts.map +1 -0
- package/dist/src/child-proxy/id-generator.js +7 -0
- package/dist/src/child-proxy/id-generator.js.map +1 -0
- package/dist/src/child-proxy/message-protocol.d.ts +71 -0
- package/dist/src/child-proxy/message-protocol.d.ts.map +1 -0
- package/dist/src/child-proxy/message-protocol.js +34 -0
- package/dist/src/child-proxy/message-protocol.js.map +1 -0
- package/dist/src/child-proxy/out-of-memory-error.d.ts +5 -0
- package/dist/src/child-proxy/out-of-memory-error.d.ts.map +1 -0
- package/dist/src/child-proxy/out-of-memory-error.js +11 -0
- package/dist/src/child-proxy/out-of-memory-error.js.map +1 -0
- package/dist/src/concurrent/concurrency-token-provider.d.ts +20 -0
- package/dist/src/concurrent/concurrency-token-provider.d.ts.map +1 -0
- package/dist/src/concurrent/concurrency-token-provider.js +68 -0
- package/dist/src/concurrent/concurrency-token-provider.js.map +1 -0
- package/dist/src/concurrent/index.d.ts +4 -0
- package/dist/src/concurrent/index.d.ts.map +1 -0
- package/dist/src/concurrent/index.js +4 -0
- package/dist/src/concurrent/index.js.map +1 -0
- package/dist/src/concurrent/pool.d.ts +49 -0
- package/dist/src/concurrent/pool.d.ts.map +1 -0
- package/dist/src/concurrent/pool.js +137 -0
- package/dist/src/concurrent/pool.js.map +1 -0
- package/dist/src/concurrent/resource-decorator.d.ts +14 -0
- package/dist/src/concurrent/resource-decorator.d.ts.map +1 -0
- package/dist/src/concurrent/resource-decorator.js +24 -0
- package/dist/src/concurrent/resource-decorator.js.map +1 -0
- package/dist/src/config/config-file-formats.d.ts +6 -0
- package/dist/src/config/config-file-formats.d.ts.map +1 -0
- package/dist/src/config/config-file-formats.js +23 -0
- package/dist/src/config/config-file-formats.js.map +1 -0
- package/dist/src/config/config-reader.d.ts +23 -0
- package/dist/src/config/config-reader.d.ts.map +1 -0
- package/dist/src/config/config-reader.js +141 -0
- package/dist/src/config/config-reader.js.map +1 -0
- package/dist/src/config/file-matcher.d.ts +10 -0
- package/dist/src/config/file-matcher.d.ts.map +1 -0
- package/dist/src/config/file-matcher.js +31 -0
- package/dist/src/config/file-matcher.js.map +1 -0
- package/dist/src/config/index.d.ts +6 -0
- package/dist/src/config/index.d.ts.map +1 -0
- package/dist/src/config/index.js +6 -0
- package/dist/src/config/index.js.map +1 -0
- package/dist/src/config/meta-schema-builder.d.ts +10 -0
- package/dist/src/config/meta-schema-builder.d.ts.map +1 -0
- package/dist/src/config/meta-schema-builder.js +30 -0
- package/dist/src/config/meta-schema-builder.js.map +1 -0
- package/dist/src/config/options-validator.d.ts +28 -0
- package/dist/src/config/options-validator.d.ts.map +1 -0
- package/dist/src/config/options-validator.js +213 -0
- package/dist/src/config/options-validator.js.map +1 -0
- package/dist/src/config/validation-errors.d.ts +7 -0
- package/dist/src/config/validation-errors.d.ts.map +1 -0
- package/dist/src/config/validation-errors.js +154 -0
- package/dist/src/config/validation-errors.js.map +1 -0
- package/dist/src/di/core-tokens.d.ts +40 -0
- package/dist/src/di/core-tokens.d.ts.map +1 -0
- package/dist/src/di/core-tokens.js +40 -0
- package/dist/src/di/core-tokens.js.map +1 -0
- package/dist/src/di/index.d.ts +4 -0
- package/dist/src/di/index.d.ts.map +1 -0
- package/dist/src/di/index.js +4 -0
- package/dist/src/di/index.js.map +1 -0
- package/dist/src/di/plugin-creator.d.ts +10 -0
- package/dist/src/di/plugin-creator.d.ts.map +1 -0
- package/dist/src/di/plugin-creator.js +51 -0
- package/dist/src/di/plugin-creator.js.map +1 -0
- package/dist/src/di/plugin-loader.d.ts +41 -0
- package/dist/src/di/plugin-loader.d.ts.map +1 -0
- package/dist/src/di/plugin-loader.js +153 -0
- package/dist/src/di/plugin-loader.js.map +1 -0
- package/dist/src/errors.d.ts +5 -0
- package/dist/src/errors.d.ts.map +1 -0
- package/dist/src/errors.js +13 -0
- package/dist/src/errors.js.map +1 -0
- package/dist/src/fs/file-system.d.ts +19 -0
- package/dist/src/fs/file-system.d.ts.map +1 -0
- package/dist/src/fs/file-system.js +52 -0
- package/dist/src/fs/file-system.js.map +1 -0
- package/dist/src/fs/index.d.ts +5 -0
- package/dist/src/fs/index.d.ts.map +1 -0
- package/dist/src/fs/index.js +5 -0
- package/dist/src/fs/index.js.map +1 -0
- package/dist/src/fs/project-file.d.ts +26 -0
- package/dist/src/fs/project-file.d.ts.map +1 -0
- package/dist/src/fs/project-file.js +87 -0
- package/dist/src/fs/project-file.js.map +1 -0
- package/dist/src/fs/project-reader.d.ts +51 -0
- package/dist/src/fs/project-reader.d.ts.map +1 -0
- package/dist/src/fs/project-reader.js +335 -0
- package/dist/src/fs/project-reader.js.map +1 -0
- package/dist/src/fs/project.d.ts +22 -0
- package/dist/src/fs/project.d.ts.map +1 -0
- package/dist/src/fs/project.js +65 -0
- package/dist/src/fs/project.js.map +1 -0
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +6 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/initializer/custom-initializers/angular-initializer.d.ts +17 -0
- package/dist/src/initializer/custom-initializers/angular-initializer.d.ts.map +1 -0
- package/dist/src/initializer/custom-initializers/angular-initializer.js +74 -0
- package/dist/src/initializer/custom-initializers/angular-initializer.js.map +1 -0
- package/dist/src/initializer/custom-initializers/custom-initializer.d.ts +13 -0
- package/dist/src/initializer/custom-initializers/custom-initializer.d.ts.map +1 -0
- package/dist/src/initializer/custom-initializers/custom-initializer.js +2 -0
- package/dist/src/initializer/custom-initializers/custom-initializer.js.map +1 -0
- package/dist/src/initializer/custom-initializers/index.d.ts +14 -0
- package/dist/src/initializer/custom-initializers/index.d.ts.map +1 -0
- package/dist/src/initializer/custom-initializers/index.js +16 -0
- package/dist/src/initializer/custom-initializers/index.js.map +1 -0
- package/dist/src/initializer/custom-initializers/react-initializer.d.ts +12 -0
- package/dist/src/initializer/custom-initializers/react-initializer.d.ts.map +1 -0
- package/dist/src/initializer/custom-initializers/react-initializer.js +25 -0
- package/dist/src/initializer/custom-initializers/react-initializer.js.map +1 -0
- package/dist/src/initializer/custom-initializers/svelte-initializer.d.ts +6 -0
- package/dist/src/initializer/custom-initializers/svelte-initializer.d.ts.map +1 -0
- package/dist/src/initializer/custom-initializers/svelte-initializer.js +33 -0
- package/dist/src/initializer/custom-initializers/svelte-initializer.js.map +1 -0
- package/dist/src/initializer/custom-initializers/vue-js-initializer.d.ts +11 -0
- package/dist/src/initializer/custom-initializers/vue-js-initializer.d.ts.map +1 -0
- package/dist/src/initializer/custom-initializers/vue-js-initializer.js +20 -0
- package/dist/src/initializer/custom-initializers/vue-js-initializer.js.map +1 -0
- package/dist/src/initializer/gitignore-writer.d.ts +7 -0
- package/dist/src/initializer/gitignore-writer.d.ts.map +1 -0
- package/dist/src/initializer/gitignore-writer.js +28 -0
- package/dist/src/initializer/gitignore-writer.js.map +1 -0
- package/dist/src/initializer/index.d.ts +6 -0
- package/dist/src/initializer/index.d.ts.map +1 -0
- package/dist/src/initializer/index.js +29 -0
- package/dist/src/initializer/index.js.map +1 -0
- package/dist/src/initializer/initializer-tokens.d.ts +9 -0
- package/dist/src/initializer/initializer-tokens.d.ts.map +1 -0
- package/dist/src/initializer/initializer-tokens.js +9 -0
- package/dist/src/initializer/initializer-tokens.js.map +1 -0
- package/dist/src/initializer/inquire.d.ts +12 -0
- package/dist/src/initializer/inquire.d.ts.map +1 -0
- package/dist/src/initializer/inquire.js +12 -0
- package/dist/src/initializer/inquire.js.map +1 -0
- package/dist/src/initializer/npm-client.d.ts +22 -0
- package/dist/src/initializer/npm-client.d.ts.map +1 -0
- package/dist/src/initializer/npm-client.js +65 -0
- package/dist/src/initializer/npm-client.js.map +1 -0
- package/dist/src/initializer/npm-registry.d.ts +13 -0
- package/dist/src/initializer/npm-registry.d.ts.map +1 -0
- package/dist/src/initializer/npm-registry.js +36 -0
- package/dist/src/initializer/npm-registry.js.map +1 -0
- package/dist/src/initializer/package-info.d.ts +10 -0
- package/dist/src/initializer/package-info.d.ts.map +1 -0
- package/dist/src/initializer/package-info.js +2 -0
- package/dist/src/initializer/package-info.js.map +1 -0
- package/dist/src/initializer/prompt-option.d.ts +6 -0
- package/dist/src/initializer/prompt-option.d.ts.map +1 -0
- package/dist/src/initializer/prompt-option.js +2 -0
- package/dist/src/initializer/prompt-option.js.map +1 -0
- package/dist/src/initializer/stryker-config-writer.d.ts +27 -0
- package/dist/src/initializer/stryker-config-writer.d.ts.map +1 -0
- package/dist/src/initializer/stryker-config-writer.js +106 -0
- package/dist/src/initializer/stryker-config-writer.js.map +1 -0
- package/dist/src/initializer/stryker-initializer.d.ts +45 -0
- package/dist/src/initializer/stryker-initializer.d.ts.map +1 -0
- package/dist/src/initializer/stryker-initializer.js +184 -0
- package/dist/src/initializer/stryker-initializer.js.map +1 -0
- package/dist/src/initializer/stryker-inquirer.d.ts +15 -0
- package/dist/src/initializer/stryker-inquirer.d.ts.map +1 -0
- package/dist/src/initializer/stryker-inquirer.js +72 -0
- package/dist/src/initializer/stryker-inquirer.js.map +1 -0
- package/dist/src/logging/index.d.ts +6 -0
- package/dist/src/logging/index.d.ts.map +1 -0
- package/dist/src/logging/index.js +5 -0
- package/dist/src/logging/index.js.map +1 -0
- package/dist/src/logging/logger-impl.d.ts +19 -0
- package/dist/src/logging/logger-impl.d.ts.map +1 -0
- package/dist/src/logging/logger-impl.js +64 -0
- package/dist/src/logging/logger-impl.js.map +1 -0
- package/dist/src/logging/logging-backend.d.ts +22 -0
- package/dist/src/logging/logging-backend.d.ts.map +1 -0
- package/dist/src/logging/logging-backend.js +65 -0
- package/dist/src/logging/logging-backend.js.map +1 -0
- package/dist/src/logging/logging-client.d.ts +16 -0
- package/dist/src/logging/logging-client.d.ts.map +1 -0
- package/dist/src/logging/logging-client.js +44 -0
- package/dist/src/logging/logging-client.js.map +1 -0
- package/dist/src/logging/logging-event.d.ts +23 -0
- package/dist/src/logging/logging-event.d.ts.map +1 -0
- package/dist/src/logging/logging-event.js +63 -0
- package/dist/src/logging/logging-event.js.map +1 -0
- package/dist/src/logging/logging-server.d.ts +15 -0
- package/dist/src/logging/logging-server.d.ts.map +1 -0
- package/dist/src/logging/logging-server.js +43 -0
- package/dist/src/logging/logging-server.js.map +1 -0
- package/dist/src/logging/logging-sink.d.ts +7 -0
- package/dist/src/logging/logging-sink.d.ts.map +1 -0
- package/dist/src/logging/logging-sink.js +2 -0
- package/dist/src/logging/logging-sink.js.map +1 -0
- package/dist/src/logging/priority.d.ts +12 -0
- package/dist/src/logging/priority.d.ts.map +1 -0
- package/dist/src/logging/priority.js +13 -0
- package/dist/src/logging/priority.js.map +1 -0
- package/dist/src/logging/provide-logging.d.ts +30 -0
- package/dist/src/logging/provide-logging.d.ts.map +1 -0
- package/dist/src/logging/provide-logging.js +45 -0
- package/dist/src/logging/provide-logging.js.map +1 -0
- package/dist/src/mutants/diff-statistics-collector.d.ts +14 -0
- package/dist/src/mutants/diff-statistics-collector.d.ts.map +1 -0
- package/dist/src/mutants/diff-statistics-collector.js +40 -0
- package/dist/src/mutants/diff-statistics-collector.js.map +1 -0
- package/dist/src/mutants/incremental-differ.d.ts +39 -0
- package/dist/src/mutants/incremental-differ.d.ts.map +1 -0
- package/dist/src/mutants/incremental-differ.js +547 -0
- package/dist/src/mutants/incremental-differ.js.map +1 -0
- package/dist/src/mutants/index.d.ts +4 -0
- package/dist/src/mutants/index.d.ts.map +1 -0
- package/dist/src/mutants/index.js +4 -0
- package/dist/src/mutants/index.js.map +1 -0
- package/dist/src/mutants/mutant-test-planner.d.ts +36 -0
- package/dist/src/mutants/mutant-test-planner.d.ts.map +1 -0
- package/dist/src/mutants/mutant-test-planner.js +237 -0
- package/dist/src/mutants/mutant-test-planner.js.map +1 -0
- package/dist/src/mutants/test-coverage.d.ts +22 -0
- package/dist/src/mutants/test-coverage.d.ts.map +1 -0
- package/dist/src/mutants/test-coverage.js +87 -0
- package/dist/src/mutants/test-coverage.js.map +1 -0
- package/dist/src/process/1-prepare-executor.d.ts +22 -0
- package/dist/src/process/1-prepare-executor.d.ts.map +1 -0
- package/dist/src/process/1-prepare-executor.js +86 -0
- package/dist/src/process/1-prepare-executor.js.map +1 -0
- package/dist/src/process/2-mutant-instrumenter-executor.d.ts +39 -0
- package/dist/src/process/2-mutant-instrumenter-executor.d.ts.map +1 -0
- package/dist/src/process/2-mutant-instrumenter-executor.js +58 -0
- package/dist/src/process/2-mutant-instrumenter-executor.js.map +1 -0
- package/dist/src/process/3-dry-run-executor.d.ts +50 -0
- package/dist/src/process/3-dry-run-executor.d.ts.map +1 -0
- package/dist/src/process/3-dry-run-executor.js +164 -0
- package/dist/src/process/3-dry-run-executor.js.map +1 -0
- package/dist/src/process/4-mutation-test-executor.d.ts +56 -0
- package/dist/src/process/4-mutation-test-executor.d.ts.map +1 -0
- package/dist/src/process/4-mutation-test-executor.js +152 -0
- package/dist/src/process/4-mutation-test-executor.js.map +1 -0
- package/dist/src/process/index.d.ts +5 -0
- package/dist/src/process/index.d.ts.map +1 -0
- package/dist/src/process/index.js +5 -0
- package/dist/src/process/index.js.map +1 -0
- package/dist/src/reporters/broadcast-reporter.d.ts +25 -0
- package/dist/src/reporters/broadcast-reporter.d.ts.map +1 -0
- package/dist/src/reporters/broadcast-reporter.js +74 -0
- package/dist/src/reporters/broadcast-reporter.js.map +1 -0
- package/dist/src/reporters/ci/circle-provider.d.ts +11 -0
- package/dist/src/reporters/ci/circle-provider.d.ts.map +1 -0
- package/dist/src/reporters/ci/circle-provider.js +33 -0
- package/dist/src/reporters/ci/circle-provider.js.map +1 -0
- package/dist/src/reporters/ci/github-actions-provider.d.ts +9 -0
- package/dist/src/reporters/ci/github-actions-provider.d.ts.map +1 -0
- package/dist/src/reporters/ci/github-actions-provider.js +21 -0
- package/dist/src/reporters/ci/github-actions-provider.js.map +1 -0
- package/dist/src/reporters/ci/provider.d.ts +22 -0
- package/dist/src/reporters/ci/provider.d.ts.map +1 -0
- package/dist/src/reporters/ci/provider.js +24 -0
- package/dist/src/reporters/ci/provider.js.map +1 -0
- package/dist/src/reporters/ci/travis-provider.d.ts +9 -0
- package/dist/src/reporters/ci/travis-provider.d.ts.map +1 -0
- package/dist/src/reporters/ci/travis-provider.js +19 -0
- package/dist/src/reporters/ci/travis-provider.js.map +1 -0
- package/dist/src/reporters/clear-text-reporter.d.ts +23 -0
- package/dist/src/reporters/clear-text-reporter.d.ts.map +1 -0
- package/dist/src/reporters/clear-text-reporter.js +174 -0
- package/dist/src/reporters/clear-text-reporter.js.map +1 -0
- package/dist/src/reporters/clear-text-score-table.d.ts +22 -0
- package/dist/src/reporters/clear-text-score-table.d.ts.map +1 -0
- package/dist/src/reporters/clear-text-score-table.js +191 -0
- package/dist/src/reporters/clear-text-score-table.js.map +1 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.d.ts +19 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.d.ts.map +1 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.js +54 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter-client.js.map +1 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter.d.ts +21 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter.d.ts.map +1 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter.js +62 -0
- package/dist/src/reporters/dashboard-reporter/dashboard-reporter.js.map +1 -0
- package/dist/src/reporters/dashboard-reporter/index.d.ts +7 -0
- package/dist/src/reporters/dashboard-reporter/index.d.ts.map +1 -0
- package/dist/src/reporters/dashboard-reporter/index.js +15 -0
- package/dist/src/reporters/dashboard-reporter/index.js.map +1 -0
- package/dist/src/reporters/dashboard-reporter/report.d.ts +6 -0
- package/dist/src/reporters/dashboard-reporter/report.d.ts.map +1 -0
- package/dist/src/reporters/dashboard-reporter/report.js +2 -0
- package/dist/src/reporters/dashboard-reporter/report.js.map +1 -0
- package/dist/src/reporters/dashboard-reporter/tokens.d.ts +6 -0
- package/dist/src/reporters/dashboard-reporter/tokens.d.ts.map +1 -0
- package/dist/src/reporters/dashboard-reporter/tokens.js +6 -0
- package/dist/src/reporters/dashboard-reporter/tokens.js.map +1 -0
- package/dist/src/reporters/dots-reporter.d.ts +7 -0
- package/dist/src/reporters/dots-reporter.d.ts.map +1 -0
- package/dist/src/reporters/dots-reporter.js +29 -0
- package/dist/src/reporters/dots-reporter.js.map +1 -0
- package/dist/src/reporters/event-recorder-reporter.d.ts +22 -0
- package/dist/src/reporters/event-recorder-reporter.d.ts.map +1 -0
- package/dist/src/reporters/event-recorder-reporter.js +53 -0
- package/dist/src/reporters/event-recorder-reporter.js.map +1 -0
- package/dist/src/reporters/html-reporter.d.ts +14 -0
- package/dist/src/reporters/html-reporter.d.ts.map +1 -0
- package/dist/src/reporters/html-reporter.js +65 -0
- package/dist/src/reporters/html-reporter.js.map +1 -0
- package/dist/src/reporters/index.d.ts +6 -0
- package/dist/src/reporters/index.d.ts.map +1 -0
- package/dist/src/reporters/index.js +24 -0
- package/dist/src/reporters/index.js.map +1 -0
- package/dist/src/reporters/json-reporter.d.ts +15 -0
- package/dist/src/reporters/json-reporter.d.ts.map +1 -0
- package/dist/src/reporters/json-reporter.js +29 -0
- package/dist/src/reporters/json-reporter.js.map +1 -0
- package/dist/src/reporters/mutation-test-report-helper.d.ts +40 -0
- package/dist/src/reporters/mutation-test-report-helper.d.ts.map +1 -0
- package/dist/src/reporters/mutation-test-report-helper.js +298 -0
- package/dist/src/reporters/mutation-test-report-helper.js.map +1 -0
- package/dist/src/reporters/mutation-timings-reporter.d.ts +14 -0
- package/dist/src/reporters/mutation-timings-reporter.d.ts.map +1 -0
- package/dist/src/reporters/mutation-timings-reporter.js +49 -0
- package/dist/src/reporters/mutation-timings-reporter.js.map +1 -0
- package/dist/src/reporters/progress-append-only-reporter.d.ts +10 -0
- package/dist/src/reporters/progress-append-only-reporter.d.ts.map +1 -0
- package/dist/src/reporters/progress-append-only-reporter.js +25 -0
- package/dist/src/reporters/progress-append-only-reporter.js.map +1 -0
- package/dist/src/reporters/progress-bar.d.ts +8 -0
- package/dist/src/reporters/progress-bar.d.ts.map +1 -0
- package/dist/src/reporters/progress-bar.js +6 -0
- package/dist/src/reporters/progress-bar.js.map +1 -0
- package/dist/src/reporters/progress-keeper.d.ts +27 -0
- package/dist/src/reporters/progress-keeper.d.ts.map +1 -0
- package/dist/src/reporters/progress-keeper.js +77 -0
- package/dist/src/reporters/progress-keeper.js.map +1 -0
- package/dist/src/reporters/progress-reporter.d.ts +11 -0
- package/dist/src/reporters/progress-reporter.d.ts.map +1 -0
- package/dist/src/reporters/progress-reporter.js +40 -0
- package/dist/src/reporters/progress-reporter.js.map +1 -0
- package/dist/src/reporters/reporter-util.d.ts +5 -0
- package/dist/src/reporters/reporter-util.d.ts.map +1 -0
- package/dist/src/reporters/reporter-util.js +19 -0
- package/dist/src/reporters/reporter-util.js.map +1 -0
- package/dist/src/reporters/strict-reporter.d.ts +3 -0
- package/dist/src/reporters/strict-reporter.d.ts.map +1 -0
- package/dist/src/reporters/strict-reporter.js +2 -0
- package/dist/src/reporters/strict-reporter.js.map +1 -0
- package/dist/src/sandbox/create-preprocessor.d.ts +7 -0
- package/dist/src/sandbox/create-preprocessor.d.ts.map +1 -0
- package/dist/src/sandbox/create-preprocessor.js +16 -0
- package/dist/src/sandbox/create-preprocessor.js.map +1 -0
- package/dist/src/sandbox/disable-type-checks-preprocessor.d.ts +18 -0
- package/dist/src/sandbox/disable-type-checks-preprocessor.d.ts.map +1 -0
- package/dist/src/sandbox/disable-type-checks-preprocessor.js +43 -0
- package/dist/src/sandbox/disable-type-checks-preprocessor.js.map +1 -0
- package/dist/src/sandbox/file-preprocessor.d.ts +10 -0
- package/dist/src/sandbox/file-preprocessor.d.ts.map +1 -0
- package/dist/src/sandbox/file-preprocessor.js +2 -0
- package/dist/src/sandbox/file-preprocessor.js.map +1 -0
- package/dist/src/sandbox/index.d.ts +4 -0
- package/dist/src/sandbox/index.d.ts.map +1 -0
- package/dist/src/sandbox/index.js +3 -0
- package/dist/src/sandbox/index.js.map +1 -0
- package/dist/src/sandbox/multi-preprocessor.d.ts +8 -0
- package/dist/src/sandbox/multi-preprocessor.d.ts.map +1 -0
- package/dist/src/sandbox/multi-preprocessor.js +12 -0
- package/dist/src/sandbox/multi-preprocessor.js.map +1 -0
- package/dist/src/sandbox/sandbox.d.ts +43 -0
- package/dist/src/sandbox/sandbox.d.ts.map +1 -0
- package/dist/src/sandbox/sandbox.js +134 -0
- package/dist/src/sandbox/sandbox.js.map +1 -0
- package/dist/src/sandbox/ts-config-preprocessor.d.ts +46 -0
- package/dist/src/sandbox/ts-config-preprocessor.d.ts.map +1 -0
- package/dist/src/sandbox/ts-config-preprocessor.js +112 -0
- package/dist/src/sandbox/ts-config-preprocessor.js.map +1 -0
- package/dist/src/stryker-cli.d.ts +15 -0
- package/dist/src/stryker-cli.d.ts.map +1 -0
- package/dist/src/stryker-cli.js +168 -0
- package/dist/src/stryker-cli.js.map +1 -0
- package/dist/src/stryker-package.d.ts +5 -0
- package/dist/src/stryker-package.d.ts.map +1 -0
- package/dist/src/stryker-package.js +7 -0
- package/dist/src/stryker-package.js.map +1 -0
- package/dist/src/stryker-server.d.ts +40 -0
- package/dist/src/stryker-server.d.ts.map +1 -0
- package/dist/src/stryker-server.js +234 -0
- package/dist/src/stryker-server.js.map +1 -0
- package/dist/src/stryker.d.ts +31 -0
- package/dist/src/stryker.d.ts.map +1 -0
- package/dist/src/stryker.js +86 -0
- package/dist/src/stryker.js.map +1 -0
- package/dist/src/test-runner/child-process-test-runner-proxy.d.ts +19 -0
- package/dist/src/test-runner/child-process-test-runner-proxy.d.ts.map +1 -0
- package/dist/src/test-runner/child-process-test-runner-proxy.js +45 -0
- package/dist/src/test-runner/child-process-test-runner-proxy.js.map +1 -0
- package/dist/src/test-runner/child-process-test-runner-worker.d.ts +14 -0
- package/dist/src/test-runner/child-process-test-runner-worker.d.ts.map +1 -0
- package/dist/src/test-runner/child-process-test-runner-worker.js +45 -0
- package/dist/src/test-runner/child-process-test-runner-worker.js.map +1 -0
- package/dist/src/test-runner/command-test-runner.d.ts +31 -0
- package/dist/src/test-runner/command-test-runner.d.ts.map +1 -0
- package/dist/src/test-runner/command-test-runner.js +144 -0
- package/dist/src/test-runner/command-test-runner.js.map +1 -0
- package/dist/src/test-runner/index.d.ts +11 -0
- package/dist/src/test-runner/index.d.ts.map +1 -0
- package/dist/src/test-runner/index.js +18 -0
- package/dist/src/test-runner/index.js.map +1 -0
- package/dist/src/test-runner/max-test-runner-reuse-decorator.d.ts +14 -0
- package/dist/src/test-runner/max-test-runner-reuse-decorator.d.ts.map +1 -0
- package/dist/src/test-runner/max-test-runner-reuse-decorator.js +25 -0
- package/dist/src/test-runner/max-test-runner-reuse-decorator.js.map +1 -0
- package/dist/src/test-runner/reload-environment-decorator.d.ts +11 -0
- package/dist/src/test-runner/reload-environment-decorator.d.ts.map +1 -0
- package/dist/src/test-runner/reload-environment-decorator.js +56 -0
- package/dist/src/test-runner/reload-environment-decorator.js.map +1 -0
- package/dist/src/test-runner/retry-rejected-decorator.d.ts +15 -0
- package/dist/src/test-runner/retry-rejected-decorator.d.ts.map +1 -0
- package/dist/src/test-runner/retry-rejected-decorator.js +59 -0
- package/dist/src/test-runner/retry-rejected-decorator.js.map +1 -0
- package/dist/src/test-runner/test-runner-decorator.d.ts +8 -0
- package/dist/src/test-runner/test-runner-decorator.d.ts.map +1 -0
- package/dist/src/test-runner/test-runner-decorator.js +13 -0
- package/dist/src/test-runner/test-runner-decorator.js.map +1 -0
- package/dist/src/test-runner/timeout-decorator.d.ts +15 -0
- package/dist/src/test-runner/timeout-decorator.d.ts.map +1 -0
- package/dist/src/test-runner/timeout-decorator.js +51 -0
- package/dist/src/test-runner/timeout-decorator.js.map +1 -0
- package/dist/src/unexpected-exit-handler.d.ts +13 -0
- package/dist/src/unexpected-exit-handler.d.ts.map +1 -0
- package/dist/src/unexpected-exit-handler.js +28 -0
- package/dist/src/unexpected-exit-handler.js.map +1 -0
- package/dist/src/utils/file-utils.d.ts +30 -0
- package/dist/src/utils/file-utils.d.ts.map +1 -0
- package/dist/src/utils/file-utils.js +101 -0
- package/dist/src/utils/file-utils.js.map +1 -0
- package/dist/src/utils/index.d.ts +7 -0
- package/dist/src/utils/index.d.ts.map +1 -0
- package/dist/src/utils/index.js +7 -0
- package/dist/src/utils/index.js.map +1 -0
- package/dist/src/utils/json-rpc-event-deserializer.d.ts +5 -0
- package/dist/src/utils/json-rpc-event-deserializer.d.ts.map +1 -0
- package/dist/src/utils/json-rpc-event-deserializer.js +42 -0
- package/dist/src/utils/json-rpc-event-deserializer.js.map +1 -0
- package/dist/src/utils/object-utils.d.ts +37 -0
- package/dist/src/utils/object-utils.d.ts.map +1 -0
- package/dist/src/utils/object-utils.js +91 -0
- package/dist/src/utils/object-utils.js.map +1 -0
- package/dist/src/utils/string-builder.d.ts +9 -0
- package/dist/src/utils/string-builder.d.ts.map +1 -0
- package/dist/src/utils/string-builder.js +26 -0
- package/dist/src/utils/string-builder.js.map +1 -0
- package/dist/src/utils/string-utils.d.ts +12 -0
- package/dist/src/utils/string-utils.d.ts.map +1 -0
- package/dist/src/utils/string-utils.js +54 -0
- package/dist/src/utils/string-utils.js.map +1 -0
- package/dist/src/utils/temporary-directory.d.ts +18 -0
- package/dist/src/utils/temporary-directory.d.ts.map +1 -0
- package/dist/src/utils/temporary-directory.js +63 -0
- package/dist/src/utils/temporary-directory.js.map +1 -0
- package/dist/src/utils/timer.d.ts +14 -0
- package/dist/src/utils/timer.d.ts.map +1 -0
- package/dist/src/utils/timer.js +53 -0
- package/dist/src/utils/timer.js.map +1 -0
- package/package.json +106 -0
- package/schema/stryker-schema.json +855 -0
- package/src/checker/checker-child-process-proxy.ts +67 -0
- package/src/checker/checker-facade.ts +90 -0
- package/src/checker/checker-factory.ts +46 -0
- package/src/checker/checker-resource.ts +12 -0
- package/src/checker/checker-retry-decorator.ts +57 -0
- package/src/checker/checker-worker.ts +62 -0
- package/src/checker/index.ts +3 -0
- package/src/child-proxy/child-process-crashed-error.ts +16 -0
- package/src/child-proxy/child-process-proxy-worker.ts +203 -0
- package/src/child-proxy/child-process-proxy.ts +353 -0
- package/src/child-proxy/id-generator.ts +6 -0
- package/src/child-proxy/message-protocol.ts +87 -0
- package/src/child-proxy/out-of-memory-error.ts +11 -0
- package/src/concurrent/concurrency-token-provider.ts +106 -0
- package/src/concurrent/index.ts +3 -0
- package/src/concurrent/pool.ts +209 -0
- package/src/concurrent/resource-decorator.ts +28 -0
- package/src/config/config-file-formats.ts +31 -0
- package/src/config/config-reader.ts +193 -0
- package/src/config/file-matcher.ts +36 -0
- package/src/config/index.ts +5 -0
- package/src/config/meta-schema-builder.ts +50 -0
- package/src/config/options-validator.ts +317 -0
- package/src/config/validation-errors.ts +192 -0
- package/src/di/core-tokens.ts +39 -0
- package/src/di/index.ts +4 -0
- package/src/di/plugin-creator.ts +102 -0
- package/src/di/plugin-loader.ts +245 -0
- package/src/errors.ts +12 -0
- package/src/fs/file-system.ts +63 -0
- package/src/fs/index.ts +4 -0
- package/src/fs/project-file.ts +100 -0
- package/src/fs/project-reader.ts +493 -0
- package/src/fs/project.ts +98 -0
- package/src/index.ts +7 -0
- package/src/initializer/custom-initializers/angular-initializer.ts +95 -0
- package/src/initializer/custom-initializers/custom-initializer.ts +14 -0
- package/src/initializer/custom-initializers/index.ts +31 -0
- package/src/initializer/custom-initializers/react-initializer.ts +35 -0
- package/src/initializer/custom-initializers/svelte-initializer.ts +40 -0
- package/src/initializer/custom-initializers/vue-js-initializer.ts +30 -0
- package/src/initializer/gitignore-writer.ts +33 -0
- package/src/initializer/index.ts +35 -0
- package/src/initializer/initializer-tokens.ts +8 -0
- package/src/initializer/inquire.ts +17 -0
- package/src/initializer/npm-client.ts +103 -0
- package/src/initializer/npm-registry.ts +48 -0
- package/src/initializer/package-info.ts +10 -0
- package/src/initializer/prompt-option.ts +6 -0
- package/src/initializer/stryker-config-writer.ts +158 -0
- package/src/initializer/stryker-initializer.ts +278 -0
- package/src/initializer/stryker-inquirer.ts +101 -0
- package/src/logging/index.ts +5 -0
- package/src/logging/logger-impl.ts +81 -0
- package/src/logging/logging-backend.ts +90 -0
- package/src/logging/logging-client.ts +56 -0
- package/src/logging/logging-event.ts +94 -0
- package/src/logging/logging-server.ts +56 -0
- package/src/logging/logging-sink.ts +7 -0
- package/src/logging/priority.ts +15 -0
- package/src/logging/provide-logging.ts +70 -0
- package/src/mutants/diff-statistics-collector.ts +47 -0
- package/src/mutants/incremental-differ.ts +771 -0
- package/src/mutants/index.ts +3 -0
- package/src/mutants/mutant-test-planner.ts +357 -0
- package/src/mutants/test-coverage.ts +125 -0
- package/src/process/1-prepare-executor.ts +133 -0
- package/src/process/2-mutant-instrumenter-executor.ts +122 -0
- package/src/process/3-dry-run-executor.ts +262 -0
- package/src/process/4-mutation-test-executor.ts +272 -0
- package/src/process/index.ts +4 -0
- package/src/reporters/broadcast-reporter.ts +129 -0
- package/src/reporters/ci/circle-provider.ts +50 -0
- package/src/reporters/ci/github-actions-provider.ts +22 -0
- package/src/reporters/ci/provider.ts +42 -0
- package/src/reporters/ci/travis-provider.ts +24 -0
- package/src/reporters/clear-text-reporter.ts +245 -0
- package/src/reporters/clear-text-score-table.ts +305 -0
- package/src/reporters/dashboard-reporter/dashboard-reporter-client.ts +89 -0
- package/src/reporters/dashboard-reporter/dashboard-reporter.ts +97 -0
- package/src/reporters/dashboard-reporter/index.ts +30 -0
- package/src/reporters/dashboard-reporter/report.ts +6 -0
- package/src/reporters/dashboard-reporter/tokens.ts +5 -0
- package/src/reporters/dots-reporter.ts +33 -0
- package/src/reporters/event-recorder-reporter.ts +88 -0
- package/src/reporters/html-reporter.ts +87 -0
- package/src/reporters/index.ts +48 -0
- package/src/reporters/json-reporter.ts +45 -0
- package/src/reporters/mutation-test-report-helper.ts +425 -0
- package/src/reporters/mutation-timings-reporter.ts +78 -0
- package/src/reporters/progress-append-only-reporter.ts +36 -0
- package/src/reporters/progress-bar.ts +6 -0
- package/src/reporters/progress-keeper.ts +113 -0
- package/src/reporters/progress-reporter.ts +62 -0
- package/src/reporters/reporter-util.ts +20 -0
- package/src/reporters/strict-reporter.ts +3 -0
- package/src/sandbox/create-preprocessor.ts +27 -0
- package/src/sandbox/disable-type-checks-preprocessor.ts +70 -0
- package/src/sandbox/file-preprocessor.ts +10 -0
- package/src/sandbox/index.ts +3 -0
- package/src/sandbox/multi-preprocessor.ts +13 -0
- package/src/sandbox/sandbox.ts +198 -0
- package/src/sandbox/ts-config-preprocessor.ts +168 -0
- package/src/stryker-cli.ts +363 -0
- package/src/stryker-package.ts +19 -0
- package/src/stryker-server.ts +334 -0
- package/src/stryker.ts +126 -0
- package/src/test-runner/child-process-test-runner-proxy.ts +94 -0
- package/src/test-runner/child-process-test-runner-worker.ts +66 -0
- package/src/test-runner/command-test-runner.ts +190 -0
- package/src/test-runner/index.ts +74 -0
- package/src/test-runner/max-test-runner-reuse-decorator.ts +41 -0
- package/src/test-runner/reload-environment-decorator.ts +72 -0
- package/src/test-runner/retry-rejected-decorator.ts +79 -0
- package/src/test-runner/test-runner-decorator.ts +22 -0
- package/src/test-runner/timeout-decorator.ts +71 -0
- package/src/unexpected-exit-handler.ts +36 -0
- package/src/utils/file-utils.ts +113 -0
- package/src/utils/index.ts +6 -0
- package/src/utils/json-rpc-event-deserializer.ts +48 -0
- package/src/utils/object-utils.ts +106 -0
- package/src/utils/string-builder.ts +30 -0
- package/src/utils/string-utils.ts +61 -0
- package/src/utils/temporary-directory.ts +83 -0
- 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":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAI1E,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAOvC,MAAM,OAAO,eAAe;IACnB,KAAK,CAAC,aAAa,CACxB,OAA4B;QAE5B,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC;YAClC,OAAO,EAAE;gBACP,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC5B,KAAK,EAAE,IAAI;iBACZ,CAAC,CAAC;gBACH,OAAO,CAAC,SAAS,EAAE;gBACnB,EAAE,KAAK,EAAE,YAAY,EAAE;aACxB;YACD,OAAO,EACL,4EAA4E;SAC/E,CAAC,CAAC;QACH,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;IAChD,CAAC;IAEM,KAAK,CAAC,iBAAiB,CAC5B,OAAuB;QAEvB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC;gBACtC,OAAO,EAAE;oBACP,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;oBAC/C,OAAO,CAAC,SAAS,EAAE;oBACnB,EAAE,KAAK,EAAE,iBAAiB,CAAC,UAAU,EAAE;iBACxC;gBACD,OAAO,EACL,wLAAwL;aAC3L,CAAC,CAAC;YACH,OAAO,CACL,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,UAAU,CAAC,IAAI;gBACjD,IAAI,EAAE,iBAAiB,CAAC,UAAU;gBAClC,GAAG,EAAE,IAAI;aACV,CACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAC3D,CAAC;IACH,CAAC;IAEM,KAAK,CAAC,kBAAkB;QAC7B,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC;YACvC,OAAO,EACL,uJAAuJ;YACzJ,OAAO,EAAE,MAAM;SAChB,CAAC,CAAC;QAEH,OAAO,EAAE,IAAI,EAAE,YAAY,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;IAC1E,CAAC;IAEM,KAAK,CAAC,eAAe,CAC1B,OAAuB;QAEvB,MAAM,QAAQ,GAAG,CAAC,MAAM,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;QACpD,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC;YACvC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;gBAClC,KAAK,EAAE,IAAI;gBACX,OAAO,EAAE,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC;aACjC,CAAC,CAAC;YACH,OAAO,EAAE,uCAAuC;SACjD,CAAC,CAAC;QACH,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAC/B,SAAS,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,YAAY,CAAC,CAC/D,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,oBAAoB,CAC/B,OAAuB;QAEvB,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC;YAC1C,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;YAChD,OAAO,EAAE,KAAK;YACd,OAAO,EAAE,2CAA2C;SACrD,CAAC,CAAC;QACH,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,KAAK,cAAc,CAAE,CAAC;IAC9D,CAAC;IAEM,KAAK,CAAC,sBAAsB;QACjC,MAAM,IAAI,GAAG,MAAM,CAAC;QAEpB,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC;YACxC,OAAO,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;YACnD,OAAO,EAAE,IAAI;YACb,OAAO,EAAE,kDAAkD;SAC5D,CAAC,CAAC;QACH,OAAO,YAAY,KAAK,IAAI,CAAC;IAC/B,CAAC;CACF"}
|
|
@@ -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 @@
|
|
|
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":"AACA,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,MAAM,OAAO,GAAG;IACd,8HAA8H;IAC9H,0DAA0D;CAC3D,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACZ,MAAM,SAAS,GAAG,IAAI,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;AAE3C,MAAM,OAAO,YAAY;IACd,SAAS,CAAC;IACV,YAAY,CAAS;IACrB,IAAI,CAAiB;IACrB,KAAK,CAAW;IAChB,GAAG,CAAS;IAErB,YACE,YAAoB,EACpB,KAAe,EACf,IAAoB,EACpB,SAAe,EACf,GAAW;QAEX,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACjB,CAAC;IAED,MAAM,CAAC,MAAM,CAAC,YAAoB,EAAE,KAAe,EAAE,IAAoB;QACvE,OAAO,IAAI,YAAY,CAAC,YAAY,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,IAAI,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAC9E,CAAC;IAED,MAAM;QACJ,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,EAAE,CAAC;IACnF,CAAC;IAED,eAAe;QACb,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,IAAI,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;IAC5G,CAAC;IAED,aAAa;QACX,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,GAAG,KAAK,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;IACvH,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IACD,eAAe;QACb,OAAO,QAAQ,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;IACvC,CAAC;IACD,aAAa;QACX,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,GAA2B;QAC5C,OAAO,IAAI,YAAY,CACrB,GAAG,CAAC,YAAY,EAChB,GAAG,CAAC,KAAK,EACT,CAAC,GAAG,CAAC,OAAO,CAAC,EACb,IAAI,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,EACvB,GAAG,CAAC,GAAG,CACR,CAAC;IACJ,CAAC;IAED,SAAS;QACP,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;YAClC,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,IAAI,CAAC,cAAc,EAAE;YAC9B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC;IACJ,CAAC;CACF;AAUD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;IAC3B,KAAK,EAAE,EAAE,EAAE,OAAO;IAClB,KAAK,EAAE,EAAE,EAAE,OAAO;IAClB,IAAI,EAAE,EAAE,EAAE,QAAQ;IAClB,IAAI,EAAE,EAAE,EAAE,SAAS;IACnB,KAAK,EAAE,EAAE,EAAE,MAAM;IACjB,KAAK,EAAE,EAAE,EAAE,UAAU;IACrB,GAAG,EAAE,EAAE,EAAE,OAAO;CACjB,CAAC,CAAC"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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"}
|