@servicetitan/startup 30.3.1 → 31.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/index.js +5 -6
- package/dist/cli/commands/build.d.ts +10 -3
- package/dist/cli/commands/build.d.ts.map +1 -1
- package/dist/cli/commands/build.js +119 -49
- package/dist/cli/commands/build.js.map +1 -1
- package/dist/cli/commands/bundle-package.d.ts +0 -2
- package/dist/cli/commands/bundle-package.d.ts.map +1 -1
- package/dist/cli/commands/bundle-package.js +54 -36
- package/dist/cli/commands/bundle-package.js.map +1 -1
- package/dist/cli/commands/clean.d.ts +6 -0
- package/dist/cli/commands/clean.d.ts.map +1 -0
- package/dist/cli/commands/clean.js +55 -0
- package/dist/cli/commands/clean.js.map +1 -0
- package/dist/cli/commands/convert-eslint-config.js +163 -107
- package/dist/cli/commands/convert-eslint-config.js.map +1 -1
- package/dist/cli/commands/eslint.d.ts.map +1 -1
- package/dist/cli/commands/eslint.js +43 -24
- package/dist/cli/commands/eslint.js.map +1 -1
- package/dist/cli/commands/get-command.d.ts.map +1 -1
- package/dist/cli/commands/get-command.js +50 -53
- package/dist/cli/commands/get-command.js.map +1 -1
- package/dist/cli/commands/get-user-commands.js +21 -11
- package/dist/cli/commands/get-user-commands.js.map +1 -1
- package/dist/cli/commands/index.d.ts +1 -1
- package/dist/cli/commands/index.d.ts.map +1 -1
- package/dist/cli/commands/index.js +31 -30
- package/dist/cli/commands/index.js.map +1 -1
- package/dist/cli/commands/init.js +74 -48
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/install.d.ts +8 -1
- package/dist/cli/commands/install.d.ts.map +1 -1
- package/dist/cli/commands/install.js +61 -23
- package/dist/cli/commands/install.js.map +1 -1
- package/dist/cli/commands/kendo-ui-license.js +48 -31
- package/dist/cli/commands/kendo-ui-license.js.map +1 -1
- package/dist/cli/commands/lint.d.ts +3 -1
- package/dist/cli/commands/lint.d.ts.map +1 -1
- package/dist/cli/commands/lint.js +112 -73
- package/dist/cli/commands/lint.js.map +1 -1
- package/dist/cli/commands/mfe-package-clean.js +80 -57
- package/dist/cli/commands/mfe-package-clean.js.map +1 -1
- package/dist/cli/commands/mfe-package-publish.d.ts +1 -0
- package/dist/cli/commands/mfe-package-publish.d.ts.map +1 -1
- package/dist/cli/commands/mfe-package-publish.js +124 -70
- package/dist/cli/commands/mfe-package-publish.js.map +1 -1
- package/dist/cli/commands/mfe-publish.d.ts.map +1 -1
- package/dist/cli/commands/mfe-publish.js +83 -48
- package/dist/cli/commands/mfe-publish.js.map +1 -1
- package/dist/cli/commands/prepare-package.d.ts +1 -1
- package/dist/cli/commands/prepare-package.d.ts.map +1 -1
- package/dist/cli/commands/prepare-package.js +43 -33
- package/dist/cli/commands/prepare-package.js.map +1 -1
- package/dist/cli/commands/review/index.d.ts +3 -0
- package/dist/cli/commands/review/index.d.ts.map +1 -0
- package/dist/cli/commands/review/index.js +20 -0
- package/dist/cli/commands/review/index.js.map +1 -0
- package/dist/cli/commands/review/review.d.ts +28 -0
- package/dist/cli/commands/review/review.d.ts.map +1 -0
- package/dist/cli/commands/review/review.js +239 -0
- package/dist/cli/commands/review/review.js.map +1 -0
- package/dist/cli/commands/review/rules/index.d.ts +3 -0
- package/dist/cli/commands/review/rules/index.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/index.js +30 -0
- package/dist/cli/commands/review/rules/index.js.map +1 -0
- package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts +14 -0
- package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/no-typescript-entry-point.js +89 -0
- package/dist/cli/commands/review/rules/no-typescript-entry-point.js.map +1 -0
- package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts +7 -0
- package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-explicit-side-effects.js +37 -0
- package/dist/cli/commands/review/rules/require-explicit-side-effects.js.map +1 -0
- package/dist/cli/commands/review/rules/require-npmrc.d.ts +7 -0
- package/dist/cli/commands/review/rules/require-npmrc.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-npmrc.js +38 -0
- package/dist/cli/commands/review/rules/require-npmrc.js.map +1 -0
- package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts +5 -0
- package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js +33 -0
- package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js.map +1 -0
- package/dist/cli/commands/review/rules/require-one-collection-version.d.ts +45 -0
- package/dist/cli/commands/review/rules/require-one-collection-version.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-one-collection-version.js +140 -0
- package/dist/cli/commands/review/rules/require-one-collection-version.js.map +1 -0
- package/dist/cli/commands/review/rules/require-one-package-version.d.ts +20 -0
- package/dist/cli/commands/review/rules/require-one-package-version.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-one-package-version.js +70 -0
- package/dist/cli/commands/review/rules/require-one-package-version.js.map +1 -0
- package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts +5 -0
- package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-one-uikit-version.js +40 -0
- package/dist/cli/commands/review/rules/require-one-uikit-version.js.map +1 -0
- package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts +19 -0
- package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js +103 -0
- package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js.map +1 -0
- package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts +7 -0
- package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/require-servicetitan-scope.js +37 -0
- package/dist/cli/commands/review/rules/require-servicetitan-scope.js.map +1 -0
- package/dist/cli/commands/review/types.d.ts +72 -0
- package/dist/cli/commands/review/types.d.ts.map +1 -0
- package/dist/cli/commands/review/types.js +36 -0
- package/dist/cli/commands/review/types.js.map +1 -0
- package/dist/cli/commands/review/utils/apply-filter.d.ts +3 -0
- package/dist/cli/commands/review/utils/apply-filter.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/apply-filter.js +20 -0
- package/dist/cli/commands/review/utils/apply-filter.js.map +1 -0
- package/dist/cli/commands/review/utils/collate-dependencies.d.ts +29 -0
- package/dist/cli/commands/review/utils/collate-dependencies.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/collate-dependencies.js +31 -0
- package/dist/cli/commands/review/utils/collate-dependencies.js.map +1 -0
- package/dist/cli/commands/review/utils/compare-version.d.ts +9 -0
- package/dist/cli/commands/review/utils/compare-version.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/compare-version.js +137 -0
- package/dist/cli/commands/review/utils/compare-version.js.map +1 -0
- package/dist/cli/commands/review/utils/format-depends-on.d.ts +2 -0
- package/dist/cli/commands/review/utils/format-depends-on.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/format-depends-on.js +21 -0
- package/dist/cli/commands/review/utils/format-depends-on.js.map +1 -0
- package/dist/cli/commands/review/utils/format-location.d.ts +2 -0
- package/dist/cli/commands/review/utils/format-location.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/format-location.js +25 -0
- package/dist/cli/commands/review/utils/format-location.js.map +1 -0
- package/dist/cli/commands/review/utils/get-key.d.ts +3 -0
- package/dist/cli/commands/review/utils/get-key.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/get-key.js +20 -0
- package/dist/cli/commands/review/utils/get-key.js.map +1 -0
- package/dist/cli/commands/review/utils/get-max-version.d.ts +2 -0
- package/dist/cli/commands/review/utils/get-max-version.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/get-max-version.js +16 -0
- package/dist/cli/commands/review/utils/get-max-version.js.map +1 -0
- package/dist/cli/commands/review/utils/indent.d.ts +2 -0
- package/dist/cli/commands/review/utils/indent.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/indent.js +17 -0
- package/dist/cli/commands/review/utils/indent.js.map +1 -0
- package/dist/cli/commands/review/utils/index.d.ts +14 -0
- package/dist/cli/commands/review/utils/index.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/index.js +32 -0
- package/dist/cli/commands/review/utils/index.js.map +1 -0
- package/dist/cli/commands/review/utils/is-library.d.ts +3 -0
- package/dist/cli/commands/review/utils/is-library.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/is-library.js +15 -0
- package/dist/cli/commands/review/utils/is-library.js.map +1 -0
- package/dist/cli/commands/review/utils/name-to-location.d.ts +3 -0
- package/dist/cli/commands/review/utils/name-to-location.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/name-to-location.js +18 -0
- package/dist/cli/commands/review/utils/name-to-location.js.map +1 -0
- package/dist/cli/commands/review/utils/pluralize.d.ts +2 -0
- package/dist/cli/commands/review/utils/pluralize.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/pluralize.js +15 -0
- package/dist/cli/commands/review/utils/pluralize.js.map +1 -0
- package/dist/cli/commands/review/utils/set-version.d.ts +10 -0
- package/dist/cli/commands/review/utils/set-version.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/set-version.js +33 -0
- package/dist/cli/commands/review/utils/set-version.js.map +1 -0
- package/dist/cli/commands/review/utils/summarize.d.ts +11 -0
- package/dist/cli/commands/review/utils/summarize.d.ts.map +1 -0
- package/dist/cli/commands/review/utils/summarize.js +30 -0
- package/dist/cli/commands/review/utils/summarize.js.map +1 -0
- package/dist/cli/commands/run-task.js +50 -31
- package/dist/cli/commands/run-task.js.map +1 -1
- package/dist/cli/commands/run-task.test.d.ts +2 -0
- package/dist/cli/commands/run-task.test.d.ts.map +1 -0
- package/dist/cli/commands/run-task.test.js +59 -0
- package/dist/cli/commands/run-task.test.js.map +1 -0
- package/dist/cli/commands/start.d.ts +11 -3
- package/dist/cli/commands/start.d.ts.map +1 -1
- package/dist/cli/commands/start.js +158 -70
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/commands/styles-check.js +73 -59
- package/dist/cli/commands/styles-check.js.map +1 -1
- package/dist/cli/commands/tests.d.ts +1 -0
- package/dist/cli/commands/tests.d.ts.map +1 -1
- package/dist/cli/commands/tests.js +45 -28
- package/dist/cli/commands/tests.js.map +1 -1
- package/dist/cli/commands/types.d.ts +1 -0
- package/dist/cli/commands/types.d.ts.map +1 -1
- package/dist/cli/commands/types.js +4 -1
- package/dist/cli/commands/types.js.map +1 -1
- package/dist/cli/index.js +43 -34
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/tasks/cli-task.d.ts +0 -1
- package/dist/cli/tasks/cli-task.d.ts.map +1 -1
- package/dist/cli/tasks/cli-task.js +52 -41
- package/dist/cli/tasks/cli-task.js.map +1 -1
- package/dist/cli/tasks/swc-cli.d.js +3 -0
- package/dist/cli/tasks/swc-cli.d.js.map +1 -0
- package/dist/cli/tasks/swc-compile-package.d.ts +0 -1
- package/dist/cli/tasks/swc-compile-package.d.ts.map +1 -1
- package/dist/cli/tasks/swc-compile-package.js +78 -34
- package/dist/cli/tasks/swc-compile-package.js.map +1 -1
- package/dist/cli/tasks/task.d.ts +0 -2
- package/dist/cli/tasks/task.d.ts.map +1 -1
- package/dist/cli/tasks/task.js +60 -65
- package/dist/cli/tasks/task.js.map +1 -1
- package/dist/cli/tasks/tsc-compile-package.d.ts +0 -1
- package/dist/cli/tasks/tsc-compile-package.d.ts.map +1 -1
- package/dist/cli/tasks/tsc-compile-package.js +26 -22
- package/dist/cli/tasks/tsc-compile-package.js.map +1 -1
- package/dist/cli/tasks/tsc-compile.d.ts +0 -2
- package/dist/cli/tasks/tsc-compile.d.ts.map +1 -1
- package/dist/cli/tasks/tsc-compile.js +51 -31
- package/dist/cli/tasks/tsc-compile.js.map +1 -1
- package/dist/cli/types/cpx2.d.js +3 -0
- package/dist/cli/types/cpx2.d.js.map +1 -0
- package/dist/cli/utils/bundle.d.ts +2 -4
- package/dist/cli/utils/bundle.d.ts.map +1 -1
- package/dist/cli/utils/bundle.js +136 -74
- package/dist/cli/utils/bundle.js.map +1 -1
- package/dist/cli/utils/check-args.d.ts +6 -0
- package/dist/cli/utils/check-args.d.ts.map +1 -0
- package/dist/cli/utils/check-args.js +20 -0
- package/dist/cli/utils/check-args.js.map +1 -0
- package/dist/cli/utils/cli-git.js +23 -9
- package/dist/cli/utils/cli-git.js.map +1 -1
- package/dist/cli/utils/cli-npm.js +62 -23
- package/dist/cli/utils/cli-npm.js.map +1 -1
- package/dist/cli/utils/cli-os.js +34 -33
- package/dist/cli/utils/cli-os.js.map +1 -1
- package/dist/cli/utils/compile-less.d.ts.map +1 -1
- package/dist/cli/utils/compile-less.js +27 -11
- package/dist/cli/utils/compile-less.js.map +1 -1
- package/dist/cli/utils/compile-sass.d.ts.map +1 -1
- package/dist/cli/utils/compile-sass.js +25 -9
- package/dist/cli/utils/compile-sass.js.map +1 -1
- package/dist/cli/utils/compile.d.ts +6 -0
- package/dist/cli/utils/compile.d.ts.map +1 -0
- package/dist/cli/utils/compile.js +33 -0
- package/dist/cli/utils/compile.js.map +1 -0
- package/dist/cli/utils/copy-files.d.ts +8 -0
- package/dist/cli/utils/copy-files.d.ts.map +1 -0
- package/dist/cli/utils/copy-files.js +119 -0
- package/dist/cli/utils/copy-files.js.map +1 -0
- package/dist/cli/utils/eslint.d.ts.map +1 -1
- package/dist/cli/utils/eslint.js +22 -12
- package/dist/cli/utils/eslint.js.map +1 -1
- package/dist/cli/utils/get-module-type.d.ts.map +1 -1
- package/dist/cli/utils/get-module-type.js +12 -18
- package/dist/cli/utils/get-module-type.js.map +1 -1
- package/dist/cli/utils/index.d.ts +8 -6
- package/dist/cli/utils/index.d.ts.map +1 -1
- package/dist/cli/utils/index.js +33 -30
- package/dist/cli/utils/index.js.map +1 -1
- package/dist/cli/utils/is-module-installed.js +11 -4
- package/dist/cli/utils/is-module-installed.js.map +1 -1
- package/dist/cli/utils/lerna-exec.d.ts +4 -3
- package/dist/cli/utils/lerna-exec.d.ts.map +1 -1
- package/dist/cli/utils/lerna-exec.js +40 -19
- package/dist/cli/utils/lerna-exec.js.map +1 -1
- package/dist/cli/utils/maybe-create-git-folder.js +20 -18
- package/dist/cli/utils/maybe-create-git-folder.js.map +1 -1
- package/dist/cli/utils/pipe-stdout.d.ts +3 -0
- package/dist/cli/utils/pipe-stdout.d.ts.map +1 -0
- package/dist/cli/utils/pipe-stdout.js +19 -0
- package/dist/cli/utils/pipe-stdout.js.map +1 -0
- package/dist/cli/utils/process-tree.d.ts +14 -0
- package/dist/cli/utils/process-tree.d.ts.map +1 -0
- package/dist/cli/utils/process-tree.js +78 -0
- package/dist/cli/utils/process-tree.js.map +1 -0
- package/dist/cli/utils/publish.js +12 -6
- package/dist/cli/utils/publish.js.map +1 -1
- package/dist/cli/utils/set-node-options.d.ts +2 -1
- package/dist/cli/utils/set-node-options.d.ts.map +1 -1
- package/dist/cli/utils/set-node-options.js +39 -30
- package/dist/cli/utils/set-node-options.js.map +1 -1
- package/dist/cli/utils/ts-config.d.ts +11 -0
- package/dist/cli/utils/ts-config.d.ts.map +1 -0
- package/dist/cli/utils/ts-config.js +80 -0
- package/dist/cli/utils/ts-config.js.map +1 -0
- package/dist/cli/utils/type-check.d.ts +7 -0
- package/dist/cli/utils/type-check.d.ts.map +1 -0
- package/dist/cli/utils/type-check.js +33 -0
- package/dist/cli/utils/type-check.js.map +1 -0
- package/dist/cli/utils/watch-stdout.d.ts +3 -0
- package/dist/cli/utils/watch-stdout.d.ts.map +1 -0
- package/dist/cli/utils/watch-stdout.js +26 -0
- package/dist/cli/utils/watch-stdout.js.map +1 -0
- package/dist/index.js +20 -18
- package/dist/index.js.map +1 -1
- package/dist/jest/index.js +12 -4
- package/dist/jest/index.js.map +1 -1
- package/dist/utils/debug.js +23 -11
- package/dist/utils/debug.js.map +1 -1
- package/dist/utils/find-packages.d.ts.map +1 -1
- package/dist/utils/find-packages.js +46 -34
- package/dist/utils/find-packages.js.map +1 -1
- package/dist/utils/format-duration.d.ts +2 -0
- package/dist/utils/format-duration.d.ts.map +1 -0
- package/dist/utils/format-duration.js +24 -0
- package/dist/utils/format-duration.js.map +1 -0
- package/dist/utils/get-branch-configs.js +24 -8
- package/dist/utils/get-branch-configs.js.map +1 -1
- package/dist/utils/get-configuration.d.ts +11 -2
- package/dist/utils/get-configuration.d.ts.map +1 -1
- package/dist/utils/get-configuration.js +134 -52
- package/dist/utils/get-configuration.js.map +1 -1
- package/dist/utils/get-destination-folders.js +25 -18
- package/dist/utils/get-destination-folders.js.map +1 -1
- package/dist/utils/get-folders.d.ts +2 -2
- package/dist/utils/get-folders.d.ts.map +1 -1
- package/dist/utils/get-folders.js +20 -13
- package/dist/utils/get-folders.js.map +1 -1
- package/dist/utils/get-jest-config.js +65 -38
- package/dist/utils/get-jest-config.js.map +1 -1
- package/dist/utils/get-package-data.js +26 -12
- package/dist/utils/get-package-data.js.map +1 -1
- package/dist/utils/get-package-name.js +18 -8
- package/dist/utils/get-package-name.js.map +1 -1
- package/dist/utils/get-packages.d.ts +1 -1
- package/dist/utils/get-packages.d.ts.map +1 -1
- package/dist/utils/get-packages.js +72 -57
- package/dist/utils/get-packages.js.map +1 -1
- package/dist/utils/get-startup-version.js +18 -8
- package/dist/utils/get-startup-version.js.map +1 -1
- package/dist/utils/get-tsconfig.js +19 -12
- package/dist/utils/get-tsconfig.js.map +1 -1
- package/dist/utils/index.d.ts +3 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +34 -29
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/load-shared-dependencies.js +23 -17
- package/dist/utils/load-shared-dependencies.js.map +1 -1
- package/dist/utils/log-errors.d.ts +2 -0
- package/dist/utils/log-errors.d.ts.map +1 -0
- package/dist/utils/log-errors.js +36 -0
- package/dist/utils/log-errors.js.map +1 -0
- package/dist/utils/log.d.ts +0 -1
- package/dist/utils/log.d.ts.map +1 -1
- package/dist/utils/log.js +38 -43
- package/dist/utils/log.js.map +1 -1
- package/dist/utils/pick.js +11 -3
- package/dist/utils/pick.js.map +1 -1
- package/dist/utils/read-json.js +27 -11
- package/dist/utils/read-json.js.map +1 -1
- package/dist/utils/to-array.js +13 -3
- package/dist/utils/to-array.js.map +1 -1
- package/dist/webpack/configs/amd-config.js +13 -3
- package/dist/webpack/configs/amd-config.js.map +1 -1
- package/dist/webpack/configs/dev-server-config.d.ts +1 -1
- package/dist/webpack/configs/dev-server-config.d.ts.map +1 -1
- package/dist/webpack/configs/dev-server-config.js +47 -45
- package/dist/webpack/configs/dev-server-config.js.map +1 -1
- package/dist/webpack/configs/devtool-config.js +16 -7
- package/dist/webpack/configs/devtool-config.js.map +1 -1
- package/dist/webpack/configs/entry.config.d.ts.map +1 -1
- package/dist/webpack/configs/entry.config.js +28 -7
- package/dist/webpack/configs/entry.config.js.map +1 -1
- package/dist/webpack/configs/externals-config.js +17 -7
- package/dist/webpack/configs/externals-config.js.map +1 -1
- package/dist/webpack/configs/index.d.ts +2 -2
- package/dist/webpack/configs/index.d.ts.map +1 -1
- package/dist/webpack/configs/index.js +29 -28
- package/dist/webpack/configs/index.js.map +1 -1
- package/dist/webpack/configs/loaders/css-loader.js +22 -14
- package/dist/webpack/configs/loaders/css-loader.js.map +1 -1
- package/dist/webpack/configs/loaders/index.d.ts +1 -1
- package/dist/webpack/configs/loaders/index.d.ts.map +1 -1
- package/dist/webpack/configs/loaders/index.js +20 -19
- package/dist/webpack/configs/loaders/index.js.map +1 -1
- package/dist/webpack/configs/loaders/less-loader.js +18 -3
- package/dist/webpack/configs/loaders/less-loader.js.map +1 -1
- package/dist/webpack/configs/loaders/style-loader.js +23 -8
- package/dist/webpack/configs/loaders/style-loader.js.map +1 -1
- package/dist/webpack/configs/loaders/types.js +4 -1
- package/dist/webpack/configs/loaders/types.js.map +1 -1
- package/dist/webpack/configs/module-config.js +17 -5
- package/dist/webpack/configs/module-config.js.map +1 -1
- package/dist/webpack/configs/optimization-config.js +60 -34
- package/dist/webpack/configs/optimization-config.js.map +1 -1
- package/dist/webpack/configs/output-config.d.ts.map +1 -1
- package/dist/webpack/configs/output-config.js +28 -13
- package/dist/webpack/configs/output-config.js.map +1 -1
- package/dist/webpack/configs/plugins/assets-manifest-plugin.js +23 -14
- package/dist/webpack/configs/plugins/assets-manifest-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/bundle-analyser-plugin.js +19 -9
- package/dist/webpack/configs/plugins/bundle-analyser-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js +19 -11
- package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js +17 -7
- package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/define-web-component-name-plugin.js +13 -5
- package/dist/webpack/configs/plugins/define-web-component-name-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/filter-warnings-plugin.js +11 -3
- package/dist/webpack/configs/plugins/filter-warnings-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/html-plugin.d.ts +1 -1
- package/dist/webpack/configs/plugins/html-plugin.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/html-plugin.js +30 -22
- package/dist/webpack/configs/plugins/html-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js +24 -13
- package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js +26 -16
- package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js +15 -6
- package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/index.js +18 -16
- package/dist/webpack/configs/plugins/ignore-plugin/index.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js +22 -12
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js.map +1 -1
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js +11 -4
- package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js.map +1 -1
- package/dist/webpack/configs/plugins/index.d.ts +0 -2
- package/dist/webpack/configs/plugins/index.d.ts.map +1 -1
- package/dist/webpack/configs/plugins/index.js +29 -29
- package/dist/webpack/configs/plugins/index.js.map +1 -1
- package/dist/webpack/configs/plugins/mini-css-extract-plugin.js +23 -12
- package/dist/webpack/configs/plugins/mini-css-extract-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/moment-locales-plugin.js +18 -8
- package/dist/webpack/configs/plugins/moment-locales-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/virtual-modules-plugin.js +44 -24
- package/dist/webpack/configs/plugins/virtual-modules-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins/watch-run-plugin.js +23 -15
- package/dist/webpack/configs/plugins/watch-run-plugin.js.map +1 -1
- package/dist/webpack/configs/plugins-config.d.ts.map +1 -1
- package/dist/webpack/configs/plugins-config.js +27 -21
- package/dist/webpack/configs/plugins-config.js.map +1 -1
- package/dist/webpack/configs/resolve-config.js +16 -4
- package/dist/webpack/configs/resolve-config.js.map +1 -1
- package/dist/webpack/configs/rules/css-rules.js +43 -18
- package/dist/webpack/configs/rules/css-rules.js.map +1 -1
- package/dist/webpack/configs/rules/font-rules.js +13 -5
- package/dist/webpack/configs/rules/font-rules.js.map +1 -1
- package/dist/webpack/configs/rules/image-rules.js +13 -5
- package/dist/webpack/configs/rules/image-rules.js.map +1 -1
- package/dist/webpack/configs/rules/index.d.ts +0 -1
- package/dist/webpack/configs/rules/index.d.ts.map +1 -1
- package/dist/webpack/configs/rules/index.js +24 -23
- package/dist/webpack/configs/rules/index.js.map +1 -1
- package/dist/webpack/configs/rules/js-rules.d.ts +1 -1
- package/dist/webpack/configs/rules/js-rules.d.ts.map +1 -1
- package/dist/webpack/configs/rules/js-rules.js +47 -7
- package/dist/webpack/configs/rules/js-rules.js.map +1 -1
- package/dist/webpack/configs/rules/less-rules.js +25 -9
- package/dist/webpack/configs/rules/less-rules.js.map +1 -1
- package/dist/webpack/configs/rules/scss-rules.js +25 -9
- package/dist/webpack/configs/rules/scss-rules.js.map +1 -1
- package/dist/webpack/configs/rules/svg-rules.js +40 -20
- package/dist/webpack/configs/rules/svg-rules.js.map +1 -1
- package/dist/webpack/configs/rules-config.d.ts.map +1 -1
- package/dist/webpack/configs/rules-config.js +34 -19
- package/dist/webpack/configs/rules-config.js.map +1 -1
- package/dist/webpack/configs/stats-config.js +14 -4
- package/dist/webpack/configs/stats-config.js.map +1 -1
- package/dist/webpack/configs/types.d.ts +1 -3
- package/dist/webpack/configs/types.d.ts.map +1 -1
- package/dist/webpack/configs/types.js +4 -1
- package/dist/webpack/configs/types.js.map +1 -1
- package/dist/webpack/configs/utils/generate-metadata.d.ts.map +1 -1
- package/dist/webpack/configs/utils/generate-metadata.js +44 -22
- package/dist/webpack/configs/utils/generate-metadata.js.map +1 -1
- package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js +20 -11
- package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js.map +1 -1
- package/dist/webpack/configs/utils/get-web-components-version.js +18 -8
- package/dist/webpack/configs/utils/get-web-components-version.js.map +1 -1
- package/dist/webpack/configs/utils/index.js +18 -16
- package/dist/webpack/configs/utils/index.js.map +1 -1
- package/dist/webpack/configs/watch-options-config.d.ts +6 -0
- package/dist/webpack/configs/watch-options-config.d.ts.map +1 -0
- package/dist/webpack/configs/watch-options-config.js +24 -0
- package/dist/webpack/configs/watch-options-config.js.map +1 -0
- package/dist/webpack/create-webpack-config.d.ts.map +1 -1
- package/dist/webpack/create-webpack-config.js +61 -50
- package/dist/webpack/create-webpack-config.js.map +1 -1
- package/dist/webpack/index.d.ts +1 -1
- package/dist/webpack/index.d.ts.map +1 -1
- package/dist/webpack/index.js +18 -17
- package/dist/webpack/index.js.map +1 -1
- package/dist/webpack/loaders/expose-loader/index.js +15 -15
- package/dist/webpack/loaders/expose-loader/index.js.map +1 -1
- package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js +5 -6
- package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js.map +1 -1
- package/dist/webpack/loaders/expose-loader/utils/contextify-request.js +20 -13
- package/dist/webpack/loaders/expose-loader/utils/contextify-request.js.map +1 -1
- package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js +22 -11
- package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js.map +1 -1
- package/dist/webpack/loaders/expose-loader/utils/index.js +20 -18
- package/dist/webpack/loaders/expose-loader/utils/index.js.map +1 -1
- package/dist/webpack/loaders/expose-loader/utils/stringify-request.js +20 -12
- package/dist/webpack/loaders/expose-loader/utils/stringify-request.js.map +1 -1
- package/dist/webpack/types.d.ts +1 -4
- package/dist/webpack/types.d.ts.map +1 -1
- package/dist/webpack/types.js +4 -1
- package/dist/webpack/types.js.map +1 -1
- package/dist/webpack/utils/get-caller-filename.js +14 -7
- package/dist/webpack/utils/get-caller-filename.js.map +1 -1
- package/dist/webpack/utils/{bundle.d.ts → get-module-entry-path.d.ts} +1 -1
- package/dist/webpack/utils/get-module-entry-path.d.ts.map +1 -0
- package/dist/webpack/utils/get-module-entry-path.js +21 -0
- package/dist/webpack/utils/get-module-entry-path.js.map +1 -0
- package/dist/webpack/utils/index.d.ts +1 -2
- package/dist/webpack/utils/index.d.ts.map +1 -1
- package/dist/webpack/utils/index.js +20 -19
- package/dist/webpack/utils/index.js.map +1 -1
- package/dist/webpack/utils/split-by-entry.js +17 -7
- package/dist/webpack/utils/split-by-entry.js.map +1 -1
- package/dist/webpack/utils/testing/compile.js +12 -4
- package/dist/webpack/utils/testing/compile.js.map +1 -1
- package/dist/webpack/utils/testing/execute.js +26 -13
- package/dist/webpack/utils/testing/execute.js.map +1 -1
- package/dist/webpack/utils/testing/get-compiler.js +34 -24
- package/dist/webpack/utils/testing/get-compiler.js.map +1 -1
- package/dist/webpack/utils/testing/get-errors.js +12 -4
- package/dist/webpack/utils/testing/get-errors.js.map +1 -1
- package/dist/webpack/utils/testing/get-module-source.js +18 -5
- package/dist/webpack/utils/testing/get-module-source.js.map +1 -1
- package/dist/webpack/utils/testing/get-warnings.js +12 -4
- package/dist/webpack/utils/testing/get-warnings.js.map +1 -1
- package/dist/webpack/utils/testing/index.js +28 -20
- package/dist/webpack/utils/testing/index.js.map +1 -1
- package/dist/webpack/utils/testing/normalize-errors.js +11 -3
- package/dist/webpack/utils/testing/normalize-errors.js.map +1 -1
- package/dist/webpack/utils/testing/read-asset.js +20 -11
- package/dist/webpack/utils/testing/read-asset.js.map +1 -1
- package/dist/webpack/utils/testing/read-assets.js +13 -5
- package/dist/webpack/utils/testing/read-assets.js.map +1 -1
- package/package.json +22 -23
- package/src/cli/commands/__tests__/build.test.ts +66 -43
- package/src/cli/commands/__tests__/clean.test.ts +32 -0
- package/src/cli/commands/__tests__/install.test.ts +50 -8
- package/src/cli/commands/__tests__/kendo-ui-license.test.ts +5 -5
- package/src/cli/commands/__tests__/lint.test.ts +4 -0
- package/src/cli/commands/__tests__/mfe-package-publish.test.ts +21 -2
- package/src/cli/commands/__tests__/mfe-publish.test.ts +19 -23
- package/src/cli/commands/__tests__/prepare-package.test.ts +6 -48
- package/src/cli/commands/__tests__/start.test.ts +77 -42
- package/src/cli/commands/__tests__/tests.test.ts +4 -0
- package/src/cli/commands/build.ts +71 -35
- package/src/cli/commands/bundle-package.ts +0 -4
- package/src/cli/commands/clean.ts +24 -0
- package/src/cli/commands/eslint.ts +1 -1
- package/src/cli/commands/get-command.ts +25 -35
- package/src/cli/commands/index.ts +1 -1
- package/src/cli/commands/install.ts +29 -8
- package/src/cli/commands/lint.ts +22 -17
- package/src/cli/commands/mfe-package-publish.ts +22 -5
- package/src/cli/commands/mfe-publish.ts +5 -18
- package/src/cli/commands/prepare-package.ts +5 -12
- package/src/cli/commands/review/__mocks__/expect-calls.ts +48 -0
- package/src/cli/commands/review/__mocks__/index.ts +1 -0
- package/src/cli/commands/review/__tests__/review.test.ts +483 -0
- package/src/cli/commands/review/index.ts +3 -0
- package/src/cli/commands/review/review.ts +247 -0
- package/src/cli/commands/review/rules/__mocks__/index.ts +3 -0
- package/src/cli/commands/review/rules/__mocks__/mock-config.ts +14 -0
- package/src/cli/commands/review/rules/__mocks__/mock-packages.ts +41 -0
- package/src/cli/commands/review/rules/__mocks__/mock-project.ts +11 -0
- package/src/cli/commands/review/rules/__tests__/no-typescript-entry-point.test.ts +166 -0
- package/src/cli/commands/review/rules/__tests__/require-explicit-side-effects.test.ts +113 -0
- package/src/cli/commands/review/rules/__tests__/require-npmrc.test.ts +71 -0
- package/src/cli/commands/review/rules/__tests__/require-one-anvil-uikit-contrib-version.test.ts +33 -0
- package/src/cli/commands/review/rules/__tests__/require-one-collection-version.test.ts +155 -0
- package/src/cli/commands/review/rules/__tests__/require-one-package-version.test.ts +135 -0
- package/src/cli/commands/review/rules/__tests__/require-one-uikit-version.ts +40 -0
- package/src/cli/commands/review/rules/__tests__/require-project-version-in-root-node-modules.test.ts +186 -0
- package/src/cli/commands/review/rules/__tests__/require-servicetitan-scope.test.ts +83 -0
- package/src/cli/commands/review/rules/index.ts +20 -0
- package/src/cli/commands/review/rules/no-typescript-entry-point.ts +78 -0
- package/src/cli/commands/review/rules/require-explicit-side-effects.ts +31 -0
- package/src/cli/commands/review/rules/require-npmrc.ts +27 -0
- package/src/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.ts +20 -0
- package/src/cli/commands/review/rules/require-one-collection-version.ts +169 -0
- package/src/cli/commands/review/rules/require-one-package-version.ts +76 -0
- package/src/cli/commands/review/rules/require-one-uikit-version.ts +27 -0
- package/src/cli/commands/review/rules/require-project-version-in-root-node-modules.ts +104 -0
- package/src/cli/commands/review/rules/require-servicetitan-scope.ts +27 -0
- package/src/cli/commands/review/types.ts +72 -0
- package/src/cli/commands/review/utils/__tests__/compare-version.test.ts +73 -0
- package/src/cli/commands/review/utils/__tests__/get-max-version.test.ts +17 -0
- package/src/cli/commands/review/utils/__tests__/indent.test.ts +41 -0
- package/src/cli/commands/review/utils/__tests__/name-to-location.test.ts +39 -0
- package/src/cli/commands/review/utils/__tests__/set-version.test.ts +84 -0
- package/src/cli/commands/review/utils/apply-filter.ts +14 -0
- package/src/cli/commands/review/utils/collate-dependencies.ts +46 -0
- package/src/cli/commands/review/utils/compare-version.ts +82 -0
- package/src/cli/commands/review/utils/format-depends-on.ts +11 -0
- package/src/cli/commands/review/utils/format-location.ts +8 -0
- package/src/cli/commands/review/utils/get-key.ts +10 -0
- package/src/cli/commands/review/utils/get-max-version.ts +5 -0
- package/src/cli/commands/review/utils/indent.ts +8 -0
- package/src/cli/commands/review/utils/index.ts +13 -0
- package/src/cli/commands/review/utils/is-library.ts +5 -0
- package/src/cli/commands/review/utils/name-to-location.ts +7 -0
- package/src/cli/commands/review/utils/pluralize.ts +3 -0
- package/src/cli/commands/review/utils/set-version.ts +26 -0
- package/src/cli/commands/review/utils/summarize.ts +21 -0
- package/src/cli/commands/run-task.test.ts +60 -0
- package/src/cli/commands/start.ts +128 -55
- package/src/cli/commands/tests.ts +2 -0
- package/src/cli/commands/types.ts +1 -0
- package/src/cli/index.ts +4 -4
- package/src/cli/tasks/__tests__/cli-task.test.ts +16 -4
- package/src/cli/tasks/__tests__/swc-compile-package.test.ts +290 -0
- package/src/cli/tasks/__tests__/tsc-compile-package.test.ts +1 -0
- package/src/cli/tasks/__tests__/tsc-compile.test.ts +12 -23
- package/src/cli/tasks/cli-task.ts +12 -18
- package/src/cli/tasks/swc-cli.d.ts +12 -1
- package/src/cli/tasks/swc-compile-package.ts +73 -46
- package/src/cli/tasks/task.ts +2 -11
- package/src/cli/tasks/tsc-compile-package.ts +0 -4
- package/src/cli/tasks/tsc-compile.ts +14 -17
- package/src/cli/types/cpx2.d.ts +8 -1
- package/src/cli/utils/__tests__/bundle.test.ts +49 -8
- package/src/cli/utils/__tests__/check-args.test.ts +34 -0
- package/src/cli/utils/__tests__/compile.test.ts +59 -0
- package/src/cli/utils/__tests__/copy-files.test.ts +157 -0
- package/src/cli/utils/__tests__/get-module-type.test.ts +19 -0
- package/src/cli/utils/__tests__/lerna-exec.test.ts +58 -11
- package/src/cli/utils/__tests__/pipe-stdout.test.ts +39 -0
- package/src/cli/utils/__tests__/process-tree.test.ts +175 -0
- package/src/cli/utils/__tests__/set-node-options.test.ts +51 -6
- package/src/cli/utils/__tests__/type-check.test.ts +47 -0
- package/src/cli/utils/__tests__/watch-stdout.test.ts +68 -0
- package/src/cli/utils/bundle.ts +32 -23
- package/src/cli/utils/check-args.ts +13 -0
- package/src/cli/utils/compile-less.ts +0 -1
- package/src/cli/utils/compile-sass.ts +0 -1
- package/src/cli/utils/compile.ts +22 -0
- package/src/cli/utils/copy-files.ts +86 -0
- package/src/cli/utils/eslint.ts +1 -0
- package/src/cli/utils/get-module-type.ts +2 -20
- package/src/cli/utils/index.ts +8 -7
- package/src/cli/utils/lerna-exec.ts +17 -10
- package/src/cli/utils/pipe-stdout.ts +10 -0
- package/src/cli/utils/process-tree.ts +57 -0
- package/src/cli/utils/set-node-options.ts +15 -12
- package/src/cli/utils/ts-config.ts +64 -0
- package/src/cli/utils/type-check.ts +19 -0
- package/src/cli/utils/watch-stdout.ts +24 -0
- package/src/utils/__tests__/format-duration.test.ts +22 -0
- package/src/utils/__tests__/get-configuration.test.ts +64 -2
- package/src/utils/__tests__/get-packages.test.ts +58 -49
- package/src/utils/__tests__/log-errors.test.ts +102 -0
- package/src/utils/__tests__/log.test.ts +1 -86
- package/src/utils/find-packages.ts +12 -6
- package/src/utils/format-duration.ts +13 -0
- package/src/utils/get-configuration.ts +31 -5
- package/src/utils/get-folders.ts +3 -1
- package/src/utils/get-packages.ts +9 -16
- package/src/utils/index.ts +3 -0
- package/src/utils/log-errors.ts +29 -0
- package/src/utils/log.ts +0 -26
- package/src/webpack/__mocks__/file-rules.ts +0 -5
- package/src/webpack/__tests__/create-webpack-config-shared-dependencies.test.ts +0 -1
- package/src/webpack/__tests__/create-webpack-config-web-component.test.ts +21 -33
- package/src/webpack/__tests__/create-webpack-config.test.ts +60 -150
- package/src/webpack/configs/dev-server-config.ts +4 -27
- package/src/webpack/configs/devtool-config.ts +2 -2
- package/src/webpack/configs/entry.config.ts +7 -2
- package/src/webpack/configs/index.ts +2 -2
- package/src/webpack/configs/loaders/index.ts +1 -1
- package/src/webpack/configs/optimization-config.ts +8 -8
- package/src/webpack/configs/output-config.ts +4 -2
- package/src/webpack/configs/plugins/html-plugin.ts +5 -2
- package/src/webpack/configs/plugins/index.ts +0 -2
- package/src/webpack/configs/plugins/virtual-modules-plugin.ts +18 -5
- package/src/webpack/configs/plugins-config.ts +0 -4
- package/src/webpack/configs/resolve-config.ts +1 -1
- package/src/webpack/configs/rules/index.ts +0 -1
- package/src/webpack/configs/rules/js-rules.ts +27 -2
- package/src/webpack/configs/rules-config.ts +1 -11
- package/src/webpack/configs/types.ts +1 -3
- package/src/webpack/configs/utils/__tests__/generate-metadata.test.ts +3 -1
- package/src/webpack/configs/utils/generate-metadata.ts +6 -1
- package/src/webpack/configs/watch-options-config.ts +17 -0
- package/src/webpack/create-webpack-config.ts +3 -6
- package/src/webpack/index.ts +1 -1
- package/src/webpack/types.ts +1 -4
- package/src/webpack/utils/index.ts +1 -2
- package/dist/__mocks__/create-package.d.ts +0 -3
- package/dist/__mocks__/create-package.d.ts.map +0 -1
- package/dist/__mocks__/create-package.js +0 -17
- package/dist/__mocks__/create-package.js.map +0 -1
- package/dist/__mocks__/index.d.ts +0 -2
- package/dist/__mocks__/index.d.ts.map +0 -1
- package/dist/__mocks__/index.js +0 -18
- package/dist/__mocks__/index.js.map +0 -1
- package/dist/cli/utils/assets-copy.d.ts +0 -3
- package/dist/cli/utils/assets-copy.d.ts.map +0 -1
- package/dist/cli/utils/assets-copy.js +0 -25
- package/dist/cli/utils/assets-copy.js.map +0 -1
- package/dist/cli/utils/styles-copy.d.ts +0 -3
- package/dist/cli/utils/styles-copy.d.ts.map +0 -1
- package/dist/cli/utils/styles-copy.js +0 -25
- package/dist/cli/utils/styles-copy.js.map +0 -1
- package/dist/cli/utils/tcm.d.ts +0 -3
- package/dist/cli/utils/tcm.d.ts.map +0 -1
- package/dist/cli/utils/tcm.js +0 -67
- package/dist/cli/utils/tcm.js.map +0 -1
- package/dist/cli/utils/tsc.d.ts +0 -5
- package/dist/cli/utils/tsc.d.ts.map +0 -1
- package/dist/cli/utils/tsc.js +0 -37
- package/dist/cli/utils/tsc.js.map +0 -1
- package/dist/webpack/__mocks__/file-rules.d.ts +0 -3
- package/dist/webpack/__mocks__/file-rules.d.ts.map +0 -1
- package/dist/webpack/__mocks__/file-rules.js +0 -79
- package/dist/webpack/__mocks__/file-rules.js.map +0 -1
- package/dist/webpack/__mocks__/index.d.ts +0 -3
- package/dist/webpack/__mocks__/index.d.ts.map +0 -1
- package/dist/webpack/__mocks__/index.js +0 -19
- package/dist/webpack/__mocks__/index.js.map +0 -1
- package/dist/webpack/__mocks__/style-rules.d.ts +0 -8
- package/dist/webpack/__mocks__/style-rules.d.ts.map +0 -1
- package/dist/webpack/__mocks__/style-rules.js +0 -124
- package/dist/webpack/__mocks__/style-rules.js.map +0 -1
- package/dist/webpack/configs/cache-config.d.ts +0 -6
- package/dist/webpack/configs/cache-config.d.ts.map +0 -1
- package/dist/webpack/configs/cache-config.js +0 -23
- package/dist/webpack/configs/cache-config.js.map +0 -1
- package/dist/webpack/configs/plugins/provide-react-plugin.d.ts +0 -4
- package/dist/webpack/configs/plugins/provide-react-plugin.d.ts.map +0 -1
- package/dist/webpack/configs/plugins/provide-react-plugin.js +0 -13
- package/dist/webpack/configs/plugins/provide-react-plugin.js.map +0 -1
- package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts +0 -4
- package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts.map +0 -1
- package/dist/webpack/configs/plugins/ts-checker-plugin.js +0 -30
- package/dist/webpack/configs/plugins/ts-checker-plugin.js.map +0 -1
- package/dist/webpack/configs/rules/tsx-rules.d.ts +0 -4
- package/dist/webpack/configs/rules/tsx-rules.d.ts.map +0 -1
- package/dist/webpack/configs/rules/tsx-rules.js +0 -44
- package/dist/webpack/configs/rules/tsx-rules.js.map +0 -1
- package/dist/webpack/utils/bundle.d.ts.map +0 -1
- package/dist/webpack/utils/bundle.js +0 -19
- package/dist/webpack/utils/bundle.js.map +0 -1
- package/dist/webpack/utils/feature-cohort.d.ts +0 -5
- package/dist/webpack/utils/feature-cohort.d.ts.map +0 -1
- package/dist/webpack/utils/feature-cohort.js +0 -21
- package/dist/webpack/utils/feature-cohort.js.map +0 -1
- package/dist/webpack/utils/hash-mod.d.ts +0 -9
- package/dist/webpack/utils/hash-mod.d.ts.map +0 -1
- package/dist/webpack/utils/hash-mod.js +0 -34
- package/dist/webpack/utils/hash-mod.js.map +0 -1
- package/src/cli/tasks/__tests__/swc-compile.test.ts +0 -192
- package/src/cli/utils/__tests__/assets-copy.test.ts +0 -52
- package/src/cli/utils/__tests__/styles-copy.test.ts +0 -52
- package/src/cli/utils/__tests__/tcm.test.ts +0 -191
- package/src/cli/utils/__tests__/tsc.test.ts +0 -63
- package/src/cli/utils/assets-copy.ts +0 -23
- package/src/cli/utils/styles-copy.ts +0 -23
- package/src/cli/utils/tcm.ts +0 -76
- package/src/cli/utils/tsc.ts +0 -38
- package/src/webpack/configs/cache-config.ts +0 -25
- package/src/webpack/configs/plugins/provide-react-plugin.ts +0 -12
- package/src/webpack/configs/plugins/ts-checker-plugin.ts +0 -33
- package/src/webpack/configs/rules/tsx-rules.ts +0 -48
- package/src/webpack/utils/feature-cohort.ts +0 -19
- package/src/webpack/utils/hash-mod.ts +0 -32
- /package/src/webpack/utils/{bundle.ts → get-module-entry-path.ts} +0 -0
|
@@ -47,5 +47,24 @@ describe('[startup] Cli Utils', () => {
|
|
|
47
47
|
expect(subject()).toBe(module);
|
|
48
48
|
});
|
|
49
49
|
});
|
|
50
|
+
|
|
51
|
+
describe('when config extends relative path', () => {
|
|
52
|
+
const module = 'baz';
|
|
53
|
+
|
|
54
|
+
beforeEach(() => {
|
|
55
|
+
vol.fromJSON({
|
|
56
|
+
'base.json': JSON.stringify({
|
|
57
|
+
compilerOptions: { module },
|
|
58
|
+
}),
|
|
59
|
+
'foo/tsconfig.json': JSON.stringify({
|
|
60
|
+
extends: '../base.json',
|
|
61
|
+
}),
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
test("returns extended config's module", () => {
|
|
66
|
+
expect(subject('foo/tsconfig.json')).toBe(module);
|
|
67
|
+
});
|
|
68
|
+
});
|
|
50
69
|
});
|
|
51
70
|
});
|
|
@@ -5,6 +5,13 @@ import { lernaExec } from '../lerna-exec';
|
|
|
5
5
|
|
|
6
6
|
jest.mock('execa');
|
|
7
7
|
|
|
8
|
+
const AVAILABLE_PARALLELISM = 2;
|
|
9
|
+
|
|
10
|
+
jest.mock('node:os', () => ({
|
|
11
|
+
...jest.requireActual('node:os'),
|
|
12
|
+
availableParallelism: () => AVAILABLE_PARALLELISM,
|
|
13
|
+
}));
|
|
14
|
+
|
|
8
15
|
describe(`${lernaExec.name}`, () => {
|
|
9
16
|
let args: Parameters<typeof lernaExec>[0];
|
|
10
17
|
|
|
@@ -12,34 +19,60 @@ describe(`${lernaExec.name}`, () => {
|
|
|
12
19
|
jest.clearAllMocks();
|
|
13
20
|
jest.spyOn(log, 'info').mockImplementation(jest.fn()); // suppress log output
|
|
14
21
|
args = { cmd: 'foo' };
|
|
22
|
+
delete process.env.CI;
|
|
15
23
|
});
|
|
16
24
|
|
|
17
25
|
const subject = () => lernaExec(args);
|
|
18
26
|
|
|
19
27
|
function expectExecaCalledWith(commandLine: string) {
|
|
20
28
|
const [cmd, ...args] = commandLine.split(' ');
|
|
21
|
-
expect(execa).toHaveBeenCalledWith(cmd, args, {
|
|
29
|
+
expect(execa).toHaveBeenCalledWith(cmd, args, {
|
|
30
|
+
stdio: 'inherit',
|
|
31
|
+
env: {
|
|
32
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
33
|
+
FORCE_COLOR: 'true',
|
|
34
|
+
},
|
|
35
|
+
});
|
|
22
36
|
}
|
|
23
37
|
|
|
24
|
-
|
|
25
|
-
|
|
38
|
+
function itRunsLernaExec(option?: string) {
|
|
39
|
+
const optionString = option ? ` ${option}` : '';
|
|
40
|
+
test(`runs "lerna exec${optionString} -- {cmd}"`, () => {
|
|
41
|
+
subject();
|
|
26
42
|
|
|
27
|
-
|
|
28
|
-
|
|
43
|
+
expectExecaCalledWith(`lerna exec${optionString} -- ${args.cmd}`);
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
itRunsLernaExec();
|
|
29
48
|
|
|
30
49
|
describe.each([
|
|
31
50
|
{ arg: { parallel: true }, option: '--parallel' },
|
|
32
51
|
{ arg: { stream: true }, option: '--stream' },
|
|
33
52
|
{ arg: { bail: false }, option: '--no-bail' },
|
|
34
|
-
{ arg: {
|
|
35
|
-
{ arg: {
|
|
53
|
+
{ arg: { parallel: 1 }, option: '--concurrency=1' },
|
|
54
|
+
{ arg: { parallel: 0 }, option: '--concurrency=0' },
|
|
36
55
|
] as { arg: Partial<typeof args>; option: string }[])('with $arg', ({ arg, option }) => {
|
|
37
|
-
beforeEach(() =>
|
|
56
|
+
beforeEach(() => {
|
|
57
|
+
Object.assign(args, arg);
|
|
58
|
+
});
|
|
38
59
|
|
|
39
|
-
|
|
40
|
-
|
|
60
|
+
itRunsLernaExec(option);
|
|
61
|
+
});
|
|
41
62
|
|
|
42
|
-
|
|
63
|
+
describe('when process.env.CI=true', () => {
|
|
64
|
+
beforeEach(() => {
|
|
65
|
+
process.env.CI = 'true';
|
|
66
|
+
});
|
|
67
|
+
describe.each([
|
|
68
|
+
{ arg: { parallel: true }, option: `--concurrency=${AVAILABLE_PARALLELISM}` },
|
|
69
|
+
{ arg: { parallel: 10 }, option: '--concurrency=10' },
|
|
70
|
+
] as { arg: Partial<typeof args>; option: string }[])('with $arg', ({ arg, option }) => {
|
|
71
|
+
beforeEach(() => {
|
|
72
|
+
Object.assign(args, arg);
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
itRunsLernaExec(option);
|
|
43
76
|
});
|
|
44
77
|
});
|
|
45
78
|
|
|
@@ -63,4 +96,18 @@ describe(`${lernaExec.name}`, () => {
|
|
|
63
96
|
expectExecaCalledWith(`lerna exec -- ${args.cmd} ${args['--']!.join(' ')}`);
|
|
64
97
|
});
|
|
65
98
|
});
|
|
99
|
+
|
|
100
|
+
describe('with "stdio"', () => {
|
|
101
|
+
beforeEach(() => (args.stdio = 'ignore'));
|
|
102
|
+
|
|
103
|
+
test('runs execa with stdio option', () => {
|
|
104
|
+
subject();
|
|
105
|
+
|
|
106
|
+
expect(execa).toHaveBeenCalledWith(
|
|
107
|
+
'lerna',
|
|
108
|
+
expect.any(Array),
|
|
109
|
+
expect.objectContaining({ stdio: args.stdio })
|
|
110
|
+
);
|
|
111
|
+
});
|
|
112
|
+
});
|
|
66
113
|
});
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import { pipeStdout } from '../pipe-stdout';
|
|
3
|
+
|
|
4
|
+
describe(`${pipeStdout.name}`, () => {
|
|
5
|
+
const proc = {
|
|
6
|
+
stdout: { on: jest.fn(), off: jest.fn() },
|
|
7
|
+
} as unknown as execa.ExecaChildProcess;
|
|
8
|
+
|
|
9
|
+
const subject = () => pipeStdout(proc);
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn());
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
test('subscribes to stdout', () => {
|
|
17
|
+
subject();
|
|
18
|
+
|
|
19
|
+
expect(proc.stdout!.on).toHaveBeenCalledWith('data', expect.any(Function));
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
test('unsubscribes from stdout', () => {
|
|
23
|
+
const unsubscribe = subject();
|
|
24
|
+
const handler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
25
|
+
|
|
26
|
+
unsubscribe();
|
|
27
|
+
|
|
28
|
+
expect(proc.stdout!.off).toHaveBeenCalledWith('data', handler);
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
test('handler writes output to stdout', () => {
|
|
32
|
+
subject();
|
|
33
|
+
|
|
34
|
+
const handler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
35
|
+
handler('output');
|
|
36
|
+
|
|
37
|
+
expect(globalThis.process.stdout.write).toHaveBeenCalledWith('output');
|
|
38
|
+
});
|
|
39
|
+
});
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { HandlerResult, ProcessTree } from '../process-tree';
|
|
2
|
+
|
|
3
|
+
enum TestProcesses {
|
|
4
|
+
A,
|
|
5
|
+
B,
|
|
6
|
+
C,
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
describe(`[startup] ${ProcessTree.name}`, () => {
|
|
10
|
+
const createProcess = (
|
|
11
|
+
name: number,
|
|
12
|
+
timeout: number,
|
|
13
|
+
{ watchMode = false, returnObject }: { watchMode?: boolean; returnObject?: boolean } = {}
|
|
14
|
+
) => {
|
|
15
|
+
output.push(`started:${name}`);
|
|
16
|
+
if (watchMode) {
|
|
17
|
+
return {
|
|
18
|
+
process: new Promise(() => {}),
|
|
19
|
+
onComplete: new Promise<void>(resolve =>
|
|
20
|
+
setTimeout(() => {
|
|
21
|
+
output.push(`completed:${name}`);
|
|
22
|
+
resolve();
|
|
23
|
+
}, timeout)
|
|
24
|
+
),
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
const promise = new Promise<void>(resolve =>
|
|
28
|
+
setTimeout(() => {
|
|
29
|
+
output.push(`finished:${name}`);
|
|
30
|
+
resolve();
|
|
31
|
+
}, timeout)
|
|
32
|
+
);
|
|
33
|
+
return returnObject ? promise : { process: promise };
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
const subject = async () => {
|
|
37
|
+
const processTree = new ProcessTree<typeof TestProcesses>();
|
|
38
|
+
|
|
39
|
+
[TestProcesses.A, TestProcesses.B, TestProcesses.C].forEach(id => {
|
|
40
|
+
processTree.add(id, handlers[id], {
|
|
41
|
+
...(dependsOn[id] ? { dependsOn: dependsOn[id] } : {}),
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
processTree.run();
|
|
46
|
+
|
|
47
|
+
await jest.runAllTimersAsync();
|
|
48
|
+
|
|
49
|
+
return processTree;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
let handlers: Record<TestProcesses, () => HandlerResult>;
|
|
53
|
+
let dependsOn: { [key in TestProcesses]?: TestProcesses[] };
|
|
54
|
+
let output: string[] = [];
|
|
55
|
+
|
|
56
|
+
beforeEach(() => {
|
|
57
|
+
jest.useFakeTimers();
|
|
58
|
+
jest.clearAllMocks();
|
|
59
|
+
output = [];
|
|
60
|
+
handlers = {
|
|
61
|
+
[TestProcesses.A]: () => {
|
|
62
|
+
return createProcess(TestProcesses.A, 3000);
|
|
63
|
+
},
|
|
64
|
+
[TestProcesses.B]: () => {
|
|
65
|
+
return createProcess(TestProcesses.B, 2000);
|
|
66
|
+
},
|
|
67
|
+
[TestProcesses.C]: () => {
|
|
68
|
+
return createProcess(TestProcesses.C, 1000);
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
dependsOn = {};
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
function itRunsProcessesInParallel() {
|
|
75
|
+
test('runs processes in parallel', async () => {
|
|
76
|
+
await subject();
|
|
77
|
+
expect(output).toEqual([
|
|
78
|
+
`started:${TestProcesses.A}`,
|
|
79
|
+
`started:${TestProcesses.B}`,
|
|
80
|
+
`started:${TestProcesses.C}`,
|
|
81
|
+
`finished:${TestProcesses.C}`,
|
|
82
|
+
`finished:${TestProcesses.B}`,
|
|
83
|
+
`finished:${TestProcesses.A}`,
|
|
84
|
+
]);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
itRunsProcessesInParallel();
|
|
89
|
+
|
|
90
|
+
describe('when handler returns an object', () => {
|
|
91
|
+
beforeEach(() => {
|
|
92
|
+
handlers[TestProcesses.A] = () =>
|
|
93
|
+
createProcess(TestProcesses.A, 3000, { returnObject: true });
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
itRunsProcessesInParallel();
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
describe('when processes have dependencies', () => {
|
|
100
|
+
beforeEach(() => (dependsOn[TestProcesses.B] = [TestProcesses.A]));
|
|
101
|
+
|
|
102
|
+
test('waits for dependency to finish', async () => {
|
|
103
|
+
await subject();
|
|
104
|
+
expect(output).toEqual([
|
|
105
|
+
`started:${TestProcesses.A}`,
|
|
106
|
+
`started:${TestProcesses.C}`,
|
|
107
|
+
`finished:${TestProcesses.C}`,
|
|
108
|
+
`finished:${TestProcesses.A}`,
|
|
109
|
+
`started:${TestProcesses.B}`,
|
|
110
|
+
`finished:${TestProcesses.B}`,
|
|
111
|
+
]);
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
describe('when dependency is in watch mode', () => {
|
|
115
|
+
beforeEach(() => {
|
|
116
|
+
handlers[TestProcesses.A] = () =>
|
|
117
|
+
createProcess(TestProcesses.A, 3000, { watchMode: true });
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
test('waits for dependency to complete initialization', async () => {
|
|
121
|
+
await subject();
|
|
122
|
+
expect(output).toEqual([
|
|
123
|
+
`started:${TestProcesses.A}`,
|
|
124
|
+
`started:${TestProcesses.C}`,
|
|
125
|
+
`finished:${TestProcesses.C}`,
|
|
126
|
+
`completed:${TestProcesses.A}`,
|
|
127
|
+
`started:${TestProcesses.B}`,
|
|
128
|
+
`finished:${TestProcesses.B}`,
|
|
129
|
+
]);
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
describe('when more than one process depends on another', () => {
|
|
134
|
+
beforeEach(() => (dependsOn[TestProcesses.C] = [TestProcesses.A]));
|
|
135
|
+
|
|
136
|
+
test('processes wait for dependencies to finish', async () => {
|
|
137
|
+
await subject();
|
|
138
|
+
expect(output).toEqual([
|
|
139
|
+
`started:${TestProcesses.A}`,
|
|
140
|
+
`finished:${TestProcesses.A}`,
|
|
141
|
+
`started:${TestProcesses.B}`,
|
|
142
|
+
`started:${TestProcesses.C}`,
|
|
143
|
+
`finished:${TestProcesses.C}`,
|
|
144
|
+
`finished:${TestProcesses.B}`,
|
|
145
|
+
]);
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
describe('when process depends on multiple processes', () => {
|
|
150
|
+
beforeEach(() => {
|
|
151
|
+
dependsOn[TestProcesses.C] = [TestProcesses.A, TestProcesses.B];
|
|
152
|
+
});
|
|
153
|
+
test('waits for all dependencies to finish', async () => {
|
|
154
|
+
await subject();
|
|
155
|
+
expect(output).toEqual([
|
|
156
|
+
`started:${TestProcesses.A}`,
|
|
157
|
+
`finished:${TestProcesses.A}`,
|
|
158
|
+
`started:${TestProcesses.B}`,
|
|
159
|
+
`finished:${TestProcesses.B}`,
|
|
160
|
+
`started:${TestProcesses.C}`,
|
|
161
|
+
`finished:${TestProcesses.C}`,
|
|
162
|
+
]);
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
test("throws when dependency doesn't exist", () => {
|
|
168
|
+
const processTree = new ProcessTree<typeof TestProcesses>();
|
|
169
|
+
expect(() =>
|
|
170
|
+
processTree.add(TestProcesses.A, handlers[TestProcesses.A], {
|
|
171
|
+
dependsOn: [TestProcesses.B],
|
|
172
|
+
})
|
|
173
|
+
).toThrow(/Unknown process dependency/);
|
|
174
|
+
});
|
|
175
|
+
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import os from 'os';
|
|
2
2
|
import { getConfigurationSafe } from '../../../utils';
|
|
3
|
-
import {
|
|
3
|
+
import { Command } from '../../commands';
|
|
4
4
|
|
|
5
5
|
import { setNodeOptions } from '../set-node-options';
|
|
6
6
|
|
|
@@ -13,21 +13,37 @@ jest.mock('../../../utils', () => ({
|
|
|
13
13
|
getConfigurationSafe: jest.fn(() => ({})),
|
|
14
14
|
}));
|
|
15
15
|
|
|
16
|
+
class MockCommand implements Command {
|
|
17
|
+
get greedy() {
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
description() {
|
|
22
|
+
return 'mock command';
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
async execute() {
|
|
26
|
+
return Promise.resolve();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
16
30
|
describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
17
31
|
const MB = 1024 * 1024;
|
|
18
32
|
const DEFAULT_SIZE = 8192;
|
|
19
33
|
const originalNodeOptions = process.env.NODE_OPTIONS;
|
|
20
34
|
const maxOldSpaceSize = `--max_old_space_size=${DEFAULT_SIZE}`;
|
|
21
|
-
const
|
|
35
|
+
const commandName: any = 'mock';
|
|
36
|
+
const command = new MockCommand();
|
|
22
37
|
|
|
23
38
|
beforeEach(() => {
|
|
24
39
|
delete process.env.NODE_OPTIONS;
|
|
25
40
|
(os.totalmem as jest.Mock).mockReturnValue(16384 * MB);
|
|
41
|
+
jest.spyOn(command, 'greedy', 'get').mockReturnValue(true);
|
|
26
42
|
});
|
|
27
43
|
|
|
28
44
|
afterAll(() => (process.env.NODE_OPTIONS = originalNodeOptions));
|
|
29
45
|
|
|
30
|
-
const subject = () => setNodeOptions(command);
|
|
46
|
+
const subject = () => setNodeOptions(commandName, command);
|
|
31
47
|
|
|
32
48
|
test(`returns true and adds ${maxOldSpaceSize} to process.env.NODE_OPTIONS`, () => {
|
|
33
49
|
expect(subject()).toBe(true);
|
|
@@ -35,6 +51,16 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
35
51
|
expect(process.env.NODE_OPTIONS).toEqual(maxOldSpaceSize);
|
|
36
52
|
});
|
|
37
53
|
|
|
54
|
+
describe('when the command is not greedy', () => {
|
|
55
|
+
beforeEach(() => jest.spyOn(command, 'greedy', 'get').mockReturnValue(false));
|
|
56
|
+
|
|
57
|
+
test('returns false and does not set NODE_OPTIONS', () => {
|
|
58
|
+
expect(subject()).toBe(false);
|
|
59
|
+
|
|
60
|
+
expect(process.env.NODE_OPTIONS).toBeUndefined();
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
|
|
38
64
|
describe('when system has insufficient memory', () => {
|
|
39
65
|
const totalMem = 4096 * MB;
|
|
40
66
|
|
|
@@ -104,11 +130,11 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
104
130
|
|
|
105
131
|
beforeEach(() => (process.env.NODE_OPTIONS = envOptions));
|
|
106
132
|
|
|
107
|
-
test("
|
|
133
|
+
test("appends cli's NODE_OPTIONS to existing NODE_OPTIONS", () => {
|
|
108
134
|
expect(subject()).toBe(true);
|
|
109
135
|
|
|
110
136
|
expect(process.env.NODE_OPTIONS).toEqual(
|
|
111
|
-
[maxOldSpaceSize, ...options
|
|
137
|
+
[maxOldSpaceSize, envOptions, ...options].join(' ')
|
|
112
138
|
);
|
|
113
139
|
});
|
|
114
140
|
});
|
|
@@ -120,7 +146,7 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
120
146
|
beforeEach(() =>
|
|
121
147
|
(getConfigurationSafe as jest.Mock).mockReturnValue({
|
|
122
148
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
123
|
-
[
|
|
149
|
+
[commandName]: { NODE_OPTIONS: options },
|
|
124
150
|
})
|
|
125
151
|
);
|
|
126
152
|
|
|
@@ -130,4 +156,23 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
130
156
|
expect(process.env.NODE_OPTIONS).toBe(`${maxOldSpaceSize} ${options.join(' ')}`);
|
|
131
157
|
});
|
|
132
158
|
});
|
|
159
|
+
|
|
160
|
+
describe("when cli's and command's config have duplicate NODE_OPTIONS", () => {
|
|
161
|
+
const options = ['--no-warning', '--test'];
|
|
162
|
+
|
|
163
|
+
beforeEach(() => {
|
|
164
|
+
(getConfigurationSafe as jest.Mock).mockReturnValue({
|
|
165
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
166
|
+
NODE_OPTIONS: options,
|
|
167
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
168
|
+
[commandName]: { NODE_OPTIONS: options },
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
test('drops duplicate NODE_OPTIONS', () => {
|
|
173
|
+
subject();
|
|
174
|
+
|
|
175
|
+
expect(process.env.NODE_OPTIONS).toBe(`${maxOldSpaceSize} ${options.join(' ')}`);
|
|
176
|
+
});
|
|
177
|
+
});
|
|
133
178
|
});
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import { typeCheck } from '../type-check';
|
|
3
|
+
|
|
4
|
+
jest.mock('execa', () => jest.fn());
|
|
5
|
+
|
|
6
|
+
describe('[startup] Cli Utils', () => {
|
|
7
|
+
describe(`${typeCheck.name}`, () => {
|
|
8
|
+
const packages = ['foo', 'bar'];
|
|
9
|
+
let args: Parameters<typeof typeCheck>[0];
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
args = { packages };
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
function itRunsTscCompile({ watch }: { watch?: boolean } = {}) {
|
|
17
|
+
expect(execa).toHaveBeenCalledWith(
|
|
18
|
+
'startup',
|
|
19
|
+
[
|
|
20
|
+
'task',
|
|
21
|
+
'tsc-compile',
|
|
22
|
+
...packages.map(name => `--scope=${name}`),
|
|
23
|
+
watch ? '--watch' : undefined,
|
|
24
|
+
].filter(i => i !== undefined),
|
|
25
|
+
{ stdio: 'inherit' }
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const subject = async () => typeCheck(args);
|
|
30
|
+
|
|
31
|
+
test('type checks packages', async () => {
|
|
32
|
+
await subject();
|
|
33
|
+
|
|
34
|
+
itRunsTscCompile();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
describe('with "watch"', () => {
|
|
38
|
+
beforeEach(() => (args.watch = true));
|
|
39
|
+
|
|
40
|
+
test('type checks packages in watch mode', async () => {
|
|
41
|
+
await subject();
|
|
42
|
+
|
|
43
|
+
itRunsTscCompile({ watch: true });
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
});
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import { watchStdout } from '../watch-stdout';
|
|
3
|
+
|
|
4
|
+
describe(`${watchStdout.name}`, () => {
|
|
5
|
+
const proc = {
|
|
6
|
+
stdout: { on: jest.fn(), off: jest.fn() },
|
|
7
|
+
} as unknown as execa.ExecaChildProcess;
|
|
8
|
+
let indicator = 'indicator';
|
|
9
|
+
const handler = jest.fn();
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn());
|
|
14
|
+
indicator = 'indicator';
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
const subject = () => watchStdout(proc, indicator, handler);
|
|
18
|
+
|
|
19
|
+
test('subscribes to stdout', () => {
|
|
20
|
+
subject();
|
|
21
|
+
|
|
22
|
+
expect(proc.stdout!.on).toHaveBeenCalledWith('data', expect.any(Function));
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
test('unsubscribes from stdout', () => {
|
|
26
|
+
const unsubscribe = subject();
|
|
27
|
+
|
|
28
|
+
const stdoutHandler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
29
|
+
|
|
30
|
+
unsubscribe();
|
|
31
|
+
|
|
32
|
+
expect(proc.stdout!.off).toHaveBeenCalledWith('data', stdoutHandler);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
describe('when indicator is empty string', () => {
|
|
36
|
+
beforeEach(() => {
|
|
37
|
+
indicator = '';
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
test("doesn't subscribe to stdout", () => {
|
|
41
|
+
subject();
|
|
42
|
+
|
|
43
|
+
expect(proc.stdout!.on).not.toHaveBeenCalled();
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('stdout handler', () => {
|
|
48
|
+
beforeEach(() => {
|
|
49
|
+
subject();
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
test('calls the handler when there is match', () => {
|
|
53
|
+
const stdoutHandler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
54
|
+
|
|
55
|
+
stdoutHandler(indicator);
|
|
56
|
+
|
|
57
|
+
expect(handler).toHaveBeenCalledWith(1);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
test("doesn't call the handler when there is no match", () => {
|
|
61
|
+
const stdoutHandler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
62
|
+
|
|
63
|
+
stdoutHandler('abc');
|
|
64
|
+
|
|
65
|
+
expect(handler).not.toHaveBeenCalled();
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
});
|
package/src/cli/utils/bundle.ts
CHANGED
|
@@ -6,15 +6,19 @@ import { getPortPromise } from 'portfinder';
|
|
|
6
6
|
import webpack, { Configuration } from 'webpack';
|
|
7
7
|
import WebpackDevServer from 'webpack-dev-server';
|
|
8
8
|
|
|
9
|
-
import {
|
|
9
|
+
import {
|
|
10
|
+
getPackageName,
|
|
11
|
+
hasHeadlessBundle,
|
|
12
|
+
isDevServerDisabled,
|
|
13
|
+
isWebComponent,
|
|
14
|
+
log,
|
|
15
|
+
} from '../../utils';
|
|
10
16
|
import { Overrides, createWebpackConfig } from '../../webpack';
|
|
11
17
|
|
|
12
18
|
interface Options {
|
|
13
19
|
buildStat?: boolean;
|
|
14
20
|
codeCoverage?: boolean;
|
|
15
21
|
config?: string;
|
|
16
|
-
esbuild?: boolean;
|
|
17
|
-
experimentalBundlers?: boolean;
|
|
18
22
|
}
|
|
19
23
|
|
|
20
24
|
function getName() {
|
|
@@ -36,9 +40,8 @@ export async function bundle(options: Options = {}) {
|
|
|
36
40
|
const mode = 'production';
|
|
37
41
|
const fallback = `./${webpackProdConfigFileName}`;
|
|
38
42
|
const config = readWebpackConfig({ ...options, fallback });
|
|
39
|
-
const { buildStat, codeCoverage
|
|
40
|
-
|
|
41
|
-
const webpackOptions = { name, buildStat, codeCoverage, esbuild, experimentalBundlers };
|
|
43
|
+
const { buildStat, codeCoverage } = options;
|
|
44
|
+
const webpackOptions = { name, buildStat, codeCoverage };
|
|
42
45
|
|
|
43
46
|
if (isWebComponent()) {
|
|
44
47
|
const webpackConfig: Overrides = {
|
|
@@ -46,10 +49,18 @@ export async function bundle(options: Options = {}) {
|
|
|
46
49
|
plugins: config?.plugins,
|
|
47
50
|
};
|
|
48
51
|
|
|
49
|
-
|
|
52
|
+
const bundles = [
|
|
50
53
|
run(createWebpackConfig(webpackConfig, { embed: true, ...webpackOptions })),
|
|
51
54
|
run(createWebpackConfig(webpackConfig, webpackOptions)),
|
|
52
|
-
]
|
|
55
|
+
];
|
|
56
|
+
|
|
57
|
+
if (hasHeadlessBundle()) {
|
|
58
|
+
bundles.push(
|
|
59
|
+
run(createWebpackConfig(webpackConfig, { ...webpackOptions, headless: true }))
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
return Promise.all(bundles);
|
|
53
64
|
}
|
|
54
65
|
|
|
55
66
|
return run(config ?? createWebpackConfig({ configuration: { mode } }, webpackOptions));
|
|
@@ -61,8 +72,7 @@ export async function bundleWatch(options: Options = {}) {
|
|
|
61
72
|
const name = getName();
|
|
62
73
|
const mode = 'development';
|
|
63
74
|
const config = readWebpackConfig({ ...options, fallback: `./${webpackDevConfigFileName}` });
|
|
64
|
-
const { codeCoverage
|
|
65
|
-
const configOverrides = { codeCoverage, esbuild, experimentalBundlers, name };
|
|
75
|
+
const configOverrides = { codeCoverage: options.codeCoverage, name };
|
|
66
76
|
|
|
67
77
|
if (isWebComponent()) {
|
|
68
78
|
const webpackConfig: Overrides = {
|
|
@@ -70,27 +80,26 @@ export async function bundleWatch(options: Options = {}) {
|
|
|
70
80
|
plugins: config?.plugins,
|
|
71
81
|
};
|
|
72
82
|
|
|
73
|
-
|
|
74
|
-
runWatch(
|
|
75
|
-
createWebpackConfig(webpackConfig, {
|
|
76
|
-
embed: true,
|
|
77
|
-
...configOverrides,
|
|
78
|
-
})
|
|
79
|
-
),
|
|
83
|
+
const bundles = [
|
|
84
|
+
runWatch(createWebpackConfig(webpackConfig, { embed: true, ...configOverrides })),
|
|
80
85
|
isDevServerDisabled()
|
|
81
86
|
? runWatch(createWebpackConfig(webpackConfig, configOverrides))
|
|
82
87
|
: runServe(createWebpackConfig(webpackConfig, configOverrides)),
|
|
83
|
-
]
|
|
88
|
+
];
|
|
89
|
+
|
|
90
|
+
if (hasHeadlessBundle()) {
|
|
91
|
+
bundles.push(
|
|
92
|
+
runWatch(createWebpackConfig(webpackConfig, { ...configOverrides, headless: true }))
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
return Promise.all(bundles);
|
|
84
97
|
}
|
|
85
98
|
|
|
86
99
|
const webpackConfig =
|
|
87
100
|
config ?? createWebpackConfig({ configuration: { mode } }, configOverrides);
|
|
88
101
|
|
|
89
|
-
|
|
90
|
-
return runWatch(webpackConfig);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
return runServe(webpackConfig);
|
|
102
|
+
return isDevServerDisabled() ? runWatch(webpackConfig) : runServe(webpackConfig);
|
|
94
103
|
}
|
|
95
104
|
|
|
96
105
|
function readWebpackConfig({ config, fallback }: Options & { fallback: string }) {
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { log } from '../../utils';
|
|
2
|
+
|
|
3
|
+
interface Options {
|
|
4
|
+
obsolete?: string[];
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export function checkArgs(args: Record<string, any>, { obsolete }: Options) {
|
|
8
|
+
obsolete?.forEach(arg => {
|
|
9
|
+
if (args[arg.replace(/^--/, '')]) {
|
|
10
|
+
log.warning(`WARNING: ${arg} option is obsolete and is ignored`);
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
}
|