@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,39 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import { pipeStdout } from '../pipe-stdout';
|
|
3
|
+
|
|
4
|
+
describe(`${pipeStdout.name}`, () => {
|
|
5
|
+
const proc = {
|
|
6
|
+
stdout: { on: jest.fn(), off: jest.fn() },
|
|
7
|
+
} as unknown as execa.ExecaChildProcess;
|
|
8
|
+
|
|
9
|
+
const subject = () => pipeStdout(proc);
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn());
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
test('subscribes to stdout', () => {
|
|
17
|
+
subject();
|
|
18
|
+
|
|
19
|
+
expect(proc.stdout!.on).toHaveBeenCalledWith('data', expect.any(Function));
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
test('unsubscribes from stdout', () => {
|
|
23
|
+
const unsubscribe = subject();
|
|
24
|
+
const handler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
25
|
+
|
|
26
|
+
unsubscribe();
|
|
27
|
+
|
|
28
|
+
expect(proc.stdout!.off).toHaveBeenCalledWith('data', handler);
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
test('handler writes output to stdout', () => {
|
|
32
|
+
subject();
|
|
33
|
+
|
|
34
|
+
const handler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
35
|
+
handler('output');
|
|
36
|
+
|
|
37
|
+
expect(globalThis.process.stdout.write).toHaveBeenCalledWith('output');
|
|
38
|
+
});
|
|
39
|
+
});
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import { HandlerResult, ProcessTree } from '../process-tree';
|
|
2
|
+
|
|
3
|
+
enum TestProcesses {
|
|
4
|
+
A,
|
|
5
|
+
B,
|
|
6
|
+
C,
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
describe(`[startup] ${ProcessTree.name}`, () => {
|
|
10
|
+
const createProcess = (
|
|
11
|
+
name: number,
|
|
12
|
+
timeout: number,
|
|
13
|
+
{ watchMode = false, returnObject }: { watchMode?: boolean; returnObject?: boolean } = {}
|
|
14
|
+
) => {
|
|
15
|
+
output.push(`started:${name}`);
|
|
16
|
+
if (watchMode) {
|
|
17
|
+
return {
|
|
18
|
+
process: new Promise(() => {}),
|
|
19
|
+
onComplete: new Promise<void>(resolve =>
|
|
20
|
+
setTimeout(() => {
|
|
21
|
+
output.push(`completed:${name}`);
|
|
22
|
+
resolve();
|
|
23
|
+
}, timeout)
|
|
24
|
+
),
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
const promise = new Promise<void>(resolve =>
|
|
28
|
+
setTimeout(() => {
|
|
29
|
+
output.push(`finished:${name}`);
|
|
30
|
+
resolve();
|
|
31
|
+
}, timeout)
|
|
32
|
+
);
|
|
33
|
+
return returnObject ? promise : { process: promise };
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
const subject = async () => {
|
|
37
|
+
const processTree = new ProcessTree<typeof TestProcesses>();
|
|
38
|
+
|
|
39
|
+
[TestProcesses.A, TestProcesses.B, TestProcesses.C].forEach(id => {
|
|
40
|
+
processTree.add(id, handlers[id], {
|
|
41
|
+
...(dependsOn[id] ? { dependsOn: dependsOn[id] } : {}),
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
processTree.run();
|
|
46
|
+
|
|
47
|
+
await jest.runAllTimersAsync();
|
|
48
|
+
|
|
49
|
+
return processTree;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
let handlers: Record<TestProcesses, () => HandlerResult>;
|
|
53
|
+
let dependsOn: { [key in TestProcesses]?: TestProcesses[] };
|
|
54
|
+
let output: string[] = [];
|
|
55
|
+
|
|
56
|
+
beforeEach(() => {
|
|
57
|
+
jest.useFakeTimers();
|
|
58
|
+
jest.clearAllMocks();
|
|
59
|
+
output = [];
|
|
60
|
+
handlers = {
|
|
61
|
+
[TestProcesses.A]: () => {
|
|
62
|
+
return createProcess(TestProcesses.A, 3000);
|
|
63
|
+
},
|
|
64
|
+
[TestProcesses.B]: () => {
|
|
65
|
+
return createProcess(TestProcesses.B, 2000);
|
|
66
|
+
},
|
|
67
|
+
[TestProcesses.C]: () => {
|
|
68
|
+
return createProcess(TestProcesses.C, 1000);
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
dependsOn = {};
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
function itRunsProcessesInParallel() {
|
|
75
|
+
test('runs processes in parallel', async () => {
|
|
76
|
+
await subject();
|
|
77
|
+
expect(output).toEqual([
|
|
78
|
+
`started:${TestProcesses.A}`,
|
|
79
|
+
`started:${TestProcesses.B}`,
|
|
80
|
+
`started:${TestProcesses.C}`,
|
|
81
|
+
`finished:${TestProcesses.C}`,
|
|
82
|
+
`finished:${TestProcesses.B}`,
|
|
83
|
+
`finished:${TestProcesses.A}`,
|
|
84
|
+
]);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
itRunsProcessesInParallel();
|
|
89
|
+
|
|
90
|
+
describe('when handler returns an object', () => {
|
|
91
|
+
beforeEach(() => {
|
|
92
|
+
handlers[TestProcesses.A] = () =>
|
|
93
|
+
createProcess(TestProcesses.A, 3000, { returnObject: true });
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
itRunsProcessesInParallel();
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
describe('when processes have dependencies', () => {
|
|
100
|
+
beforeEach(() => (dependsOn[TestProcesses.B] = [TestProcesses.A]));
|
|
101
|
+
|
|
102
|
+
test('waits for dependency to finish', async () => {
|
|
103
|
+
await subject();
|
|
104
|
+
expect(output).toEqual([
|
|
105
|
+
`started:${TestProcesses.A}`,
|
|
106
|
+
`started:${TestProcesses.C}`,
|
|
107
|
+
`finished:${TestProcesses.C}`,
|
|
108
|
+
`finished:${TestProcesses.A}`,
|
|
109
|
+
`started:${TestProcesses.B}`,
|
|
110
|
+
`finished:${TestProcesses.B}`,
|
|
111
|
+
]);
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
describe('when dependency is in watch mode', () => {
|
|
115
|
+
beforeEach(() => {
|
|
116
|
+
handlers[TestProcesses.A] = () =>
|
|
117
|
+
createProcess(TestProcesses.A, 3000, { watchMode: true });
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
test('waits for dependency to complete initialization', async () => {
|
|
121
|
+
await subject();
|
|
122
|
+
expect(output).toEqual([
|
|
123
|
+
`started:${TestProcesses.A}`,
|
|
124
|
+
`started:${TestProcesses.C}`,
|
|
125
|
+
`finished:${TestProcesses.C}`,
|
|
126
|
+
`completed:${TestProcesses.A}`,
|
|
127
|
+
`started:${TestProcesses.B}`,
|
|
128
|
+
`finished:${TestProcesses.B}`,
|
|
129
|
+
]);
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
describe('when more than one process depends on another', () => {
|
|
134
|
+
beforeEach(() => (dependsOn[TestProcesses.C] = [TestProcesses.A]));
|
|
135
|
+
|
|
136
|
+
test('processes wait for dependencies to finish', async () => {
|
|
137
|
+
await subject();
|
|
138
|
+
expect(output).toEqual([
|
|
139
|
+
`started:${TestProcesses.A}`,
|
|
140
|
+
`finished:${TestProcesses.A}`,
|
|
141
|
+
`started:${TestProcesses.B}`,
|
|
142
|
+
`started:${TestProcesses.C}`,
|
|
143
|
+
`finished:${TestProcesses.C}`,
|
|
144
|
+
`finished:${TestProcesses.B}`,
|
|
145
|
+
]);
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
describe('when process depends on multiple processes', () => {
|
|
150
|
+
beforeEach(() => {
|
|
151
|
+
dependsOn[TestProcesses.C] = [TestProcesses.A, TestProcesses.B];
|
|
152
|
+
});
|
|
153
|
+
test('waits for all dependencies to finish', async () => {
|
|
154
|
+
await subject();
|
|
155
|
+
expect(output).toEqual([
|
|
156
|
+
`started:${TestProcesses.A}`,
|
|
157
|
+
`finished:${TestProcesses.A}`,
|
|
158
|
+
`started:${TestProcesses.B}`,
|
|
159
|
+
`finished:${TestProcesses.B}`,
|
|
160
|
+
`started:${TestProcesses.C}`,
|
|
161
|
+
`finished:${TestProcesses.C}`,
|
|
162
|
+
]);
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
test("throws when dependency doesn't exist", () => {
|
|
168
|
+
const processTree = new ProcessTree<typeof TestProcesses>();
|
|
169
|
+
expect(() =>
|
|
170
|
+
processTree.add(TestProcesses.A, handlers[TestProcesses.A], {
|
|
171
|
+
dependsOn: [TestProcesses.B],
|
|
172
|
+
})
|
|
173
|
+
).toThrow(/Unknown process dependency/);
|
|
174
|
+
});
|
|
175
|
+
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import os from 'os';
|
|
2
2
|
import { getConfigurationSafe } from '../../../utils';
|
|
3
|
-
import {
|
|
3
|
+
import { Command } from '../../commands';
|
|
4
4
|
|
|
5
5
|
import { setNodeOptions } from '../set-node-options';
|
|
6
6
|
|
|
@@ -13,21 +13,37 @@ jest.mock('../../../utils', () => ({
|
|
|
13
13
|
getConfigurationSafe: jest.fn(() => ({})),
|
|
14
14
|
}));
|
|
15
15
|
|
|
16
|
+
class MockCommand implements Command {
|
|
17
|
+
get greedy() {
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
description() {
|
|
22
|
+
return 'mock command';
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
async execute() {
|
|
26
|
+
return Promise.resolve();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
16
30
|
describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
17
31
|
const MB = 1024 * 1024;
|
|
18
32
|
const DEFAULT_SIZE = 8192;
|
|
19
33
|
const originalNodeOptions = process.env.NODE_OPTIONS;
|
|
20
34
|
const maxOldSpaceSize = `--max_old_space_size=${DEFAULT_SIZE}`;
|
|
21
|
-
const
|
|
35
|
+
const commandName: any = 'mock';
|
|
36
|
+
const command = new MockCommand();
|
|
22
37
|
|
|
23
38
|
beforeEach(() => {
|
|
24
39
|
delete process.env.NODE_OPTIONS;
|
|
25
40
|
(os.totalmem as jest.Mock).mockReturnValue(16384 * MB);
|
|
41
|
+
jest.spyOn(command, 'greedy', 'get').mockReturnValue(true);
|
|
26
42
|
});
|
|
27
43
|
|
|
28
44
|
afterAll(() => (process.env.NODE_OPTIONS = originalNodeOptions));
|
|
29
45
|
|
|
30
|
-
const subject = () => setNodeOptions(command);
|
|
46
|
+
const subject = () => setNodeOptions(commandName, command);
|
|
31
47
|
|
|
32
48
|
test(`returns true and adds ${maxOldSpaceSize} to process.env.NODE_OPTIONS`, () => {
|
|
33
49
|
expect(subject()).toBe(true);
|
|
@@ -35,6 +51,16 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
35
51
|
expect(process.env.NODE_OPTIONS).toEqual(maxOldSpaceSize);
|
|
36
52
|
});
|
|
37
53
|
|
|
54
|
+
describe('when the command is not greedy', () => {
|
|
55
|
+
beforeEach(() => jest.spyOn(command, 'greedy', 'get').mockReturnValue(false));
|
|
56
|
+
|
|
57
|
+
test('returns false and does not set NODE_OPTIONS', () => {
|
|
58
|
+
expect(subject()).toBe(false);
|
|
59
|
+
|
|
60
|
+
expect(process.env.NODE_OPTIONS).toBeUndefined();
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
|
|
38
64
|
describe('when system has insufficient memory', () => {
|
|
39
65
|
const totalMem = 4096 * MB;
|
|
40
66
|
|
|
@@ -104,11 +130,11 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
104
130
|
|
|
105
131
|
beforeEach(() => (process.env.NODE_OPTIONS = envOptions));
|
|
106
132
|
|
|
107
|
-
test("
|
|
133
|
+
test("appends cli's NODE_OPTIONS to existing NODE_OPTIONS", () => {
|
|
108
134
|
expect(subject()).toBe(true);
|
|
109
135
|
|
|
110
136
|
expect(process.env.NODE_OPTIONS).toEqual(
|
|
111
|
-
[maxOldSpaceSize, ...options
|
|
137
|
+
[maxOldSpaceSize, envOptions, ...options].join(' ')
|
|
112
138
|
);
|
|
113
139
|
});
|
|
114
140
|
});
|
|
@@ -120,7 +146,7 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
120
146
|
beforeEach(() =>
|
|
121
147
|
(getConfigurationSafe as jest.Mock).mockReturnValue({
|
|
122
148
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
123
|
-
[
|
|
149
|
+
[commandName]: { NODE_OPTIONS: options },
|
|
124
150
|
})
|
|
125
151
|
);
|
|
126
152
|
|
|
@@ -130,4 +156,23 @@ describe(`[startup] utils:${setNodeOptions.name}`, () => {
|
|
|
130
156
|
expect(process.env.NODE_OPTIONS).toBe(`${maxOldSpaceSize} ${options.join(' ')}`);
|
|
131
157
|
});
|
|
132
158
|
});
|
|
159
|
+
|
|
160
|
+
describe("when cli's and command's config have duplicate NODE_OPTIONS", () => {
|
|
161
|
+
const options = ['--no-warning', '--test'];
|
|
162
|
+
|
|
163
|
+
beforeEach(() => {
|
|
164
|
+
(getConfigurationSafe as jest.Mock).mockReturnValue({
|
|
165
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
166
|
+
NODE_OPTIONS: options,
|
|
167
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
168
|
+
[commandName]: { NODE_OPTIONS: options },
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
test('drops duplicate NODE_OPTIONS', () => {
|
|
173
|
+
subject();
|
|
174
|
+
|
|
175
|
+
expect(process.env.NODE_OPTIONS).toBe(`${maxOldSpaceSize} ${options.join(' ')}`);
|
|
176
|
+
});
|
|
177
|
+
});
|
|
133
178
|
});
|
|
@@ -7,8 +7,8 @@ import fs, { Stats } from 'fs';
|
|
|
7
7
|
import { getFolders, log } from '../../../utils';
|
|
8
8
|
import * as sassModule from '../compile-sass';
|
|
9
9
|
|
|
10
|
-
import { styleExtensions } from '
|
|
11
|
-
import { tcm
|
|
10
|
+
import { styleExtensions } from '../style-extensions';
|
|
11
|
+
import { tcm } from '../tcm';
|
|
12
12
|
|
|
13
13
|
jest.mock('../../../utils', () => ({
|
|
14
14
|
...jest.requireActual('../../../utils'),
|
|
@@ -27,7 +27,7 @@ describe('[startup] Cli Utils', () => {
|
|
|
27
27
|
|
|
28
28
|
beforeEach(() => {
|
|
29
29
|
jest.resetAllMocks();
|
|
30
|
-
jest.mocked(getFolders).mockReturnValue({ source, destination:
|
|
30
|
+
jest.mocked(getFolders).mockReturnValue({ source, destination: 'dist' });
|
|
31
31
|
fs.readdirSync(source).forEach(file => fs.rmSync(`${source}/${file}`));
|
|
32
32
|
});
|
|
33
33
|
|
|
@@ -45,7 +45,12 @@ describe('[startup] Cli Utils', () => {
|
|
|
45
45
|
}
|
|
46
46
|
|
|
47
47
|
describe(`${tcm.name}`, () => {
|
|
48
|
-
const subject = async () => tcm();
|
|
48
|
+
const subject = async () => tcm(options);
|
|
49
|
+
let options: Parameters<typeof tcm>[0];
|
|
50
|
+
|
|
51
|
+
beforeEach(() => {
|
|
52
|
+
options = undefined;
|
|
53
|
+
});
|
|
49
54
|
|
|
50
55
|
describe.each(styleExtensions)('with %s module', extension => {
|
|
51
56
|
const module = `foo.module.${extension}`;
|
|
@@ -73,118 +78,117 @@ describe('[startup] Cli Utils', () => {
|
|
|
73
78
|
expect(log.error).toHaveBeenCalledWith(expect.stringContaining('Oops!'));
|
|
74
79
|
});
|
|
75
80
|
});
|
|
76
|
-
});
|
|
77
81
|
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
+
describe(`watch mode`, () => {
|
|
83
|
+
type Listener = (path: string) => Promise<void>;
|
|
84
|
+
let watchSpy: jest.SpyInstance;
|
|
85
|
+
let fsWatcher: Partial<ReturnType<typeof chokidar.watch>>;
|
|
82
86
|
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
const subject = () => tcmWatch();
|
|
87
|
+
beforeEach(() => {
|
|
88
|
+
options = { watch: true };
|
|
89
|
+
fsWatcher = { on: jest.fn() };
|
|
90
|
+
watchSpy = jest.spyOn(chokidar, 'watch').mockReturnValue(fsWatcher as any);
|
|
91
|
+
fs.writeFileSync(`${source}/foo.bar`, '');
|
|
92
|
+
});
|
|
90
93
|
|
|
91
|
-
|
|
92
|
-
|
|
94
|
+
test('watches for new and changed style modules', async () => {
|
|
95
|
+
await subject();
|
|
93
96
|
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
+
expect(watchSpy).toHaveBeenCalledWith(source, {
|
|
98
|
+
ignored: expect.any(Function),
|
|
99
|
+
ignoreInitial: true,
|
|
100
|
+
});
|
|
101
|
+
expect(fsWatcher.on).toHaveBeenCalledWith('add', expect.any(Function));
|
|
102
|
+
expect(fsWatcher.on).toHaveBeenCalledWith('change', expect.any(Function));
|
|
97
103
|
});
|
|
98
|
-
expect(fsWatcher.on).toHaveBeenCalledWith('add', expect.any(Function));
|
|
99
|
-
expect(fsWatcher.on).toHaveBeenCalledWith('change', expect.any(Function));
|
|
100
|
-
});
|
|
101
104
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
describe('"ignored" filter', () => {
|
|
108
|
-
const styleExtensions = ['.module.css', '.module.scss', '.module.less'];
|
|
109
|
-
let ignored: (path: string, stats?: Partial<Stats>) => boolean;
|
|
110
|
-
let filePath: string;
|
|
111
|
-
let stats: Partial<Stats> | undefined;
|
|
112
|
-
|
|
113
|
-
beforeEach(async () => {
|
|
114
|
-
await tcmWatch();
|
|
115
|
-
const { calls } = watchSpy.mock;
|
|
116
|
-
ignored = calls[0][1].ignored;
|
|
117
|
-
stats = { isFile: () => true };
|
|
118
|
-
});
|
|
105
|
+
function getListener(name: string) {
|
|
106
|
+
const { calls } = jest.mocked(fsWatcher.on)!.mock;
|
|
107
|
+
return calls.find(([event]) => event === name)![1] as Listener;
|
|
108
|
+
}
|
|
119
109
|
|
|
120
|
-
|
|
110
|
+
describe('"ignored" filter', () => {
|
|
111
|
+
const styleExtensions = ['.module.css', '.module.scss', '.module.less'];
|
|
112
|
+
let ignored: (path: string, stats?: Partial<Stats>) => boolean;
|
|
113
|
+
let filePath: string;
|
|
114
|
+
let stats: Partial<Stats> | undefined;
|
|
115
|
+
|
|
116
|
+
beforeEach(async () => {
|
|
117
|
+
await tcm(options);
|
|
118
|
+
const { calls } = watchSpy.mock;
|
|
119
|
+
ignored = calls[0][1].ignored;
|
|
120
|
+
stats = { isFile: () => true };
|
|
121
|
+
});
|
|
121
122
|
|
|
122
|
-
|
|
123
|
-
test(`returns ${value}`, () => expect(subject()).toBe(value));
|
|
124
|
-
}
|
|
123
|
+
const subject = () => ignored(filePath, stats);
|
|
125
124
|
|
|
126
|
-
|
|
127
|
-
|
|
125
|
+
function itReturns(value: boolean) {
|
|
126
|
+
test(`returns ${value}`, () => expect(subject()).toBe(value));
|
|
127
|
+
}
|
|
128
128
|
|
|
129
|
-
|
|
130
|
-
|
|
129
|
+
describe.each(styleExtensions)('when path ends with %s', ext => {
|
|
130
|
+
beforeEach(() => (filePath = `foo${ext}`));
|
|
131
131
|
|
|
132
|
-
|
|
133
|
-
|
|
132
|
+
itReturns(false);
|
|
133
|
+
});
|
|
134
134
|
|
|
135
|
-
|
|
136
|
-
|
|
135
|
+
describe.each(styleExtensions)('when path contains %s', ext => {
|
|
136
|
+
beforeEach(() => (filePath = `foo${ext}.d.ts`));
|
|
137
137
|
|
|
138
|
-
|
|
139
|
-
|
|
138
|
+
itReturns(true);
|
|
139
|
+
});
|
|
140
140
|
|
|
141
|
-
|
|
141
|
+
describe.each(['', '.scss', '.tsx'])('when path ends with "%s"', ext => {
|
|
142
|
+
beforeEach(() => (filePath = `foo${ext}`));
|
|
142
143
|
|
|
143
|
-
|
|
144
|
-
beforeEach(() => (stats = undefined));
|
|
144
|
+
itReturns(true);
|
|
145
145
|
|
|
146
|
-
|
|
147
|
-
|
|
146
|
+
describe('when stats is undefined', () => {
|
|
147
|
+
beforeEach(() => (stats = undefined));
|
|
148
148
|
|
|
149
|
-
|
|
150
|
-
|
|
149
|
+
itReturns(false);
|
|
150
|
+
});
|
|
151
151
|
|
|
152
|
-
|
|
152
|
+
describe('when stats.isFile returns false', () => {
|
|
153
|
+
beforeEach(() => (stats = { isFile: () => false }));
|
|
154
|
+
|
|
155
|
+
itReturns(false);
|
|
156
|
+
});
|
|
153
157
|
});
|
|
154
158
|
});
|
|
155
|
-
});
|
|
156
159
|
|
|
157
|
-
|
|
158
|
-
|
|
160
|
+
describe('when module is added', () => {
|
|
161
|
+
const module = 'bar.module.scss';
|
|
159
162
|
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
163
|
+
const setup = async () => {
|
|
164
|
+
await subject();
|
|
165
|
+
mockStylesModule(module, 'bar');
|
|
166
|
+
await getListener('add')(`${source}/${module}`);
|
|
167
|
+
};
|
|
165
168
|
|
|
166
|
-
|
|
167
|
-
|
|
169
|
+
test('generates Typescript definitions for new module', async () => {
|
|
170
|
+
await setup();
|
|
168
171
|
|
|
169
|
-
|
|
172
|
+
expectTypeDefinitions(module, 'bar');
|
|
173
|
+
});
|
|
170
174
|
});
|
|
171
|
-
});
|
|
172
175
|
|
|
173
|
-
|
|
174
|
-
|
|
176
|
+
describe('when module is changed', () => {
|
|
177
|
+
const module = 'baz.module.less';
|
|
175
178
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
+
const setup = async () => {
|
|
180
|
+
mockStylesModule(module, 'foo');
|
|
181
|
+
await subject();
|
|
179
182
|
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
+
mockStylesModule(module, 'baz');
|
|
184
|
+
await getListener('change')(`${source}/${module}`);
|
|
185
|
+
};
|
|
183
186
|
|
|
184
|
-
|
|
185
|
-
|
|
187
|
+
test('generates Typescript definitions for changed module', async () => {
|
|
188
|
+
await setup();
|
|
186
189
|
|
|
187
|
-
|
|
190
|
+
expectTypeDefinitions(module, 'baz');
|
|
191
|
+
});
|
|
188
192
|
});
|
|
189
193
|
});
|
|
190
194
|
});
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import { typeCheck } from '../type-check';
|
|
3
|
+
|
|
4
|
+
jest.mock('execa', () => jest.fn());
|
|
5
|
+
|
|
6
|
+
describe('[startup] Cli Utils', () => {
|
|
7
|
+
describe(`${typeCheck.name}`, () => {
|
|
8
|
+
const packages = ['foo', 'bar'];
|
|
9
|
+
let args: Parameters<typeof typeCheck>[0];
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
args = { packages };
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
function itRunsTscCompile({ watch }: { watch?: boolean } = {}) {
|
|
17
|
+
expect(execa).toHaveBeenCalledWith(
|
|
18
|
+
'startup',
|
|
19
|
+
[
|
|
20
|
+
'task',
|
|
21
|
+
'tsc-compile',
|
|
22
|
+
...packages.map(name => `--scope=${name}`),
|
|
23
|
+
watch ? '--watch' : undefined,
|
|
24
|
+
].filter(i => i !== undefined),
|
|
25
|
+
{ stdio: 'inherit' }
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const subject = async () => typeCheck(args);
|
|
30
|
+
|
|
31
|
+
test('type checks packages', async () => {
|
|
32
|
+
await subject();
|
|
33
|
+
|
|
34
|
+
itRunsTscCompile();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
describe('with "watch"', () => {
|
|
38
|
+
beforeEach(() => (args.watch = true));
|
|
39
|
+
|
|
40
|
+
test('type checks packages in watch mode', async () => {
|
|
41
|
+
await subject();
|
|
42
|
+
|
|
43
|
+
itRunsTscCompile({ watch: true });
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
});
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import execa from 'execa';
|
|
2
|
+
import { watchStdout } from '../watch-stdout';
|
|
3
|
+
|
|
4
|
+
describe(`${watchStdout.name}`, () => {
|
|
5
|
+
const proc = {
|
|
6
|
+
stdout: { on: jest.fn(), off: jest.fn() },
|
|
7
|
+
} as unknown as execa.ExecaChildProcess;
|
|
8
|
+
let indicator = 'indicator';
|
|
9
|
+
const handler = jest.fn();
|
|
10
|
+
|
|
11
|
+
beforeEach(() => {
|
|
12
|
+
jest.clearAllMocks();
|
|
13
|
+
jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn());
|
|
14
|
+
indicator = 'indicator';
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
const subject = () => watchStdout(proc, indicator, handler);
|
|
18
|
+
|
|
19
|
+
test('subscribes to stdout', () => {
|
|
20
|
+
subject();
|
|
21
|
+
|
|
22
|
+
expect(proc.stdout!.on).toHaveBeenCalledWith('data', expect.any(Function));
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
test('unsubscribes from stdout', () => {
|
|
26
|
+
const unsubscribe = subject();
|
|
27
|
+
|
|
28
|
+
const stdoutHandler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
29
|
+
|
|
30
|
+
unsubscribe();
|
|
31
|
+
|
|
32
|
+
expect(proc.stdout!.off).toHaveBeenCalledWith('data', stdoutHandler);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
describe('when indicator is empty string', () => {
|
|
36
|
+
beforeEach(() => {
|
|
37
|
+
indicator = '';
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
test("doesn't subscribe to stdout", () => {
|
|
41
|
+
subject();
|
|
42
|
+
|
|
43
|
+
expect(proc.stdout!.on).not.toHaveBeenCalled();
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
describe('stdout handler', () => {
|
|
48
|
+
beforeEach(() => {
|
|
49
|
+
subject();
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
test('calls the handler when there is match', () => {
|
|
53
|
+
const stdoutHandler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
54
|
+
|
|
55
|
+
stdoutHandler(indicator);
|
|
56
|
+
|
|
57
|
+
expect(handler).toHaveBeenCalledWith(1);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
test("doesn't call the handler when there is no match", () => {
|
|
61
|
+
const stdoutHandler = jest.mocked(proc.stdout!.on).mock.calls[0][1];
|
|
62
|
+
|
|
63
|
+
stdoutHandler('abc');
|
|
64
|
+
|
|
65
|
+
expect(handler).not.toHaveBeenCalled();
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
});
|