@servicetitan/startup 30.3.0 → 31.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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 +124 -48
- 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 +3 -2
- package/dist/cli/commands/prepare-package.d.ts.map +1 -1
- package/dist/cli/commands/prepare-package.js +44 -32
- package/dist/cli/commands/prepare-package.js.map +1 -1
- package/dist/cli/commands/review/__mocks__/expect-calls.d.ts +23 -0
- package/dist/cli/commands/review/__mocks__/expect-calls.d.ts.map +1 -0
- package/dist/cli/commands/review/__mocks__/index.d.ts +2 -0
- package/dist/cli/commands/review/__mocks__/index.d.ts.map +1 -0
- 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/__mocks__/index.d.ts +4 -0
- package/dist/cli/commands/review/rules/__mocks__/index.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/__mocks__/mock-config.d.ts +7 -0
- package/dist/cli/commands/review/rules/__mocks__/mock-config.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/__mocks__/mock-packages.d.ts +21 -0
- package/dist/cli/commands/review/rules/__mocks__/mock-packages.d.ts.map +1 -0
- package/dist/cli/commands/review/rules/__mocks__/mock-project.d.ts +3 -0
- package/dist/cli/commands/review/rules/__mocks__/mock-project.d.ts.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/start.d.ts +11 -3
- package/dist/cli/commands/start.d.ts.map +1 -1
- package/dist/cli/commands/start.js +166 -69
- 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-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 +75 -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/utils/bundle.d.ts +0 -2
- package/dist/cli/utils/bundle.d.ts.map +1 -1
- package/dist/cli/utils/bundle.js +118 -70
- 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 +112 -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 +21 -13
- package/dist/cli/utils/get-module-type.js.map +1 -1
- package/dist/cli/utils/index.d.ts +7 -5
- 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/style-extensions.d.ts +2 -0
- package/dist/cli/utils/style-extensions.d.ts.map +1 -0
- package/dist/cli/utils/style-extensions.js +17 -0
- package/dist/cli/utils/style-extensions.js.map +1 -0
- package/dist/cli/utils/tcm.d.ts +5 -2
- package/dist/cli/utils/tcm.d.ts.map +1 -1
- package/dist/cli/utils/tcm.js +51 -46
- package/dist/cli/utils/tcm.js.map +1 -1
- 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 +10 -2
- package/dist/utils/get-configuration.d.ts.map +1 -1
- package/dist/utils/get-configuration.js +120 -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/__mocks__/file-rules.d.ts.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/cache-config.js +20 -9
- package/dist/webpack/configs/cache-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 -1
- package/dist/webpack/configs/index.d.ts.map +1 -1
- package/dist/webpack/configs/index.js +30 -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 +54 -28
- package/dist/webpack/configs/optimization-config.js.map +1 -1
- package/dist/webpack/configs/output-config.js +26 -12
- 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.js +28 -20
- 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 +32 -22
- 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.js +40 -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 +62 -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 +0 -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/feature-cohort.js +17 -12
- package/dist/webpack/utils/feature-cohort.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/hash-mod.js +16 -11
- package/dist/webpack/utils/hash-mod.js.map +1 -1
- package/dist/webpack/utils/index.d.ts +1 -1
- package/dist/webpack/utils/index.d.ts.map +1 -1
- package/dist/webpack/utils/index.js +21 -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 +20 -20
- package/src/cli/commands/__tests__/build.test.ts +69 -44
- 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 +17 -36
- package/src/cli/commands/__tests__/start.test.ts +81 -44
- package/src/cli/commands/__tests__/tests.test.ts +4 -0
- package/src/cli/commands/build.ts +73 -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 +8 -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 +130 -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.test.ts → swc-compile-package.test.ts} +75 -36
- 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 +71 -45
- 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 +1 -1
- 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__/tcm.test.ts +90 -86
- 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 +5 -18
- 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 +76 -0
- package/src/cli/utils/eslint.ts +1 -0
- package/src/cli/utils/get-module-type.ts +4 -6
- package/src/cli/utils/index.ts +7 -6
- 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/style-extensions.ts +1 -0
- package/src/cli/utils/tcm.ts +22 -32
- 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 +44 -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 +19 -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-web-component.test.ts +4 -5
- package/src/webpack/__tests__/create-webpack-config.test.ts +33 -112
- 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 -1
- package/src/webpack/configs/loaders/index.ts +1 -1
- package/src/webpack/configs/optimization-config.ts +2 -2
- package/src/webpack/configs/plugins/index.ts +0 -2
- package/src/webpack/configs/plugins/virtual-modules-plugin.ts +3 -3
- 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/watch-options-config.ts +17 -0
- package/src/webpack/create-webpack-config.ts +3 -4
- package/src/webpack/index.ts +1 -1
- package/src/webpack/types.ts +0 -4
- package/src/webpack/utils/index.ts +1 -1
- package/dist/__mocks__/create-package.js +0 -17
- package/dist/__mocks__/create-package.js.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/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.js +0 -79
- package/dist/webpack/__mocks__/file-rules.js.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.js +0 -124
- package/dist/webpack/__mocks__/style-rules.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/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__/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/tsc.ts +0 -38
- 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/{bundle.ts → get-module-entry-path.ts} +0 -0
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { execSync } from 'child_process';
|
|
3
|
+
import terminalLink from 'terminal-link';
|
|
4
|
+
import {
|
|
5
|
+
findPackages,
|
|
6
|
+
getReviewConfiguration,
|
|
7
|
+
log,
|
|
8
|
+
logErrors,
|
|
9
|
+
readJsonSafe,
|
|
10
|
+
toArray,
|
|
11
|
+
} from '../../../utils';
|
|
12
|
+
import { Command } from '../types';
|
|
13
|
+
|
|
14
|
+
import {
|
|
15
|
+
ErrorSeverity,
|
|
16
|
+
FixCategory,
|
|
17
|
+
Level,
|
|
18
|
+
Package,
|
|
19
|
+
PackageError,
|
|
20
|
+
PackageRule,
|
|
21
|
+
Project,
|
|
22
|
+
RuleConfiguration,
|
|
23
|
+
} from './types';
|
|
24
|
+
import {
|
|
25
|
+
collateDependencies,
|
|
26
|
+
ErrorSummary,
|
|
27
|
+
formatLocation,
|
|
28
|
+
indent,
|
|
29
|
+
pluralize,
|
|
30
|
+
summarize,
|
|
31
|
+
} from './utils';
|
|
32
|
+
import { rules } from './rules';
|
|
33
|
+
|
|
34
|
+
const collator = new Intl.Collator();
|
|
35
|
+
|
|
36
|
+
interface Args {
|
|
37
|
+
fix?: boolean;
|
|
38
|
+
rule?: string | string[];
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export class Review implements Command {
|
|
42
|
+
private readonly severityToLabel: Record<ErrorSeverity, string> = {
|
|
43
|
+
[ErrorSeverity.warning]: chalk.yellow('warning'),
|
|
44
|
+
[ErrorSeverity.error]: chalk.red('error'),
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
private readonly levelToSeverity: Partial<Record<Level, ErrorSeverity>> = {
|
|
48
|
+
warn: ErrorSeverity.warning,
|
|
49
|
+
error: ErrorSeverity.error,
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
constructor(private readonly args: Args) {}
|
|
53
|
+
|
|
54
|
+
description() {
|
|
55
|
+
return 'check project for configuration errors';
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
@logErrors
|
|
59
|
+
async execute() {
|
|
60
|
+
const errors = this.args.fix ? this.fixErrors() : this.findErrors();
|
|
61
|
+
const summary = this.reportErrors(errors);
|
|
62
|
+
return summary.error > 0 ? Promise.reject() : Promise.resolve();
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
private createProject(): Project {
|
|
66
|
+
const root = readJsonSafe('package.json');
|
|
67
|
+
if (!root?.workspaces) {
|
|
68
|
+
throw new Error('this command must be run from the workspace root directory');
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const packageLock = readJsonSafe<Project['packageLock']>('package-lock.json');
|
|
72
|
+
if (!packageLock?.packages) {
|
|
73
|
+
throw new Error('this command must be run with valid package-lock.json');
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
root.location = '.'; // identifies the root package.json for rules that care
|
|
77
|
+
packageLock.location = './package-lock.json';
|
|
78
|
+
|
|
79
|
+
const config = getReviewConfiguration();
|
|
80
|
+
const packages: Package[] = [root, ...findPackages()];
|
|
81
|
+
const dependencies = sortByKey(collateDependencies(packages));
|
|
82
|
+
this.debug('review:packages', packages);
|
|
83
|
+
this.debug('review:dependencies', dependencies);
|
|
84
|
+
|
|
85
|
+
return { config, dependencies, packageLock, packages };
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
private debug(namespace: string, data: any) {
|
|
89
|
+
/* istanbul ignore next: debug only */
|
|
90
|
+
log.debug(namespace, () => data && JSON.stringify(data, null, 2));
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
private findErrors(project?: Project) {
|
|
94
|
+
const errors = this.runRules(project ?? this.createProject());
|
|
95
|
+
this.debug('review:errors', errors);
|
|
96
|
+
return errors;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
private fixErrors() {
|
|
100
|
+
const rulesById = rules.reduce<Record<string, PackageRule>>((result, rule) => {
|
|
101
|
+
result[rule.id] = rule;
|
|
102
|
+
return result;
|
|
103
|
+
}, {});
|
|
104
|
+
|
|
105
|
+
let project = this.createProject();
|
|
106
|
+
let errors = this.findErrors(project);
|
|
107
|
+
let totalFixed = 0;
|
|
108
|
+
|
|
109
|
+
for (const category of [FixCategory.isolated, FixCategory.normal, FixCategory.lockFile]) {
|
|
110
|
+
const fixable = errors.filter(({ fixable }) => fixable === category);
|
|
111
|
+
if (fixable.length === 0) {
|
|
112
|
+
continue;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
fixable.forEach(error => {
|
|
116
|
+
const rule = rulesById[error.id];
|
|
117
|
+
if (rule.fix) {
|
|
118
|
+
log.text(`Fixing ${this.formatError({ ...error, details: '', location: '' })}`);
|
|
119
|
+
rule.fix(error, project);
|
|
120
|
+
totalFixed += 1;
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
execSync('npx startup install --fix --quiet', { stdio: 'inherit' });
|
|
125
|
+
project = this.createProject();
|
|
126
|
+
errors = this.findErrors(project);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
if (totalFixed > 0) {
|
|
130
|
+
let summary = `Fixed ${pluralize(totalFixed, 'problem')}`;
|
|
131
|
+
if (errors.length) {
|
|
132
|
+
summary = `${summary}, ${pluralize(errors.length, 'problem remains', 'problems remain')}:\n`;
|
|
133
|
+
}
|
|
134
|
+
log.info(summary);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
return errors;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
private formatError(error: PackageError) {
|
|
141
|
+
const { location, message, severity = ErrorSeverity.error } = error;
|
|
142
|
+
|
|
143
|
+
const label = indent(this.severityToLabel[severity], location ? 1 : 0);
|
|
144
|
+
const details = error.details ? `\n${indent(error.details, location ? 2 : 1)}` : '';
|
|
145
|
+
const link = this.getLink(error);
|
|
146
|
+
|
|
147
|
+
return `${label} ${message} ${link}${details}`;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
private reportErrors(errors: PackageError[]) {
|
|
151
|
+
let prevLocation: string | undefined;
|
|
152
|
+
|
|
153
|
+
errors.forEach((error, index) => {
|
|
154
|
+
const { location } = error;
|
|
155
|
+
if (index > 0 && (!location || location !== prevLocation)) {
|
|
156
|
+
log.text('');
|
|
157
|
+
}
|
|
158
|
+
if (location && location !== prevLocation) {
|
|
159
|
+
log.text(chalk.underline(formatLocation(location)));
|
|
160
|
+
prevLocation = location;
|
|
161
|
+
}
|
|
162
|
+
log.text(this.formatError(error));
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
const summary = summarize(errors);
|
|
166
|
+
this.reportSummary(summary);
|
|
167
|
+
return summary;
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
private reportSummary({ error, warning, fixable }: ErrorSummary) {
|
|
171
|
+
if (error + warning === 0) {
|
|
172
|
+
return log.success('0 problems');
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
log.text('');
|
|
176
|
+
|
|
177
|
+
const severity = error ? 'error' : 'warning';
|
|
178
|
+
log[severity](
|
|
179
|
+
`${pluralize(error + warning, 'problem')} (${pluralize(error, 'error')}, ${pluralize(warning, 'warning')})`
|
|
180
|
+
);
|
|
181
|
+
|
|
182
|
+
if (fixable.error + fixable.warning > 0) {
|
|
183
|
+
log[severity](
|
|
184
|
+
`${pluralize(fixable.error, 'error')} and ${pluralize(fixable.warning, 'warning')} potentially fixable with --fix option`
|
|
185
|
+
);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
private runRules(project: Project): PackageError[] {
|
|
190
|
+
const selected = this.getSelectedRules();
|
|
191
|
+
return rules
|
|
192
|
+
.filter(({ id }) => !selected || selected.has(id))
|
|
193
|
+
.flatMap(rule => this.runRule(rule, project))
|
|
194
|
+
.filter(error => !!error)
|
|
195
|
+
.sort(compareError);
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
private runRule(rule: PackageRule, project: Project) {
|
|
199
|
+
const level = this.getLevel(project.config.rules?.[rule.id]);
|
|
200
|
+
if (level === 'off') {
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
return this.transform(rule.run(project), level);
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
private transform(errors?: PackageError | PackageError[], level?: 'error' | 'warn') {
|
|
208
|
+
const severity = level && this.levelToSeverity[level];
|
|
209
|
+
return errors && severity ? toArray(errors).map(error => ({ ...error, severity })) : errors;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
private getLevel(config?: RuleConfiguration) {
|
|
213
|
+
if (typeof config === 'string') {
|
|
214
|
+
return config;
|
|
215
|
+
}
|
|
216
|
+
if (Array.isArray(config) && typeof config[0] === 'string') {
|
|
217
|
+
return config[0];
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
private getLink({ id }: PackageError) {
|
|
222
|
+
const url = `https://docs.st.dev/docs/frontend/uikit/startup/review#${id}`;
|
|
223
|
+
return chalk.dim(terminalLink(id, url));
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
private getSelectedRules() {
|
|
227
|
+
const rule = this.args.rule;
|
|
228
|
+
if (typeof rule === 'string' && rule) {
|
|
229
|
+
return new Set([rule]);
|
|
230
|
+
}
|
|
231
|
+
if (Array.isArray(rule)) {
|
|
232
|
+
return new Set(rule.filter(id => !!id));
|
|
233
|
+
}
|
|
234
|
+
return undefined;
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
function compareError(
|
|
239
|
+
{ location: locationA = '', severity: severityA = ErrorSeverity.error }: PackageError,
|
|
240
|
+
{ location: locationB = '', severity: severityB = ErrorSeverity.error }: PackageError
|
|
241
|
+
) {
|
|
242
|
+
return locationA === locationB ? severityA - severityB : collator.compare(locationA, locationB);
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
function sortByKey<T>(obj: Record<string, T>): Record<string, T> {
|
|
246
|
+
return Object.fromEntries(Object.entries(obj).sort(([a], [b]) => collator.compare(a, b)));
|
|
247
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { toArray } from '../../../../../utils';
|
|
2
|
+
import { ReviewConfiguration } from '../../types';
|
|
3
|
+
|
|
4
|
+
export function mockConfig({
|
|
5
|
+
id,
|
|
6
|
+
level = 'error',
|
|
7
|
+
exclude = [],
|
|
8
|
+
}: {
|
|
9
|
+
id: string;
|
|
10
|
+
level?: 'error' | 'warn';
|
|
11
|
+
exclude: string | string[];
|
|
12
|
+
}): ReviewConfiguration {
|
|
13
|
+
return { rules: { [id]: exclude ? [level, { exclude: toArray(exclude) }] : [level] } };
|
|
14
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import { Dependencies, Package } from '../../types';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Generates an array of mock Package objects based on a dependencies map.
|
|
6
|
+
*
|
|
7
|
+
* Each dependency entry can specify multiple versions, and each version can be used by multiple package names.
|
|
8
|
+
* The resulting packages will have their dependencies set accordingly.
|
|
9
|
+
*
|
|
10
|
+
* @param {Dependencies} dependencies - An object mapping dependency names to version maps,
|
|
11
|
+
* where each version maps to an array of package names that depend on that version.
|
|
12
|
+
*
|
|
13
|
+
* @returns {Package[]} An array of Package objects with the specified dependencies.
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* const deps = {
|
|
17
|
+
* lodash: { '4.17.21': ['foo', 'bar'], '4.17.20': ['baz'] }
|
|
18
|
+
* };
|
|
19
|
+
* const pkgs = mockPackages(deps);
|
|
20
|
+
* // pkgs will include packages 'foo', 'bar', and 'baz' with appropriate lodash dependencies.
|
|
21
|
+
*/
|
|
22
|
+
export function mockPackages(dependencies: Dependencies): Package[] {
|
|
23
|
+
const packages = Object.entries(dependencies).reduce<Record<string, Package>>(
|
|
24
|
+
(result, [dependency, versions]) => {
|
|
25
|
+
Object.entries(versions).forEach(([version, names]) => {
|
|
26
|
+
names.forEach(name => {
|
|
27
|
+
result[name] ??= {
|
|
28
|
+
name,
|
|
29
|
+
location: path.join('packages', name),
|
|
30
|
+
dependencies: {},
|
|
31
|
+
};
|
|
32
|
+
result[name].dependencies![dependency] = version;
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
return result;
|
|
36
|
+
},
|
|
37
|
+
{}
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
return Object.values(packages);
|
|
41
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Project } from '../../types';
|
|
2
|
+
|
|
3
|
+
export function mockProject(project: Partial<Project>): Project {
|
|
4
|
+
return {
|
|
5
|
+
config: {},
|
|
6
|
+
dependencies: {},
|
|
7
|
+
packageLock: { packages: {}, location: './package-lock.json' },
|
|
8
|
+
packages: [],
|
|
9
|
+
...project,
|
|
10
|
+
};
|
|
11
|
+
}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { execSync } from 'child_process';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import { getFolders } from '../../../../../utils';
|
|
4
|
+
import { FixCategory, Package, ReviewConfiguration } from '../../types';
|
|
5
|
+
import { mockConfig, mockProject } from '../__mocks__';
|
|
6
|
+
|
|
7
|
+
import { NoTypescriptEntryPoint } from '../no-typescript-entry-point';
|
|
8
|
+
|
|
9
|
+
jest.mock('child_process', () => ({ execSync: jest.fn() }));
|
|
10
|
+
jest.mock('../../../../../utils', () => ({
|
|
11
|
+
...jest.requireActual('../../../../../utils'),
|
|
12
|
+
getFolders: jest.fn(),
|
|
13
|
+
}));
|
|
14
|
+
|
|
15
|
+
describe(`[startup] Review ${NoTypescriptEntryPoint.name}`, () => {
|
|
16
|
+
const id = 'no-typescript-entry-point';
|
|
17
|
+
const rule = new NoTypescriptEntryPoint();
|
|
18
|
+
let config: ReviewConfiguration;
|
|
19
|
+
let pkg: Package;
|
|
20
|
+
let packages: Package[];
|
|
21
|
+
|
|
22
|
+
beforeEach(() => {
|
|
23
|
+
config = {};
|
|
24
|
+
pkg = { name: 'lib', location: path.normalize('packages/lib'), main: 'index.js' };
|
|
25
|
+
packages = [pkg];
|
|
26
|
+
jest.clearAllMocks();
|
|
27
|
+
jest.mocked(getFolders).mockImplementation(() => ({ source: 'src', destination: 'dist' }));
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
const subject = () => rule.run(mockProject({ config, packages }));
|
|
31
|
+
|
|
32
|
+
function itReturnsError(message: () => string) {
|
|
33
|
+
test('returns error', () => {
|
|
34
|
+
expect(subject()).toEqual([
|
|
35
|
+
expect.objectContaining({
|
|
36
|
+
id,
|
|
37
|
+
message: message(),
|
|
38
|
+
location: pkg.location,
|
|
39
|
+
fixable: FixCategory.normal,
|
|
40
|
+
}),
|
|
41
|
+
]);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function itReturnsNothing() {
|
|
46
|
+
test('returns nothing', () => {
|
|
47
|
+
expect(subject()).toEqual([]);
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function itFixesErrorWith(command: () => string) {
|
|
52
|
+
test('fixes error', () => {
|
|
53
|
+
rule.fix(subject()[0]);
|
|
54
|
+
|
|
55
|
+
expect(execSync).toHaveBeenCalledWith(command());
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
itReturnsNothing();
|
|
60
|
+
|
|
61
|
+
describe('when main is a .ts file', () => {
|
|
62
|
+
beforeEach(() => (pkg.main = 'src/index.ts'));
|
|
63
|
+
|
|
64
|
+
itReturnsError(() => `"main" is Typescript: ${pkg.main}`);
|
|
65
|
+
|
|
66
|
+
itFixesErrorWith(() => `npm pkg set "main"="dist/index.js" -w ${pkg.location}`);
|
|
67
|
+
|
|
68
|
+
describe('when config excludes package', () => {
|
|
69
|
+
beforeEach(() => (config = mockConfig({ id, exclude: pkg.name })));
|
|
70
|
+
|
|
71
|
+
itReturnsNothing();
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
describe('when module is a .ts file', () => {
|
|
76
|
+
beforeEach(() => (pkg.module = './src/foo.ts'));
|
|
77
|
+
|
|
78
|
+
itReturnsError(() => `"module" is Typescript: ${pkg.module as string}`);
|
|
79
|
+
|
|
80
|
+
itFixesErrorWith(() => `npm pkg set "module"="./dist/foo.js" -w ${pkg.location}`);
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
describe('when exports is a .ts file', () => {
|
|
84
|
+
beforeEach(() => (pkg.exports = './src/foo.ts'));
|
|
85
|
+
|
|
86
|
+
itReturnsError(() => `"exports" is Typescript: ${pkg.exports as string}`);
|
|
87
|
+
|
|
88
|
+
itFixesErrorWith(() => `npm pkg set "exports"="./dist/foo.js" -w ${pkg.location}`);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
describe('when exports is a .d.ts file', () => {
|
|
92
|
+
beforeEach(() => (pkg.exports = './dist/index.d.ts'));
|
|
93
|
+
|
|
94
|
+
itReturnsNothing();
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
describe('when exports is an object with .ts file', () => {
|
|
98
|
+
beforeEach(() => (pkg.exports = { import: './foo.ts', require: './foo.js' }));
|
|
99
|
+
|
|
100
|
+
itReturnsError(() => `"exports[import]" is Typescript: ${(pkg.exports as any).import}`);
|
|
101
|
+
|
|
102
|
+
itFixesErrorWith(() => `npm pkg set "exports[import]"="./foo.js" -w ${pkg.location}`);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
describe('when exports is a nested object with .ts file', () => {
|
|
106
|
+
beforeEach(() => {
|
|
107
|
+
pkg.exports = { '.': { import: './src/import/foo.ts', require: './foo.js' } };
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
itReturnsError(
|
|
111
|
+
() => `"exports[.][import]" is Typescript: ${(pkg.exports as any)['.'].import}`
|
|
112
|
+
);
|
|
113
|
+
|
|
114
|
+
itFixesErrorWith(
|
|
115
|
+
() => `npm pkg set "exports[.][import]"="./dist/import/foo.js" -w ${pkg.location}`
|
|
116
|
+
);
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
describe('when both main and exports are .ts files', () => {
|
|
120
|
+
const exports = { import: './foo.ts', require: './foo.js' };
|
|
121
|
+
|
|
122
|
+
beforeEach(() => Object.assign(pkg, { main: 'main.ts', exports }));
|
|
123
|
+
|
|
124
|
+
test('returns multiple errors', () => {
|
|
125
|
+
expect(subject()).toEqual([
|
|
126
|
+
expect.objectContaining({
|
|
127
|
+
message: `"main" is Typescript: ${pkg.main}`,
|
|
128
|
+
location: pkg.location,
|
|
129
|
+
}),
|
|
130
|
+
expect.objectContaining({
|
|
131
|
+
message: `"exports[import]" is Typescript: ${exports.import}`,
|
|
132
|
+
location: pkg.location,
|
|
133
|
+
}),
|
|
134
|
+
]);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
describe('when multiple packages contain Typescript entry points', () => {
|
|
139
|
+
beforeEach(() => {
|
|
140
|
+
packages = [
|
|
141
|
+
{ ...pkg, name: 'lib1' }, // ok
|
|
142
|
+
{ ...pkg, name: 'lib2', main: 'main.ts' }, // error
|
|
143
|
+
{ ...pkg, name: 'lib3', exports: 'foo.ts' }, // error
|
|
144
|
+
];
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
test('returns errors for each package', () => {
|
|
148
|
+
expect(subject()).toEqual([
|
|
149
|
+
expect.objectContaining({
|
|
150
|
+
message: `"main" is Typescript: ${packages[1].main}`,
|
|
151
|
+
location: packages[1].location,
|
|
152
|
+
}),
|
|
153
|
+
expect.objectContaining({
|
|
154
|
+
message: `"exports" is Typescript: ${packages[2].exports as string}`,
|
|
155
|
+
location: packages[2].location,
|
|
156
|
+
}),
|
|
157
|
+
]);
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
test('ignores invalid error', () => {
|
|
162
|
+
rule.fix({} as any);
|
|
163
|
+
|
|
164
|
+
expect(execSync).not.toHaveBeenCalled();
|
|
165
|
+
});
|
|
166
|
+
});
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { ErrorSeverity, Package, ReviewConfiguration } from '../../types';
|
|
2
|
+
import { mockConfig, mockProject } from '../__mocks__';
|
|
3
|
+
|
|
4
|
+
import { RequireExplicitSideEffects } from '../require-explicit-side-effects';
|
|
5
|
+
|
|
6
|
+
describe(`[startup] Review ${RequireExplicitSideEffects.name}`, () => {
|
|
7
|
+
const id = 'require-explicit-side-effects';
|
|
8
|
+
const rule = new RequireExplicitSideEffects();
|
|
9
|
+
const basePackage: Package = {
|
|
10
|
+
name: 'lib',
|
|
11
|
+
main: 'index.js',
|
|
12
|
+
cli: { webpack: false },
|
|
13
|
+
location: 'packages/lib',
|
|
14
|
+
};
|
|
15
|
+
let config: ReviewConfiguration;
|
|
16
|
+
let packages: Package[];
|
|
17
|
+
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
config = {};
|
|
20
|
+
packages = [basePackage];
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
const subject = () => rule.run(mockProject({ config, packages }));
|
|
24
|
+
|
|
25
|
+
function itReturnsError() {
|
|
26
|
+
test('returns warning', () => {
|
|
27
|
+
expect(subject()).toEqual([
|
|
28
|
+
{
|
|
29
|
+
id,
|
|
30
|
+
message: `package "${packages[0].name}" omits sideEffects property`,
|
|
31
|
+
severity: ErrorSeverity.warning,
|
|
32
|
+
location: packages[0].location,
|
|
33
|
+
},
|
|
34
|
+
]);
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
function itReturnsNothing() {
|
|
39
|
+
test('returns nothing', () => {
|
|
40
|
+
expect(subject()).toEqual([]);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
describe('when sideEffects is omitted', () => {
|
|
45
|
+
beforeEach(() => (packages = [{ ...basePackage, sideEffects: undefined }]));
|
|
46
|
+
|
|
47
|
+
itReturnsError();
|
|
48
|
+
|
|
49
|
+
describe('when config excludes package', () => {
|
|
50
|
+
beforeEach(() => (config = mockConfig({ id, exclude: packages[0].name })));
|
|
51
|
+
|
|
52
|
+
itReturnsNothing();
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
describe('when sideEffects is true', () => {
|
|
57
|
+
beforeEach(() => (packages = [{ ...basePackage, sideEffects: true }]));
|
|
58
|
+
|
|
59
|
+
itReturnsNothing();
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
describe('when sideEffects is false', () => {
|
|
63
|
+
beforeEach(() => (packages = [{ ...basePackage, sideEffects: false }]));
|
|
64
|
+
|
|
65
|
+
itReturnsNothing();
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
describe('when sideEffects is an array', () => {
|
|
69
|
+
beforeEach(() => (packages = [{ ...basePackage, sideEffects: ['*.css'] }]));
|
|
70
|
+
|
|
71
|
+
itReturnsNothing();
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
describe('when package is an application', () => {
|
|
75
|
+
beforeEach(() => (packages = [{ ...basePackage, cli: undefined }]));
|
|
76
|
+
|
|
77
|
+
itReturnsNothing();
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
describe('when package omits "main" entry points', () => {
|
|
81
|
+
beforeEach(() => (packages = [{ ...basePackage, main: undefined }]));
|
|
82
|
+
|
|
83
|
+
itReturnsNothing();
|
|
84
|
+
|
|
85
|
+
describe('when package has "exports"', () => {
|
|
86
|
+
beforeEach(() => (packages[0].exports = 'index.js'));
|
|
87
|
+
|
|
88
|
+
itReturnsError();
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe('when multiple packages omit sideEffects', () => {
|
|
93
|
+
beforeEach(() => {
|
|
94
|
+
packages = [
|
|
95
|
+
basePackage, // error
|
|
96
|
+
{ ...basePackage, name: 'lib2', sideEffects: false }, // ok
|
|
97
|
+
{ ...basePackage, name: 'lib3', cli: { webpack: undefined } }, // ok
|
|
98
|
+
{ ...basePackage, name: 'lib4', main: undefined, exports: 'index.js' }, // error
|
|
99
|
+
];
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
test('returns multiple warnings', () => {
|
|
103
|
+
expect(subject()).toEqual([
|
|
104
|
+
expect.objectContaining({
|
|
105
|
+
message: `package "${packages[0].name}" omits sideEffects property`,
|
|
106
|
+
}),
|
|
107
|
+
expect.objectContaining({
|
|
108
|
+
message: `package "${packages[3].name}" omits sideEffects property`,
|
|
109
|
+
}),
|
|
110
|
+
]);
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
});
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { execSync } from 'child_process';
|
|
2
|
+
import { ErrorSeverity, FixCategory } from '../../types';
|
|
3
|
+
|
|
4
|
+
import { RequireNpmrc } from '../require-npmrc';
|
|
5
|
+
|
|
6
|
+
jest.mock('child_process', () => ({ execSync: jest.fn() }));
|
|
7
|
+
|
|
8
|
+
describe(`[startup] Review ${RequireNpmrc.name}`, () => {
|
|
9
|
+
const rule = new RequireNpmrc();
|
|
10
|
+
let npmConfig: Record<string, any>;
|
|
11
|
+
|
|
12
|
+
beforeEach(() => (npmConfig = {}));
|
|
13
|
+
|
|
14
|
+
const subject = () => {
|
|
15
|
+
jest.mocked(execSync).mockImplementation(() => JSON.stringify(npmConfig));
|
|
16
|
+
return rule.run();
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
function itReturnsWarning() {
|
|
20
|
+
test('returns warning', () => {
|
|
21
|
+
expect(subject()).toEqual({
|
|
22
|
+
id: expect.any(String),
|
|
23
|
+
message: 'project does not contain .npmrc with legacy-peer-deps=true',
|
|
24
|
+
severity: ErrorSeverity.warning,
|
|
25
|
+
fixable: FixCategory.isolated,
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
function itReturnsNothing() {
|
|
31
|
+
test('returns nothing', () => {
|
|
32
|
+
expect(subject()).toBeUndefined();
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
test('fetches npm settings', () => {
|
|
37
|
+
subject();
|
|
38
|
+
|
|
39
|
+
expect(execSync).toHaveBeenCalledWith(`npm config list --json`, { encoding: 'utf8' });
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
describe('when legacy-peer-deps is missing', () => {
|
|
43
|
+
beforeEach(() => (npmConfig = {}));
|
|
44
|
+
|
|
45
|
+
itReturnsWarning();
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe('when legacy-peer-deps is true', () => {
|
|
49
|
+
beforeEach(() => (npmConfig = { 'legacy-peer-deps': true }));
|
|
50
|
+
|
|
51
|
+
itReturnsNothing();
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
describe('when legacy-peer-deps is false', () => {
|
|
55
|
+
beforeEach(() => (npmConfig = { 'legacy-peer-deps': false }));
|
|
56
|
+
|
|
57
|
+
itReturnsWarning();
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
describe('fix', () => {
|
|
61
|
+
const subject = () => rule.fix();
|
|
62
|
+
|
|
63
|
+
test('sets npm project legacy-peer-deps=true', () => {
|
|
64
|
+
subject();
|
|
65
|
+
|
|
66
|
+
expect(execSync).toHaveBeenCalledWith(
|
|
67
|
+
'npm config set --location=project legacy-peer-deps=true'
|
|
68
|
+
);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
});
|