@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
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import execa from 'execa';
|
|
2
2
|
import { Task, TaskParameters } from './task';
|
|
3
|
+
import { pipeStdout, watchStdout } from '../utils';
|
|
3
4
|
|
|
4
5
|
export interface Indicators {
|
|
5
6
|
end: string;
|
|
@@ -41,24 +42,17 @@ export abstract class CliTask extends Task {
|
|
|
41
42
|
return;
|
|
42
43
|
}
|
|
43
44
|
|
|
44
|
-
childProcess
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
private readonly stdoutDataHandler = (data: Uint8Array | string) => {
|
|
49
|
-
process.stdout.write(data);
|
|
50
|
-
|
|
51
|
-
const dataStr = data.toString();
|
|
52
|
-
|
|
53
|
-
if (dataStr.includes(this.indicators.watchStart)) {
|
|
45
|
+
pipeStdout(childProcess);
|
|
46
|
+
watchStdout(childProcess, this.indicators.watchStart, () => {
|
|
54
47
|
this.taskTimer.start();
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
if (
|
|
58
|
-
dataStr.includes(this.indicators.end) ||
|
|
59
|
-
(this.indicators.watchEnd && dataStr.includes(this.indicators.watchEnd))
|
|
60
|
-
) {
|
|
48
|
+
});
|
|
49
|
+
watchStdout(childProcess, this.indicators.end, () => {
|
|
61
50
|
this.logCompletionResults(this.taskTimer.end());
|
|
62
|
-
}
|
|
63
|
-
|
|
51
|
+
});
|
|
52
|
+
watchStdout(childProcess, this.indicators.watchEnd, () => {
|
|
53
|
+
this.logCompletionResults(this.taskTimer.end());
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
await childProcess;
|
|
57
|
+
}
|
|
64
58
|
}
|
|
@@ -1,3 +1,14 @@
|
|
|
1
1
|
declare module '@swc/cli' {
|
|
2
|
-
|
|
2
|
+
interface Options {
|
|
3
|
+
cliOptions?: {
|
|
4
|
+
[key: string]: unknown;
|
|
5
|
+
};
|
|
6
|
+
swcOptions?: {
|
|
7
|
+
[key: string]: unknown;
|
|
8
|
+
};
|
|
9
|
+
callbacks?: {
|
|
10
|
+
[key: string]: Function;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
function swcDir(options: Options): void;
|
|
3
14
|
}
|
|
@@ -1,70 +1,97 @@
|
|
|
1
1
|
import { swcDir } from '@swc/cli';
|
|
2
|
-
import
|
|
2
|
+
import deepmerge from 'deepmerge';
|
|
3
3
|
|
|
4
|
+
import { getFolders, getSwcCompilePackageConfiguration, getTsConfig, log } from '../../utils';
|
|
5
|
+
import { TSConfig } from '../utils';
|
|
4
6
|
import { Task } from './task';
|
|
5
|
-
import { getFolders, log, readJson } from '../../utils';
|
|
6
7
|
|
|
7
8
|
interface Args {
|
|
8
9
|
[key: string]: unknown;
|
|
9
10
|
watch?: boolean;
|
|
10
11
|
}
|
|
11
12
|
|
|
13
|
+
function overwriteMerge(_destinationArray: unknown[], sourceArray: unknown[]) {
|
|
14
|
+
return sourceArray;
|
|
15
|
+
}
|
|
16
|
+
|
|
12
17
|
export class SwcCompilePackage extends Task {
|
|
13
18
|
constructor({ watch }: Args) {
|
|
14
19
|
super({ name: 'swc-compile-package', global: false, watch });
|
|
15
20
|
}
|
|
16
21
|
|
|
17
|
-
description() {
|
|
18
|
-
return 'Compiles TypeScript files to JavaScript with SWC within package folder';
|
|
19
|
-
}
|
|
20
|
-
|
|
21
22
|
async execute(): Promise<void> {
|
|
22
23
|
const { source, destination } = getFolders();
|
|
23
|
-
const
|
|
24
|
+
const packageConfig = getSwcCompilePackageConfiguration();
|
|
25
|
+
const tsConfig = new TSConfig(getTsConfig());
|
|
26
|
+
const target = tsConfig.getValue('compilerOptions.target');
|
|
27
|
+
const legacyDecorator = tsConfig.getValue('compilerOptions.experimentalDecorators');
|
|
28
|
+
const decoratorMetadata = tsConfig.getValue('compilerOptions.emitDecoratorMetadata');
|
|
29
|
+
const sourceMaps = tsConfig.getValue('compilerOptions.sourceMap');
|
|
30
|
+
const module = tsConfig.getValue<string>('compilerOptions.module')?.toLowerCase();
|
|
31
|
+
const ignore = tsConfig.getValue('exclude', [
|
|
32
|
+
'**/*.d.ts',
|
|
33
|
+
'**/__tests__/*',
|
|
34
|
+
'**/*.test.*',
|
|
35
|
+
'**/__mocks__/*',
|
|
36
|
+
'**/*.stories.*',
|
|
37
|
+
]);
|
|
24
38
|
|
|
25
39
|
return new Promise((resolve, reject) => {
|
|
26
|
-
swcDir(
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
parser: {
|
|
37
|
-
syntax: 'typescript',
|
|
38
|
-
tsx: true,
|
|
39
|
-
decorators: true,
|
|
40
|
+
swcDir(
|
|
41
|
+
deepmerge(
|
|
42
|
+
{
|
|
43
|
+
cliOptions: {
|
|
44
|
+
watch: this.watch,
|
|
45
|
+
outDir: destination,
|
|
46
|
+
stripLeadingPaths: true,
|
|
47
|
+
extensions: ['.ts', '.tsx'],
|
|
48
|
+
filenames: [source],
|
|
49
|
+
ignore,
|
|
40
50
|
},
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
51
|
+
swcOptions: {
|
|
52
|
+
jsc: {
|
|
53
|
+
parser: {
|
|
54
|
+
syntax: 'typescript',
|
|
55
|
+
tsx: true,
|
|
56
|
+
decorators: true,
|
|
57
|
+
},
|
|
58
|
+
target,
|
|
59
|
+
transform: {
|
|
60
|
+
legacyDecorator,
|
|
61
|
+
decoratorMetadata,
|
|
62
|
+
react: {
|
|
63
|
+
runtime: 'automatic',
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
sourceMaps,
|
|
68
|
+
module: {
|
|
69
|
+
type:
|
|
70
|
+
module === 'commonjs' || module === 'nodenext'
|
|
71
|
+
? 'commonjs'
|
|
72
|
+
: 'es6',
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
callbacks: {
|
|
76
|
+
onSuccess: (e: { duration: number }) => {
|
|
77
|
+
this.logCompletionResults(this.taskTimer.add(e.duration));
|
|
78
|
+
if (!this.watch) {
|
|
79
|
+
resolve();
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
onFail: (e: { duration: number; reasons: Map<string, string> }) => {
|
|
83
|
+
log.text([...e.reasons.values()][0]);
|
|
84
|
+
this.logCompletionResults(this.taskTimer.add(e.duration));
|
|
85
|
+
if (!this.watch) {
|
|
86
|
+
reject(new Error('Compilation failed'));
|
|
87
|
+
}
|
|
88
|
+
},
|
|
45
89
|
},
|
|
46
90
|
},
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
},
|
|
52
|
-
callbacks: {
|
|
53
|
-
onSuccess: (e: { duration: number }) => {
|
|
54
|
-
this.logCompletionResults(this.taskTimer.add(e.duration));
|
|
55
|
-
if (!this.watch) {
|
|
56
|
-
resolve();
|
|
57
|
-
}
|
|
58
|
-
},
|
|
59
|
-
onFail: (e: { duration: number; reasons: Map<string, string> }) => {
|
|
60
|
-
log.text([...e.reasons.values()][0]);
|
|
61
|
-
this.logCompletionResults(this.taskTimer.add(e.duration));
|
|
62
|
-
if (!this.watch) {
|
|
63
|
-
reject(new Error('Compilation failed'));
|
|
64
|
-
}
|
|
65
|
-
},
|
|
66
|
-
},
|
|
67
|
-
});
|
|
91
|
+
packageConfig,
|
|
92
|
+
{ arrayMerge: overwriteMerge, clone: false }
|
|
93
|
+
)
|
|
94
|
+
);
|
|
68
95
|
});
|
|
69
96
|
}
|
|
70
97
|
}
|
package/src/cli/tasks/task.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { log, readJsonSafe } from '../../utils';
|
|
1
|
+
import { formatDuration, log, readJsonSafe } from '../../utils';
|
|
2
2
|
|
|
3
3
|
class TaskTimer {
|
|
4
4
|
private counter = 0;
|
|
@@ -85,17 +85,10 @@ export abstract class Task {
|
|
|
85
85
|
}) {
|
|
86
86
|
const enumerator = counter === 0 ? 'Initial ' : 'Subsequent ';
|
|
87
87
|
log.info(
|
|
88
|
-
`${this.watch ? enumerator : ''}${this.name} task completed in ${
|
|
88
|
+
`${this.watch ? enumerator : ''}${this.name} task completed in ${formatDuration(measure.duration)}`
|
|
89
89
|
);
|
|
90
90
|
}
|
|
91
91
|
|
|
92
|
-
private formatDuration(duration: number) {
|
|
93
|
-
if (duration < 1000) {
|
|
94
|
-
return `${duration.toFixed(0)}ms`;
|
|
95
|
-
}
|
|
96
|
-
return `${(duration / 1000).toFixed(2)}s`;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
92
|
private checkRunLocation() {
|
|
100
93
|
const packageJson = readJsonSafe('package.json');
|
|
101
94
|
if (!packageJson?.workspaces && this.global) {
|
|
@@ -106,7 +99,5 @@ export abstract class Task {
|
|
|
106
99
|
}
|
|
107
100
|
}
|
|
108
101
|
|
|
109
|
-
abstract description(): string;
|
|
110
|
-
|
|
111
102
|
abstract execute(): Promise<void>;
|
|
112
103
|
}
|
|
@@ -18,10 +18,6 @@ export class TscCompilePackage extends CliTask {
|
|
|
18
18
|
});
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
-
description() {
|
|
22
|
-
return 'Compiles TypeScript files to JavaScript with TSC within package folder';
|
|
23
|
-
}
|
|
24
|
-
|
|
25
21
|
async execute() {
|
|
26
22
|
const tsConfig = getTsConfig();
|
|
27
23
|
await this.runChildProcess(
|
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getPackages,
|
|
3
|
-
getPackagesGraph,
|
|
4
|
-
getTsConfig,
|
|
5
|
-
Package,
|
|
6
|
-
PackageType,
|
|
7
|
-
splitPackagesByType,
|
|
8
|
-
} from '../../utils';
|
|
1
|
+
import { getPackages, getPackagesGraph, getTsConfig, log, Package, PackageType } from '../../utils';
|
|
9
2
|
import { CliTask } from './cli-task';
|
|
10
3
|
|
|
11
4
|
interface Args {
|
|
@@ -13,7 +6,6 @@ interface Args {
|
|
|
13
6
|
ignore?: string | string[];
|
|
14
7
|
scope?: string | string[];
|
|
15
8
|
watch?: boolean;
|
|
16
|
-
typeCheckOnly?: boolean;
|
|
17
9
|
}
|
|
18
10
|
|
|
19
11
|
export class TscCompile extends CliTask {
|
|
@@ -29,15 +21,20 @@ export class TscCompile extends CliTask {
|
|
|
29
21
|
});
|
|
30
22
|
}
|
|
31
23
|
|
|
32
|
-
description() {
|
|
33
|
-
return 'Compiles one or more TypeScript projects with optional type checking';
|
|
34
|
-
}
|
|
35
|
-
|
|
36
24
|
async execute() {
|
|
37
|
-
const packages =
|
|
38
|
-
|
|
39
|
-
|
|
25
|
+
const packages = getPackages({
|
|
26
|
+
scope: this.args.scope,
|
|
27
|
+
ignore: this.args.ignore,
|
|
28
|
+
type: [PackageType.TSC, PackageType.Webpack],
|
|
29
|
+
});
|
|
30
|
+
|
|
40
31
|
const tsConfigs = collapsePackages(packages).map(({ location }) => getTsConfig(location));
|
|
32
|
+
|
|
33
|
+
log.debug(
|
|
34
|
+
'tsc-compile',
|
|
35
|
+
`${this.args.watch ? 'watching' : 'compiling'} ${tsConfigs.join(' ')}`
|
|
36
|
+
);
|
|
37
|
+
|
|
41
38
|
await this.runChildProcess(
|
|
42
39
|
'tsc',
|
|
43
40
|
[
|
|
@@ -45,7 +42,7 @@ export class TscCompile extends CliTask {
|
|
|
45
42
|
this.watch ? '-w' : undefined,
|
|
46
43
|
'--pretty',
|
|
47
44
|
'--preserveWatchOutput',
|
|
48
|
-
|
|
45
|
+
'--emitDeclarationOnly',
|
|
49
46
|
...tsConfigs,
|
|
50
47
|
].filter(i => i !== undefined)
|
|
51
48
|
);
|
package/src/cli/types/cpx2.d.ts
CHANGED
|
@@ -1,3 +1,10 @@
|
|
|
1
1
|
declare module 'cpx2' {
|
|
2
|
-
|
|
2
|
+
import { WatchOptions } from '@types/cpx';
|
|
3
|
+
|
|
4
|
+
interface Cpx2WatchOptions extends WatchOptions {
|
|
5
|
+
ignore?: string | string[];
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export { copy, copySync } from '@types/cpx';
|
|
9
|
+
export function watch(source: string, dest: string, options?: Cpx2WatchOptions): Watcher;
|
|
3
10
|
}
|
|
@@ -7,6 +7,7 @@ import {
|
|
|
7
7
|
getConfiguration,
|
|
8
8
|
getFolders,
|
|
9
9
|
getPackageData,
|
|
10
|
+
hasHeadlessBundle,
|
|
10
11
|
loadSharedDependencies,
|
|
11
12
|
} from '../../../utils';
|
|
12
13
|
import { createWebpackConfig } from '../../../webpack';
|
|
@@ -27,6 +28,7 @@ jest.mock('../../../utils', () => ({
|
|
|
27
28
|
...jest.requireActual('../../../utils'),
|
|
28
29
|
getFolders: jest.fn(),
|
|
29
30
|
getPackageData: jest.fn(),
|
|
31
|
+
hasHeadlessBundle: jest.fn(),
|
|
30
32
|
loadSharedDependencies: jest.fn(),
|
|
31
33
|
log: { info: jest.fn() }, // suppress test output
|
|
32
34
|
}));
|
|
@@ -73,7 +75,7 @@ describe('[startup] Cli Utils', () => {
|
|
|
73
75
|
|
|
74
76
|
beforeEach(() => {
|
|
75
77
|
vol.fromJSON(packageFS());
|
|
76
|
-
options =
|
|
78
|
+
options = undefined;
|
|
77
79
|
stdoutSpy = jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn());
|
|
78
80
|
compiler.run = jest.fn(callback => callback(null, stats as any));
|
|
79
81
|
// Allows config file to be loaded with require(...)
|
|
@@ -174,6 +176,8 @@ describe('[startup] Cli Utils', () => {
|
|
|
174
176
|
const destination = 'dist';
|
|
175
177
|
const dependencies = { foo: '1.0.1' };
|
|
176
178
|
const sharedDependencies = { react: 'SharedDependencies.React' };
|
|
179
|
+
let defaultCreateOverrides: Parameters<typeof createWebpackConfig>[0];
|
|
180
|
+
let defaultCreateOptions: Parameters<typeof createWebpackConfig>[1];
|
|
177
181
|
|
|
178
182
|
beforeEach(() => {
|
|
179
183
|
vol.fromJSON(webComponentFS());
|
|
@@ -184,22 +188,42 @@ describe('[startup] Cli Utils', () => {
|
|
|
184
188
|
dependencies,
|
|
185
189
|
});
|
|
186
190
|
jest.mocked(loadSharedDependencies).mockReturnValue(sharedDependencies);
|
|
191
|
+
defaultCreateOverrides = { configuration: { mode: 'production' } };
|
|
192
|
+
defaultCreateOptions = {
|
|
193
|
+
buildStat: options?.buildStat,
|
|
194
|
+
name: expectPackageName(),
|
|
195
|
+
};
|
|
187
196
|
});
|
|
188
197
|
|
|
189
198
|
test('builds full and "embed" packages', async () => {
|
|
190
|
-
const createOptions = { buildStat: options?.buildStat, name: expectPackageName() };
|
|
191
|
-
const overrides = { configuration: { mode: 'production' } };
|
|
192
|
-
|
|
193
199
|
await subject();
|
|
194
200
|
|
|
195
|
-
expect(createWebpackConfig).toHaveBeenCalledWith(
|
|
196
|
-
|
|
197
|
-
|
|
201
|
+
expect(createWebpackConfig).toHaveBeenCalledWith(
|
|
202
|
+
defaultCreateOverrides,
|
|
203
|
+
defaultCreateOptions
|
|
204
|
+
);
|
|
205
|
+
expect(createWebpackConfig).toHaveBeenCalledWith(defaultCreateOverrides, {
|
|
206
|
+
...defaultCreateOptions,
|
|
198
207
|
embed: true,
|
|
199
208
|
});
|
|
200
209
|
expect(compiler.run).toHaveBeenCalledTimes(2);
|
|
201
210
|
});
|
|
202
211
|
|
|
212
|
+
describe('when headless file exists', () => {
|
|
213
|
+
beforeEach(() => {
|
|
214
|
+
jest.mocked(hasHeadlessBundle).mockReturnValue(true);
|
|
215
|
+
});
|
|
216
|
+
|
|
217
|
+
test('builds headless package', async () => {
|
|
218
|
+
await subject();
|
|
219
|
+
|
|
220
|
+
expect(createWebpackConfig).toHaveBeenCalledWith(defaultCreateOverrides, {
|
|
221
|
+
...defaultCreateOptions,
|
|
222
|
+
headless: true,
|
|
223
|
+
});
|
|
224
|
+
});
|
|
225
|
+
});
|
|
226
|
+
|
|
203
227
|
function itUsesConfig(params: { config: () => Record<string, any>; name: string }) {
|
|
204
228
|
test(`uses ${params.name}`, async () => {
|
|
205
229
|
const { configuration, plugins } = params.config();
|
|
@@ -384,13 +408,30 @@ describe('[startup] Cli Utils', () => {
|
|
|
384
408
|
});
|
|
385
409
|
expect(webpack).toHaveBeenNthCalledWith(1, createWebpackResult);
|
|
386
410
|
expect(webpack).toHaveBeenNthCalledWith(2, createWebpackResult);
|
|
387
|
-
expect(compiler.watch).
|
|
411
|
+
expect(compiler.watch).toHaveBeenCalledTimes(1);
|
|
388
412
|
expect(WebpackDevServer).toHaveBeenCalledWith(
|
|
389
413
|
{ host: 'localhost', port: 8080 },
|
|
390
414
|
compiler
|
|
391
415
|
);
|
|
392
416
|
});
|
|
393
417
|
|
|
418
|
+
describe('when headless file exists', () => {
|
|
419
|
+
beforeEach(() => {
|
|
420
|
+
jest.mocked(hasHeadlessBundle).mockReturnValue(true);
|
|
421
|
+
});
|
|
422
|
+
|
|
423
|
+
test('runs watch on headless bundle', async () => {
|
|
424
|
+
await subject();
|
|
425
|
+
|
|
426
|
+
expect(createWebpackConfig).toHaveBeenCalledWith(
|
|
427
|
+
expect.any(Object),
|
|
428
|
+
expect.objectContaining({ headless: true })
|
|
429
|
+
);
|
|
430
|
+
expect(webpack).toHaveBeenNthCalledWith(3, createWebpackResult);
|
|
431
|
+
expect(compiler.watch).toHaveBeenCalledTimes(2);
|
|
432
|
+
});
|
|
433
|
+
});
|
|
434
|
+
|
|
394
435
|
describe('when webpack.devServer is set to false in package.json', () => {
|
|
395
436
|
beforeEach(() => {
|
|
396
437
|
vol.fromJSON(webComponentFS({ webpack: { devServer: false } } as any));
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { checkArgs } from '../check-args';
|
|
2
|
+
import { log } from '../../../utils';
|
|
3
|
+
|
|
4
|
+
jest.mock('../../../utils', () => ({ log: { warning: jest.fn() } }));
|
|
5
|
+
|
|
6
|
+
describe(checkArgs.name, () => {
|
|
7
|
+
let args: Parameters<typeof checkArgs>[0];
|
|
8
|
+
let options: Parameters<typeof checkArgs>[1];
|
|
9
|
+
|
|
10
|
+
beforeEach(() => {
|
|
11
|
+
args = { foo: true };
|
|
12
|
+
options = {};
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
const subject = () => checkArgs(args, options);
|
|
16
|
+
|
|
17
|
+
test('logs nothing', () => {
|
|
18
|
+
subject();
|
|
19
|
+
|
|
20
|
+
expect(log.warning).not.toHaveBeenCalled();
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
describe('when argument is obsolete', () => {
|
|
24
|
+
beforeEach(() => (options = { obsolete: ['foo'] }));
|
|
25
|
+
|
|
26
|
+
test('logs warning', () => {
|
|
27
|
+
subject();
|
|
28
|
+
|
|
29
|
+
expect(log.warning).toHaveBeenCalledWith(
|
|
30
|
+
expect.stringMatching(/WARNING: \w+ option is obsolete and is ignored/)
|
|
31
|
+
);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
});
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { lernaExec } from '../lerna-exec';
|
|
2
|
+
import { compile } from '../compile';
|
|
3
|
+
|
|
4
|
+
jest.mock('../lerna-exec', () => ({
|
|
5
|
+
lernaExec: jest.fn(),
|
|
6
|
+
}));
|
|
7
|
+
|
|
8
|
+
describe('[startup] Cli Utils', () => {
|
|
9
|
+
const packages = ['foo', 'bar'];
|
|
10
|
+
let args: Parameters<typeof compile>[0];
|
|
11
|
+
|
|
12
|
+
beforeEach(() => {
|
|
13
|
+
jest.clearAllMocks();
|
|
14
|
+
args = { packages };
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
function itRunsSwcCompilePackage({ watch }: { watch?: boolean } = {}) {
|
|
18
|
+
expect(lernaExec).toHaveBeenCalledWith({
|
|
19
|
+
cmd: 'startup task swc-compile-package',
|
|
20
|
+
parallel: true,
|
|
21
|
+
scope: packages,
|
|
22
|
+
stream: true,
|
|
23
|
+
stdio: watch ? ['inherit', 'pipe', 'inherit'] : 'inherit',
|
|
24
|
+
...(watch ? { '--': ['--watch'] } : {}),
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
describe(`${compile.name}`, () => {
|
|
29
|
+
const subject = async () => compile(args);
|
|
30
|
+
|
|
31
|
+
test('compiles packages', async () => {
|
|
32
|
+
await subject();
|
|
33
|
+
|
|
34
|
+
itRunsSwcCompilePackage();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
describe('with "watch"', () => {
|
|
38
|
+
beforeEach(() => (args.watch = true));
|
|
39
|
+
|
|
40
|
+
test('compiles packages in watch mode', async () => {
|
|
41
|
+
await subject();
|
|
42
|
+
|
|
43
|
+
itRunsSwcCompilePackage({ watch: true });
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('with "useTsc"', () => {
|
|
48
|
+
beforeEach(() => (args.useTsc = true));
|
|
49
|
+
|
|
50
|
+
test('runs tsc-compile-package', async () => {
|
|
51
|
+
await subject();
|
|
52
|
+
|
|
53
|
+
expect(lernaExec).toHaveBeenCalledWith(
|
|
54
|
+
expect.objectContaining({ cmd: 'startup task tsc-compile-package' })
|
|
55
|
+
);
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
});
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @jest-environment node
|
|
3
|
+
*/
|
|
4
|
+
import cpx from 'cpx2';
|
|
5
|
+
import fs from 'fs';
|
|
6
|
+
import { getFolders, log } from '../../../utils';
|
|
7
|
+
import * as compileSassModule from '../compile-sass';
|
|
8
|
+
|
|
9
|
+
import { copyFiles, styleExtensions, supportedExtensions } from '../copy-files';
|
|
10
|
+
|
|
11
|
+
jest.mock('cpx2', () => ({
|
|
12
|
+
copySync: jest.fn(),
|
|
13
|
+
watch: jest.fn(),
|
|
14
|
+
}));
|
|
15
|
+
jest.mock('../../../utils', () => ({
|
|
16
|
+
...jest.requireActual('../../../utils'),
|
|
17
|
+
getFolders: jest.fn(),
|
|
18
|
+
log: { debug: jest.fn(), info: jest.fn(), error: jest.fn() },
|
|
19
|
+
}));
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Note: These tests don't use memfs because the typed-css-modules package
|
|
23
|
+
* uses node: URLs to import the fs modules, which bypasses the memfs filesystem
|
|
24
|
+
* (as of memfs ~4.6.0). Also sass requires the jest-environment be set to "node".
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
describe(`[startup] cli utils (${copyFiles.name})`, () => {
|
|
28
|
+
const source = fs.mkdtempSync('src');
|
|
29
|
+
const destination = 'dist';
|
|
30
|
+
const files = `${source}/**/*.{${supportedExtensions.join()}}`;
|
|
31
|
+
let options: Parameters<typeof copyFiles>[0];
|
|
32
|
+
|
|
33
|
+
beforeEach(() => {
|
|
34
|
+
jest.resetAllMocks();
|
|
35
|
+
jest.mocked(getFolders).mockReturnValue({ source, destination });
|
|
36
|
+
fs.readdirSync(source).forEach(file => fs.rmSync(`${source}/${file}`));
|
|
37
|
+
|
|
38
|
+
options = {};
|
|
39
|
+
|
|
40
|
+
jest.mocked(cpx.watch).mockImplementation(() => {
|
|
41
|
+
const emitter: { on?: Function } = {};
|
|
42
|
+
emitter.on = jest.fn((_event: string, _handler: Function) => emitter);
|
|
43
|
+
return emitter;
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
afterAll(() => {
|
|
48
|
+
if (fs.existsSync(source)) {
|
|
49
|
+
fs.rmSync(source, { recursive: true });
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
function mockStylesModule(module: string, id = 'foo') {
|
|
54
|
+
const content = `.${id} { display: none; }`;
|
|
55
|
+
fs.writeFileSync(`${source}/${module}`, content);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
function expectTypeDefinitions(module: string, id = 'foo') {
|
|
59
|
+
expect(fs.readFileSync(`${source}/${module}.d.ts`, 'utf8')).toContain(
|
|
60
|
+
`export const ${id}: string;`
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function getHandler(event: string) {
|
|
65
|
+
const emitter = jest.mocked(cpx.watch).mock.results[0].value;
|
|
66
|
+
const { calls } = jest.mocked(emitter.on).mock;
|
|
67
|
+
return calls.find(([name]: string[]) => name === event)[1] as Function;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const subject = async () => copyFiles(options);
|
|
71
|
+
|
|
72
|
+
test('copies assets and styles from source to destination', async () => {
|
|
73
|
+
await subject();
|
|
74
|
+
|
|
75
|
+
expect(cpx.copySync).toHaveBeenCalledWith(files, destination);
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
describe.each(styleExtensions)('with %s module', extension => {
|
|
79
|
+
const module = `foo.module.${extension}`;
|
|
80
|
+
|
|
81
|
+
beforeEach(() => mockStylesModule(module));
|
|
82
|
+
|
|
83
|
+
test(`generates types for ${extension} module`, async () => {
|
|
84
|
+
await subject();
|
|
85
|
+
|
|
86
|
+
expectTypeDefinitions(module);
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
describe('when an error occurs generating types', () => {
|
|
91
|
+
const errorMessage = 'Oops!';
|
|
92
|
+
|
|
93
|
+
beforeEach(() => {
|
|
94
|
+
mockStylesModule('foo.module.scss');
|
|
95
|
+
jest.spyOn(compileSassModule, 'compileSass').mockImplementation(() => {
|
|
96
|
+
throw new Error(errorMessage);
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
test('logs error', async () => {
|
|
101
|
+
await subject();
|
|
102
|
+
|
|
103
|
+
expect(log.error).toHaveBeenCalledWith(expect.stringContaining(errorMessage));
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
describe('with {watch: true}', () => {
|
|
108
|
+
beforeEach(() => (options = { watch: true }));
|
|
109
|
+
|
|
110
|
+
test('watches files', async () => {
|
|
111
|
+
await subject();
|
|
112
|
+
|
|
113
|
+
expect(cpx.watch).toHaveBeenCalledWith(
|
|
114
|
+
files,
|
|
115
|
+
destination,
|
|
116
|
+
expect.objectContaining({ initialCopy: false })
|
|
117
|
+
);
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
describe('when module is changed', () => {
|
|
121
|
+
const module = 'foo.module.scss';
|
|
122
|
+
|
|
123
|
+
beforeEach(async () => {
|
|
124
|
+
mockStylesModule(module);
|
|
125
|
+
await subject();
|
|
126
|
+
await getHandler('copy')({ srcPath: `${source}/${module}` });
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
test('generates types', () => {
|
|
130
|
+
expectTypeDefinitions(module);
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
describe('when an error occurs watching files', () => {
|
|
135
|
+
const errorMessage = 'Nope!';
|
|
136
|
+
|
|
137
|
+
beforeEach(async () => {
|
|
138
|
+
await subject();
|
|
139
|
+
await getHandler('watch-error')(new Error(errorMessage));
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
test('logs error', () => {
|
|
143
|
+
expect(log.error).toHaveBeenCalledWith(expect.stringContaining(errorMessage));
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
describe('when source location does not exist', () => {
|
|
149
|
+
beforeEach(() => fs.rmSync(source, { recursive: true }));
|
|
150
|
+
|
|
151
|
+
test('does not copy files', async () => {
|
|
152
|
+
await subject();
|
|
153
|
+
|
|
154
|
+
expect(cpx.copySync).not.toHaveBeenCalledWith();
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
});
|