@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.
Files changed (725) hide show
  1. package/bin/index.js +5 -6
  2. package/dist/cli/commands/build.d.ts +10 -3
  3. package/dist/cli/commands/build.d.ts.map +1 -1
  4. package/dist/cli/commands/build.js +124 -48
  5. package/dist/cli/commands/build.js.map +1 -1
  6. package/dist/cli/commands/bundle-package.d.ts +0 -2
  7. package/dist/cli/commands/bundle-package.d.ts.map +1 -1
  8. package/dist/cli/commands/bundle-package.js +54 -36
  9. package/dist/cli/commands/bundle-package.js.map +1 -1
  10. package/dist/cli/commands/clean.d.ts +6 -0
  11. package/dist/cli/commands/clean.d.ts.map +1 -0
  12. package/dist/cli/commands/clean.js +55 -0
  13. package/dist/cli/commands/clean.js.map +1 -0
  14. package/dist/cli/commands/convert-eslint-config.js +163 -107
  15. package/dist/cli/commands/convert-eslint-config.js.map +1 -1
  16. package/dist/cli/commands/eslint.d.ts.map +1 -1
  17. package/dist/cli/commands/eslint.js +43 -24
  18. package/dist/cli/commands/eslint.js.map +1 -1
  19. package/dist/cli/commands/get-command.d.ts.map +1 -1
  20. package/dist/cli/commands/get-command.js +50 -53
  21. package/dist/cli/commands/get-command.js.map +1 -1
  22. package/dist/cli/commands/get-user-commands.js +21 -11
  23. package/dist/cli/commands/get-user-commands.js.map +1 -1
  24. package/dist/cli/commands/index.d.ts +1 -1
  25. package/dist/cli/commands/index.d.ts.map +1 -1
  26. package/dist/cli/commands/index.js +31 -30
  27. package/dist/cli/commands/index.js.map +1 -1
  28. package/dist/cli/commands/init.js +74 -48
  29. package/dist/cli/commands/init.js.map +1 -1
  30. package/dist/cli/commands/install.d.ts +8 -1
  31. package/dist/cli/commands/install.d.ts.map +1 -1
  32. package/dist/cli/commands/install.js +61 -23
  33. package/dist/cli/commands/install.js.map +1 -1
  34. package/dist/cli/commands/kendo-ui-license.js +48 -31
  35. package/dist/cli/commands/kendo-ui-license.js.map +1 -1
  36. package/dist/cli/commands/lint.d.ts +3 -1
  37. package/dist/cli/commands/lint.d.ts.map +1 -1
  38. package/dist/cli/commands/lint.js +112 -73
  39. package/dist/cli/commands/lint.js.map +1 -1
  40. package/dist/cli/commands/mfe-package-clean.js +80 -57
  41. package/dist/cli/commands/mfe-package-clean.js.map +1 -1
  42. package/dist/cli/commands/mfe-package-publish.d.ts +1 -0
  43. package/dist/cli/commands/mfe-package-publish.d.ts.map +1 -1
  44. package/dist/cli/commands/mfe-package-publish.js +124 -70
  45. package/dist/cli/commands/mfe-package-publish.js.map +1 -1
  46. package/dist/cli/commands/mfe-publish.d.ts.map +1 -1
  47. package/dist/cli/commands/mfe-publish.js +83 -48
  48. package/dist/cli/commands/mfe-publish.js.map +1 -1
  49. package/dist/cli/commands/prepare-package.d.ts +3 -2
  50. package/dist/cli/commands/prepare-package.d.ts.map +1 -1
  51. package/dist/cli/commands/prepare-package.js +44 -32
  52. package/dist/cli/commands/prepare-package.js.map +1 -1
  53. package/dist/cli/commands/review/__mocks__/expect-calls.d.ts +23 -0
  54. package/dist/cli/commands/review/__mocks__/expect-calls.d.ts.map +1 -0
  55. package/dist/cli/commands/review/__mocks__/index.d.ts +2 -0
  56. package/dist/cli/commands/review/__mocks__/index.d.ts.map +1 -0
  57. package/dist/cli/commands/review/index.d.ts +3 -0
  58. package/dist/cli/commands/review/index.d.ts.map +1 -0
  59. package/dist/cli/commands/review/index.js +20 -0
  60. package/dist/cli/commands/review/index.js.map +1 -0
  61. package/dist/cli/commands/review/review.d.ts +28 -0
  62. package/dist/cli/commands/review/review.d.ts.map +1 -0
  63. package/dist/cli/commands/review/review.js +239 -0
  64. package/dist/cli/commands/review/review.js.map +1 -0
  65. package/dist/cli/commands/review/rules/__mocks__/index.d.ts +4 -0
  66. package/dist/cli/commands/review/rules/__mocks__/index.d.ts.map +1 -0
  67. package/dist/cli/commands/review/rules/__mocks__/mock-config.d.ts +7 -0
  68. package/dist/cli/commands/review/rules/__mocks__/mock-config.d.ts.map +1 -0
  69. package/dist/cli/commands/review/rules/__mocks__/mock-packages.d.ts +21 -0
  70. package/dist/cli/commands/review/rules/__mocks__/mock-packages.d.ts.map +1 -0
  71. package/dist/cli/commands/review/rules/__mocks__/mock-project.d.ts +3 -0
  72. package/dist/cli/commands/review/rules/__mocks__/mock-project.d.ts.map +1 -0
  73. package/dist/cli/commands/review/rules/index.d.ts +3 -0
  74. package/dist/cli/commands/review/rules/index.d.ts.map +1 -0
  75. package/dist/cli/commands/review/rules/index.js +30 -0
  76. package/dist/cli/commands/review/rules/index.js.map +1 -0
  77. package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts +14 -0
  78. package/dist/cli/commands/review/rules/no-typescript-entry-point.d.ts.map +1 -0
  79. package/dist/cli/commands/review/rules/no-typescript-entry-point.js +89 -0
  80. package/dist/cli/commands/review/rules/no-typescript-entry-point.js.map +1 -0
  81. package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts +7 -0
  82. package/dist/cli/commands/review/rules/require-explicit-side-effects.d.ts.map +1 -0
  83. package/dist/cli/commands/review/rules/require-explicit-side-effects.js +37 -0
  84. package/dist/cli/commands/review/rules/require-explicit-side-effects.js.map +1 -0
  85. package/dist/cli/commands/review/rules/require-npmrc.d.ts +7 -0
  86. package/dist/cli/commands/review/rules/require-npmrc.d.ts.map +1 -0
  87. package/dist/cli/commands/review/rules/require-npmrc.js +38 -0
  88. package/dist/cli/commands/review/rules/require-npmrc.js.map +1 -0
  89. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts +5 -0
  90. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.d.ts.map +1 -0
  91. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js +33 -0
  92. package/dist/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.js.map +1 -0
  93. package/dist/cli/commands/review/rules/require-one-collection-version.d.ts +45 -0
  94. package/dist/cli/commands/review/rules/require-one-collection-version.d.ts.map +1 -0
  95. package/dist/cli/commands/review/rules/require-one-collection-version.js +140 -0
  96. package/dist/cli/commands/review/rules/require-one-collection-version.js.map +1 -0
  97. package/dist/cli/commands/review/rules/require-one-package-version.d.ts +20 -0
  98. package/dist/cli/commands/review/rules/require-one-package-version.d.ts.map +1 -0
  99. package/dist/cli/commands/review/rules/require-one-package-version.js +70 -0
  100. package/dist/cli/commands/review/rules/require-one-package-version.js.map +1 -0
  101. package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts +5 -0
  102. package/dist/cli/commands/review/rules/require-one-uikit-version.d.ts.map +1 -0
  103. package/dist/cli/commands/review/rules/require-one-uikit-version.js +40 -0
  104. package/dist/cli/commands/review/rules/require-one-uikit-version.js.map +1 -0
  105. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts +19 -0
  106. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.d.ts.map +1 -0
  107. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js +103 -0
  108. package/dist/cli/commands/review/rules/require-project-version-in-root-node-modules.js.map +1 -0
  109. package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts +7 -0
  110. package/dist/cli/commands/review/rules/require-servicetitan-scope.d.ts.map +1 -0
  111. package/dist/cli/commands/review/rules/require-servicetitan-scope.js +37 -0
  112. package/dist/cli/commands/review/rules/require-servicetitan-scope.js.map +1 -0
  113. package/dist/cli/commands/review/types.d.ts +72 -0
  114. package/dist/cli/commands/review/types.d.ts.map +1 -0
  115. package/dist/cli/commands/review/types.js +36 -0
  116. package/dist/cli/commands/review/types.js.map +1 -0
  117. package/dist/cli/commands/review/utils/apply-filter.d.ts +3 -0
  118. package/dist/cli/commands/review/utils/apply-filter.d.ts.map +1 -0
  119. package/dist/cli/commands/review/utils/apply-filter.js +20 -0
  120. package/dist/cli/commands/review/utils/apply-filter.js.map +1 -0
  121. package/dist/cli/commands/review/utils/collate-dependencies.d.ts +29 -0
  122. package/dist/cli/commands/review/utils/collate-dependencies.d.ts.map +1 -0
  123. package/dist/cli/commands/review/utils/collate-dependencies.js +31 -0
  124. package/dist/cli/commands/review/utils/collate-dependencies.js.map +1 -0
  125. package/dist/cli/commands/review/utils/compare-version.d.ts +9 -0
  126. package/dist/cli/commands/review/utils/compare-version.d.ts.map +1 -0
  127. package/dist/cli/commands/review/utils/compare-version.js +137 -0
  128. package/dist/cli/commands/review/utils/compare-version.js.map +1 -0
  129. package/dist/cli/commands/review/utils/format-depends-on.d.ts +2 -0
  130. package/dist/cli/commands/review/utils/format-depends-on.d.ts.map +1 -0
  131. package/dist/cli/commands/review/utils/format-depends-on.js +21 -0
  132. package/dist/cli/commands/review/utils/format-depends-on.js.map +1 -0
  133. package/dist/cli/commands/review/utils/format-location.d.ts +2 -0
  134. package/dist/cli/commands/review/utils/format-location.d.ts.map +1 -0
  135. package/dist/cli/commands/review/utils/format-location.js +25 -0
  136. package/dist/cli/commands/review/utils/format-location.js.map +1 -0
  137. package/dist/cli/commands/review/utils/get-key.d.ts +3 -0
  138. package/dist/cli/commands/review/utils/get-key.d.ts.map +1 -0
  139. package/dist/cli/commands/review/utils/get-key.js +20 -0
  140. package/dist/cli/commands/review/utils/get-key.js.map +1 -0
  141. package/dist/cli/commands/review/utils/get-max-version.d.ts +2 -0
  142. package/dist/cli/commands/review/utils/get-max-version.d.ts.map +1 -0
  143. package/dist/cli/commands/review/utils/get-max-version.js +16 -0
  144. package/dist/cli/commands/review/utils/get-max-version.js.map +1 -0
  145. package/dist/cli/commands/review/utils/indent.d.ts +2 -0
  146. package/dist/cli/commands/review/utils/indent.d.ts.map +1 -0
  147. package/dist/cli/commands/review/utils/indent.js +17 -0
  148. package/dist/cli/commands/review/utils/indent.js.map +1 -0
  149. package/dist/cli/commands/review/utils/index.d.ts +14 -0
  150. package/dist/cli/commands/review/utils/index.d.ts.map +1 -0
  151. package/dist/cli/commands/review/utils/index.js +32 -0
  152. package/dist/cli/commands/review/utils/index.js.map +1 -0
  153. package/dist/cli/commands/review/utils/is-library.d.ts +3 -0
  154. package/dist/cli/commands/review/utils/is-library.d.ts.map +1 -0
  155. package/dist/cli/commands/review/utils/is-library.js +15 -0
  156. package/dist/cli/commands/review/utils/is-library.js.map +1 -0
  157. package/dist/cli/commands/review/utils/name-to-location.d.ts +3 -0
  158. package/dist/cli/commands/review/utils/name-to-location.d.ts.map +1 -0
  159. package/dist/cli/commands/review/utils/name-to-location.js +18 -0
  160. package/dist/cli/commands/review/utils/name-to-location.js.map +1 -0
  161. package/dist/cli/commands/review/utils/pluralize.d.ts +2 -0
  162. package/dist/cli/commands/review/utils/pluralize.d.ts.map +1 -0
  163. package/dist/cli/commands/review/utils/pluralize.js +15 -0
  164. package/dist/cli/commands/review/utils/pluralize.js.map +1 -0
  165. package/dist/cli/commands/review/utils/set-version.d.ts +10 -0
  166. package/dist/cli/commands/review/utils/set-version.d.ts.map +1 -0
  167. package/dist/cli/commands/review/utils/set-version.js +33 -0
  168. package/dist/cli/commands/review/utils/set-version.js.map +1 -0
  169. package/dist/cli/commands/review/utils/summarize.d.ts +11 -0
  170. package/dist/cli/commands/review/utils/summarize.d.ts.map +1 -0
  171. package/dist/cli/commands/review/utils/summarize.js +30 -0
  172. package/dist/cli/commands/review/utils/summarize.js.map +1 -0
  173. package/dist/cli/commands/run-task.js +50 -31
  174. package/dist/cli/commands/run-task.js.map +1 -1
  175. package/dist/cli/commands/run-task.test.d.ts +2 -0
  176. package/dist/cli/commands/run-task.test.d.ts.map +1 -0
  177. package/dist/cli/commands/start.d.ts +11 -3
  178. package/dist/cli/commands/start.d.ts.map +1 -1
  179. package/dist/cli/commands/start.js +166 -69
  180. package/dist/cli/commands/start.js.map +1 -1
  181. package/dist/cli/commands/styles-check.js +73 -59
  182. package/dist/cli/commands/styles-check.js.map +1 -1
  183. package/dist/cli/commands/tests.d.ts +1 -0
  184. package/dist/cli/commands/tests.d.ts.map +1 -1
  185. package/dist/cli/commands/tests.js +45 -28
  186. package/dist/cli/commands/tests.js.map +1 -1
  187. package/dist/cli/commands/types.d.ts +1 -0
  188. package/dist/cli/commands/types.d.ts.map +1 -1
  189. package/dist/cli/commands/types.js +4 -1
  190. package/dist/cli/commands/types.js.map +1 -1
  191. package/dist/cli/index.js +43 -34
  192. package/dist/cli/index.js.map +1 -1
  193. package/dist/cli/tasks/cli-task.d.ts +0 -1
  194. package/dist/cli/tasks/cli-task.d.ts.map +1 -1
  195. package/dist/cli/tasks/cli-task.js +52 -41
  196. package/dist/cli/tasks/cli-task.js.map +1 -1
  197. package/dist/cli/tasks/swc-compile-package.d.ts +0 -1
  198. package/dist/cli/tasks/swc-compile-package.d.ts.map +1 -1
  199. package/dist/cli/tasks/swc-compile-package.js +75 -34
  200. package/dist/cli/tasks/swc-compile-package.js.map +1 -1
  201. package/dist/cli/tasks/task.d.ts +0 -2
  202. package/dist/cli/tasks/task.d.ts.map +1 -1
  203. package/dist/cli/tasks/task.js +60 -65
  204. package/dist/cli/tasks/task.js.map +1 -1
  205. package/dist/cli/tasks/tsc-compile-package.d.ts +0 -1
  206. package/dist/cli/tasks/tsc-compile-package.d.ts.map +1 -1
  207. package/dist/cli/tasks/tsc-compile-package.js +26 -22
  208. package/dist/cli/tasks/tsc-compile-package.js.map +1 -1
  209. package/dist/cli/tasks/tsc-compile.d.ts +0 -2
  210. package/dist/cli/tasks/tsc-compile.d.ts.map +1 -1
  211. package/dist/cli/tasks/tsc-compile.js +51 -31
  212. package/dist/cli/tasks/tsc-compile.js.map +1 -1
  213. package/dist/cli/utils/bundle.d.ts +0 -2
  214. package/dist/cli/utils/bundle.d.ts.map +1 -1
  215. package/dist/cli/utils/bundle.js +118 -70
  216. package/dist/cli/utils/bundle.js.map +1 -1
  217. package/dist/cli/utils/check-args.d.ts +6 -0
  218. package/dist/cli/utils/check-args.d.ts.map +1 -0
  219. package/dist/cli/utils/check-args.js +20 -0
  220. package/dist/cli/utils/check-args.js.map +1 -0
  221. package/dist/cli/utils/cli-git.js +23 -9
  222. package/dist/cli/utils/cli-git.js.map +1 -1
  223. package/dist/cli/utils/cli-npm.js +62 -23
  224. package/dist/cli/utils/cli-npm.js.map +1 -1
  225. package/dist/cli/utils/cli-os.js +34 -33
  226. package/dist/cli/utils/cli-os.js.map +1 -1
  227. package/dist/cli/utils/compile-less.d.ts.map +1 -1
  228. package/dist/cli/utils/compile-less.js +27 -11
  229. package/dist/cli/utils/compile-less.js.map +1 -1
  230. package/dist/cli/utils/compile-sass.d.ts.map +1 -1
  231. package/dist/cli/utils/compile-sass.js +25 -9
  232. package/dist/cli/utils/compile-sass.js.map +1 -1
  233. package/dist/cli/utils/compile.d.ts +6 -0
  234. package/dist/cli/utils/compile.d.ts.map +1 -0
  235. package/dist/cli/utils/compile.js +33 -0
  236. package/dist/cli/utils/compile.js.map +1 -0
  237. package/dist/cli/utils/copy-files.d.ts +8 -0
  238. package/dist/cli/utils/copy-files.d.ts.map +1 -0
  239. package/dist/cli/utils/copy-files.js +112 -0
  240. package/dist/cli/utils/copy-files.js.map +1 -0
  241. package/dist/cli/utils/eslint.d.ts.map +1 -1
  242. package/dist/cli/utils/eslint.js +22 -12
  243. package/dist/cli/utils/eslint.js.map +1 -1
  244. package/dist/cli/utils/get-module-type.d.ts.map +1 -1
  245. package/dist/cli/utils/get-module-type.js +21 -13
  246. package/dist/cli/utils/get-module-type.js.map +1 -1
  247. package/dist/cli/utils/index.d.ts +7 -5
  248. package/dist/cli/utils/index.d.ts.map +1 -1
  249. package/dist/cli/utils/index.js +33 -30
  250. package/dist/cli/utils/index.js.map +1 -1
  251. package/dist/cli/utils/is-module-installed.js +11 -4
  252. package/dist/cli/utils/is-module-installed.js.map +1 -1
  253. package/dist/cli/utils/lerna-exec.d.ts +4 -3
  254. package/dist/cli/utils/lerna-exec.d.ts.map +1 -1
  255. package/dist/cli/utils/lerna-exec.js +40 -19
  256. package/dist/cli/utils/lerna-exec.js.map +1 -1
  257. package/dist/cli/utils/maybe-create-git-folder.js +20 -18
  258. package/dist/cli/utils/maybe-create-git-folder.js.map +1 -1
  259. package/dist/cli/utils/pipe-stdout.d.ts +3 -0
  260. package/dist/cli/utils/pipe-stdout.d.ts.map +1 -0
  261. package/dist/cli/utils/pipe-stdout.js +19 -0
  262. package/dist/cli/utils/pipe-stdout.js.map +1 -0
  263. package/dist/cli/utils/process-tree.d.ts +14 -0
  264. package/dist/cli/utils/process-tree.d.ts.map +1 -0
  265. package/dist/cli/utils/process-tree.js +78 -0
  266. package/dist/cli/utils/process-tree.js.map +1 -0
  267. package/dist/cli/utils/publish.js +12 -6
  268. package/dist/cli/utils/publish.js.map +1 -1
  269. package/dist/cli/utils/set-node-options.d.ts +2 -1
  270. package/dist/cli/utils/set-node-options.d.ts.map +1 -1
  271. package/dist/cli/utils/set-node-options.js +39 -30
  272. package/dist/cli/utils/set-node-options.js.map +1 -1
  273. package/dist/cli/utils/style-extensions.d.ts +2 -0
  274. package/dist/cli/utils/style-extensions.d.ts.map +1 -0
  275. package/dist/cli/utils/style-extensions.js +17 -0
  276. package/dist/cli/utils/style-extensions.js.map +1 -0
  277. package/dist/cli/utils/tcm.d.ts +5 -2
  278. package/dist/cli/utils/tcm.d.ts.map +1 -1
  279. package/dist/cli/utils/tcm.js +51 -46
  280. package/dist/cli/utils/tcm.js.map +1 -1
  281. package/dist/cli/utils/type-check.d.ts +7 -0
  282. package/dist/cli/utils/type-check.d.ts.map +1 -0
  283. package/dist/cli/utils/type-check.js +33 -0
  284. package/dist/cli/utils/type-check.js.map +1 -0
  285. package/dist/cli/utils/watch-stdout.d.ts +3 -0
  286. package/dist/cli/utils/watch-stdout.d.ts.map +1 -0
  287. package/dist/cli/utils/watch-stdout.js +26 -0
  288. package/dist/cli/utils/watch-stdout.js.map +1 -0
  289. package/dist/index.js +20 -18
  290. package/dist/index.js.map +1 -1
  291. package/dist/jest/index.js +12 -4
  292. package/dist/jest/index.js.map +1 -1
  293. package/dist/utils/debug.js +23 -11
  294. package/dist/utils/debug.js.map +1 -1
  295. package/dist/utils/find-packages.d.ts.map +1 -1
  296. package/dist/utils/find-packages.js +46 -34
  297. package/dist/utils/find-packages.js.map +1 -1
  298. package/dist/utils/format-duration.d.ts +2 -0
  299. package/dist/utils/format-duration.d.ts.map +1 -0
  300. package/dist/utils/format-duration.js +24 -0
  301. package/dist/utils/format-duration.js.map +1 -0
  302. package/dist/utils/get-branch-configs.js +24 -8
  303. package/dist/utils/get-branch-configs.js.map +1 -1
  304. package/dist/utils/get-configuration.d.ts +10 -2
  305. package/dist/utils/get-configuration.d.ts.map +1 -1
  306. package/dist/utils/get-configuration.js +120 -52
  307. package/dist/utils/get-configuration.js.map +1 -1
  308. package/dist/utils/get-destination-folders.js +25 -18
  309. package/dist/utils/get-destination-folders.js.map +1 -1
  310. package/dist/utils/get-folders.d.ts +2 -2
  311. package/dist/utils/get-folders.d.ts.map +1 -1
  312. package/dist/utils/get-folders.js +20 -13
  313. package/dist/utils/get-folders.js.map +1 -1
  314. package/dist/utils/get-jest-config.js +65 -38
  315. package/dist/utils/get-jest-config.js.map +1 -1
  316. package/dist/utils/get-package-data.js +26 -12
  317. package/dist/utils/get-package-data.js.map +1 -1
  318. package/dist/utils/get-package-name.js +18 -8
  319. package/dist/utils/get-package-name.js.map +1 -1
  320. package/dist/utils/get-packages.d.ts +1 -1
  321. package/dist/utils/get-packages.d.ts.map +1 -1
  322. package/dist/utils/get-packages.js +72 -57
  323. package/dist/utils/get-packages.js.map +1 -1
  324. package/dist/utils/get-startup-version.js +18 -8
  325. package/dist/utils/get-startup-version.js.map +1 -1
  326. package/dist/utils/get-tsconfig.js +19 -12
  327. package/dist/utils/get-tsconfig.js.map +1 -1
  328. package/dist/utils/index.d.ts +3 -0
  329. package/dist/utils/index.d.ts.map +1 -1
  330. package/dist/utils/index.js +34 -29
  331. package/dist/utils/index.js.map +1 -1
  332. package/dist/utils/load-shared-dependencies.js +23 -17
  333. package/dist/utils/load-shared-dependencies.js.map +1 -1
  334. package/dist/utils/log-errors.d.ts +2 -0
  335. package/dist/utils/log-errors.d.ts.map +1 -0
  336. package/dist/utils/log-errors.js +36 -0
  337. package/dist/utils/log-errors.js.map +1 -0
  338. package/dist/utils/log.d.ts +0 -1
  339. package/dist/utils/log.d.ts.map +1 -1
  340. package/dist/utils/log.js +38 -43
  341. package/dist/utils/log.js.map +1 -1
  342. package/dist/utils/pick.js +11 -3
  343. package/dist/utils/pick.js.map +1 -1
  344. package/dist/utils/read-json.js +27 -11
  345. package/dist/utils/read-json.js.map +1 -1
  346. package/dist/utils/to-array.js +13 -3
  347. package/dist/utils/to-array.js.map +1 -1
  348. package/dist/webpack/__mocks__/file-rules.d.ts.map +1 -1
  349. package/dist/webpack/configs/amd-config.js +13 -3
  350. package/dist/webpack/configs/amd-config.js.map +1 -1
  351. package/dist/webpack/configs/cache-config.js +20 -9
  352. package/dist/webpack/configs/cache-config.js.map +1 -1
  353. package/dist/webpack/configs/dev-server-config.d.ts +1 -1
  354. package/dist/webpack/configs/dev-server-config.d.ts.map +1 -1
  355. package/dist/webpack/configs/dev-server-config.js +47 -45
  356. package/dist/webpack/configs/dev-server-config.js.map +1 -1
  357. package/dist/webpack/configs/devtool-config.js +16 -7
  358. package/dist/webpack/configs/devtool-config.js.map +1 -1
  359. package/dist/webpack/configs/entry.config.d.ts.map +1 -1
  360. package/dist/webpack/configs/entry.config.js +28 -7
  361. package/dist/webpack/configs/entry.config.js.map +1 -1
  362. package/dist/webpack/configs/externals-config.js +17 -7
  363. package/dist/webpack/configs/externals-config.js.map +1 -1
  364. package/dist/webpack/configs/index.d.ts +2 -1
  365. package/dist/webpack/configs/index.d.ts.map +1 -1
  366. package/dist/webpack/configs/index.js +30 -28
  367. package/dist/webpack/configs/index.js.map +1 -1
  368. package/dist/webpack/configs/loaders/css-loader.js +22 -14
  369. package/dist/webpack/configs/loaders/css-loader.js.map +1 -1
  370. package/dist/webpack/configs/loaders/index.d.ts +1 -1
  371. package/dist/webpack/configs/loaders/index.d.ts.map +1 -1
  372. package/dist/webpack/configs/loaders/index.js +20 -19
  373. package/dist/webpack/configs/loaders/index.js.map +1 -1
  374. package/dist/webpack/configs/loaders/less-loader.js +18 -3
  375. package/dist/webpack/configs/loaders/less-loader.js.map +1 -1
  376. package/dist/webpack/configs/loaders/style-loader.js +23 -8
  377. package/dist/webpack/configs/loaders/style-loader.js.map +1 -1
  378. package/dist/webpack/configs/loaders/types.js +4 -1
  379. package/dist/webpack/configs/loaders/types.js.map +1 -1
  380. package/dist/webpack/configs/module-config.js +17 -5
  381. package/dist/webpack/configs/module-config.js.map +1 -1
  382. package/dist/webpack/configs/optimization-config.js +54 -28
  383. package/dist/webpack/configs/optimization-config.js.map +1 -1
  384. package/dist/webpack/configs/output-config.js +26 -12
  385. package/dist/webpack/configs/output-config.js.map +1 -1
  386. package/dist/webpack/configs/plugins/assets-manifest-plugin.js +23 -14
  387. package/dist/webpack/configs/plugins/assets-manifest-plugin.js.map +1 -1
  388. package/dist/webpack/configs/plugins/bundle-analyser-plugin.js +19 -9
  389. package/dist/webpack/configs/plugins/bundle-analyser-plugin.js.map +1 -1
  390. package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js +19 -11
  391. package/dist/webpack/configs/plugins/define-exposed-dependencies-plugin.js.map +1 -1
  392. package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js +17 -7
  393. package/dist/webpack/configs/plugins/define-exposed-instance-dependencies-plugin.js.map +1 -1
  394. package/dist/webpack/configs/plugins/define-web-component-name-plugin.js +13 -5
  395. package/dist/webpack/configs/plugins/define-web-component-name-plugin.js.map +1 -1
  396. package/dist/webpack/configs/plugins/filter-warnings-plugin.js +11 -3
  397. package/dist/webpack/configs/plugins/filter-warnings-plugin.js.map +1 -1
  398. package/dist/webpack/configs/plugins/html-plugin.js +28 -20
  399. package/dist/webpack/configs/plugins/html-plugin.js.map +1 -1
  400. package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js +24 -13
  401. package/dist/webpack/configs/plugins/ignore-plugin/check-resource.js.map +1 -1
  402. package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js +26 -16
  403. package/dist/webpack/configs/plugins/ignore-plugin/get-package-json.js.map +1 -1
  404. package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js +15 -6
  405. package/dist/webpack/configs/plugins/ignore-plugin/ignore-plugin.js.map +1 -1
  406. package/dist/webpack/configs/plugins/ignore-plugin/index.js +18 -16
  407. package/dist/webpack/configs/plugins/ignore-plugin/index.js.map +1 -1
  408. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js +22 -12
  409. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-peer-dependency.js.map +1 -1
  410. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js +11 -4
  411. package/dist/webpack/configs/plugins/ignore-plugin/is-optional-react-dom-peer-dependency.js.map +1 -1
  412. package/dist/webpack/configs/plugins/index.d.ts +0 -2
  413. package/dist/webpack/configs/plugins/index.d.ts.map +1 -1
  414. package/dist/webpack/configs/plugins/index.js +29 -29
  415. package/dist/webpack/configs/plugins/index.js.map +1 -1
  416. package/dist/webpack/configs/plugins/mini-css-extract-plugin.js +23 -12
  417. package/dist/webpack/configs/plugins/mini-css-extract-plugin.js.map +1 -1
  418. package/dist/webpack/configs/plugins/moment-locales-plugin.js +18 -8
  419. package/dist/webpack/configs/plugins/moment-locales-plugin.js.map +1 -1
  420. package/dist/webpack/configs/plugins/virtual-modules-plugin.js +32 -22
  421. package/dist/webpack/configs/plugins/virtual-modules-plugin.js.map +1 -1
  422. package/dist/webpack/configs/plugins/watch-run-plugin.js +23 -15
  423. package/dist/webpack/configs/plugins/watch-run-plugin.js.map +1 -1
  424. package/dist/webpack/configs/plugins-config.d.ts.map +1 -1
  425. package/dist/webpack/configs/plugins-config.js +27 -21
  426. package/dist/webpack/configs/plugins-config.js.map +1 -1
  427. package/dist/webpack/configs/resolve-config.js +16 -4
  428. package/dist/webpack/configs/resolve-config.js.map +1 -1
  429. package/dist/webpack/configs/rules/css-rules.js +43 -18
  430. package/dist/webpack/configs/rules/css-rules.js.map +1 -1
  431. package/dist/webpack/configs/rules/font-rules.js +13 -5
  432. package/dist/webpack/configs/rules/font-rules.js.map +1 -1
  433. package/dist/webpack/configs/rules/image-rules.js +13 -5
  434. package/dist/webpack/configs/rules/image-rules.js.map +1 -1
  435. package/dist/webpack/configs/rules/index.d.ts +0 -1
  436. package/dist/webpack/configs/rules/index.d.ts.map +1 -1
  437. package/dist/webpack/configs/rules/index.js +24 -23
  438. package/dist/webpack/configs/rules/index.js.map +1 -1
  439. package/dist/webpack/configs/rules/js-rules.d.ts +1 -1
  440. package/dist/webpack/configs/rules/js-rules.d.ts.map +1 -1
  441. package/dist/webpack/configs/rules/js-rules.js +47 -7
  442. package/dist/webpack/configs/rules/js-rules.js.map +1 -1
  443. package/dist/webpack/configs/rules/less-rules.js +25 -9
  444. package/dist/webpack/configs/rules/less-rules.js.map +1 -1
  445. package/dist/webpack/configs/rules/scss-rules.js +25 -9
  446. package/dist/webpack/configs/rules/scss-rules.js.map +1 -1
  447. package/dist/webpack/configs/rules/svg-rules.js +40 -20
  448. package/dist/webpack/configs/rules/svg-rules.js.map +1 -1
  449. package/dist/webpack/configs/rules-config.d.ts.map +1 -1
  450. package/dist/webpack/configs/rules-config.js +34 -19
  451. package/dist/webpack/configs/rules-config.js.map +1 -1
  452. package/dist/webpack/configs/stats-config.js +14 -4
  453. package/dist/webpack/configs/stats-config.js.map +1 -1
  454. package/dist/webpack/configs/types.d.ts +1 -3
  455. package/dist/webpack/configs/types.d.ts.map +1 -1
  456. package/dist/webpack/configs/types.js +4 -1
  457. package/dist/webpack/configs/types.js.map +1 -1
  458. package/dist/webpack/configs/utils/generate-metadata.js +40 -22
  459. package/dist/webpack/configs/utils/generate-metadata.js.map +1 -1
  460. package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js +20 -11
  461. package/dist/webpack/configs/utils/get-launchdarkly-sdk-version.js.map +1 -1
  462. package/dist/webpack/configs/utils/get-web-components-version.js +18 -8
  463. package/dist/webpack/configs/utils/get-web-components-version.js.map +1 -1
  464. package/dist/webpack/configs/utils/index.js +18 -16
  465. package/dist/webpack/configs/utils/index.js.map +1 -1
  466. package/dist/webpack/configs/watch-options-config.d.ts +6 -0
  467. package/dist/webpack/configs/watch-options-config.d.ts.map +1 -0
  468. package/dist/webpack/configs/watch-options-config.js +24 -0
  469. package/dist/webpack/configs/watch-options-config.js.map +1 -0
  470. package/dist/webpack/create-webpack-config.d.ts.map +1 -1
  471. package/dist/webpack/create-webpack-config.js +62 -50
  472. package/dist/webpack/create-webpack-config.js.map +1 -1
  473. package/dist/webpack/index.d.ts +1 -1
  474. package/dist/webpack/index.d.ts.map +1 -1
  475. package/dist/webpack/index.js +18 -17
  476. package/dist/webpack/index.js.map +1 -1
  477. package/dist/webpack/loaders/expose-loader/index.js +15 -15
  478. package/dist/webpack/loaders/expose-loader/index.js.map +1 -1
  479. package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js +5 -6
  480. package/dist/webpack/loaders/expose-loader/runtime/get-global-this.js.map +1 -1
  481. package/dist/webpack/loaders/expose-loader/utils/contextify-request.js +20 -13
  482. package/dist/webpack/loaders/expose-loader/utils/contextify-request.js.map +1 -1
  483. package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js +22 -11
  484. package/dist/webpack/loaders/expose-loader/utils/get-new-user-request.js.map +1 -1
  485. package/dist/webpack/loaders/expose-loader/utils/index.js +20 -18
  486. package/dist/webpack/loaders/expose-loader/utils/index.js.map +1 -1
  487. package/dist/webpack/loaders/expose-loader/utils/stringify-request.js +20 -12
  488. package/dist/webpack/loaders/expose-loader/utils/stringify-request.js.map +1 -1
  489. package/dist/webpack/types.d.ts +0 -4
  490. package/dist/webpack/types.d.ts.map +1 -1
  491. package/dist/webpack/types.js +4 -1
  492. package/dist/webpack/types.js.map +1 -1
  493. package/dist/webpack/utils/feature-cohort.js +17 -12
  494. package/dist/webpack/utils/feature-cohort.js.map +1 -1
  495. package/dist/webpack/utils/get-caller-filename.js +14 -7
  496. package/dist/webpack/utils/get-caller-filename.js.map +1 -1
  497. package/dist/webpack/utils/{bundle.d.ts → get-module-entry-path.d.ts} +1 -1
  498. package/dist/webpack/utils/get-module-entry-path.d.ts.map +1 -0
  499. package/dist/webpack/utils/get-module-entry-path.js +21 -0
  500. package/dist/webpack/utils/get-module-entry-path.js.map +1 -0
  501. package/dist/webpack/utils/hash-mod.js +16 -11
  502. package/dist/webpack/utils/hash-mod.js.map +1 -1
  503. package/dist/webpack/utils/index.d.ts +1 -1
  504. package/dist/webpack/utils/index.d.ts.map +1 -1
  505. package/dist/webpack/utils/index.js +21 -19
  506. package/dist/webpack/utils/index.js.map +1 -1
  507. package/dist/webpack/utils/split-by-entry.js +17 -7
  508. package/dist/webpack/utils/split-by-entry.js.map +1 -1
  509. package/dist/webpack/utils/testing/compile.js +12 -4
  510. package/dist/webpack/utils/testing/compile.js.map +1 -1
  511. package/dist/webpack/utils/testing/execute.js +26 -13
  512. package/dist/webpack/utils/testing/execute.js.map +1 -1
  513. package/dist/webpack/utils/testing/get-compiler.js +34 -24
  514. package/dist/webpack/utils/testing/get-compiler.js.map +1 -1
  515. package/dist/webpack/utils/testing/get-errors.js +12 -4
  516. package/dist/webpack/utils/testing/get-errors.js.map +1 -1
  517. package/dist/webpack/utils/testing/get-module-source.js +18 -5
  518. package/dist/webpack/utils/testing/get-module-source.js.map +1 -1
  519. package/dist/webpack/utils/testing/get-warnings.js +12 -4
  520. package/dist/webpack/utils/testing/get-warnings.js.map +1 -1
  521. package/dist/webpack/utils/testing/index.js +28 -20
  522. package/dist/webpack/utils/testing/index.js.map +1 -1
  523. package/dist/webpack/utils/testing/normalize-errors.js +11 -3
  524. package/dist/webpack/utils/testing/normalize-errors.js.map +1 -1
  525. package/dist/webpack/utils/testing/read-asset.js +20 -11
  526. package/dist/webpack/utils/testing/read-asset.js.map +1 -1
  527. package/dist/webpack/utils/testing/read-assets.js +13 -5
  528. package/dist/webpack/utils/testing/read-assets.js.map +1 -1
  529. package/package.json +20 -20
  530. package/src/cli/commands/__tests__/build.test.ts +69 -44
  531. package/src/cli/commands/__tests__/clean.test.ts +32 -0
  532. package/src/cli/commands/__tests__/install.test.ts +50 -8
  533. package/src/cli/commands/__tests__/kendo-ui-license.test.ts +5 -5
  534. package/src/cli/commands/__tests__/lint.test.ts +4 -0
  535. package/src/cli/commands/__tests__/mfe-package-publish.test.ts +21 -2
  536. package/src/cli/commands/__tests__/mfe-publish.test.ts +19 -23
  537. package/src/cli/commands/__tests__/prepare-package.test.ts +17 -36
  538. package/src/cli/commands/__tests__/start.test.ts +81 -44
  539. package/src/cli/commands/__tests__/tests.test.ts +4 -0
  540. package/src/cli/commands/build.ts +73 -35
  541. package/src/cli/commands/bundle-package.ts +0 -4
  542. package/src/cli/commands/clean.ts +24 -0
  543. package/src/cli/commands/eslint.ts +1 -1
  544. package/src/cli/commands/get-command.ts +25 -35
  545. package/src/cli/commands/index.ts +1 -1
  546. package/src/cli/commands/install.ts +29 -8
  547. package/src/cli/commands/lint.ts +22 -17
  548. package/src/cli/commands/mfe-package-publish.ts +22 -5
  549. package/src/cli/commands/mfe-publish.ts +5 -18
  550. package/src/cli/commands/prepare-package.ts +8 -12
  551. package/src/cli/commands/review/__mocks__/expect-calls.ts +48 -0
  552. package/src/cli/commands/review/__mocks__/index.ts +1 -0
  553. package/src/cli/commands/review/__tests__/review.test.ts +483 -0
  554. package/src/cli/commands/review/index.ts +3 -0
  555. package/src/cli/commands/review/review.ts +247 -0
  556. package/src/cli/commands/review/rules/__mocks__/index.ts +3 -0
  557. package/src/cli/commands/review/rules/__mocks__/mock-config.ts +14 -0
  558. package/src/cli/commands/review/rules/__mocks__/mock-packages.ts +41 -0
  559. package/src/cli/commands/review/rules/__mocks__/mock-project.ts +11 -0
  560. package/src/cli/commands/review/rules/__tests__/no-typescript-entry-point.test.ts +166 -0
  561. package/src/cli/commands/review/rules/__tests__/require-explicit-side-effects.test.ts +113 -0
  562. package/src/cli/commands/review/rules/__tests__/require-npmrc.test.ts +71 -0
  563. package/src/cli/commands/review/rules/__tests__/require-one-anvil-uikit-contrib-version.test.ts +33 -0
  564. package/src/cli/commands/review/rules/__tests__/require-one-collection-version.test.ts +155 -0
  565. package/src/cli/commands/review/rules/__tests__/require-one-package-version.test.ts +135 -0
  566. package/src/cli/commands/review/rules/__tests__/require-one-uikit-version.ts +40 -0
  567. package/src/cli/commands/review/rules/__tests__/require-project-version-in-root-node-modules.test.ts +186 -0
  568. package/src/cli/commands/review/rules/__tests__/require-servicetitan-scope.test.ts +83 -0
  569. package/src/cli/commands/review/rules/index.ts +20 -0
  570. package/src/cli/commands/review/rules/no-typescript-entry-point.ts +78 -0
  571. package/src/cli/commands/review/rules/require-explicit-side-effects.ts +31 -0
  572. package/src/cli/commands/review/rules/require-npmrc.ts +27 -0
  573. package/src/cli/commands/review/rules/require-one-anvil-uikit-contrib-version.ts +20 -0
  574. package/src/cli/commands/review/rules/require-one-collection-version.ts +169 -0
  575. package/src/cli/commands/review/rules/require-one-package-version.ts +76 -0
  576. package/src/cli/commands/review/rules/require-one-uikit-version.ts +27 -0
  577. package/src/cli/commands/review/rules/require-project-version-in-root-node-modules.ts +104 -0
  578. package/src/cli/commands/review/rules/require-servicetitan-scope.ts +27 -0
  579. package/src/cli/commands/review/types.ts +72 -0
  580. package/src/cli/commands/review/utils/__tests__/compare-version.test.ts +73 -0
  581. package/src/cli/commands/review/utils/__tests__/get-max-version.test.ts +17 -0
  582. package/src/cli/commands/review/utils/__tests__/indent.test.ts +41 -0
  583. package/src/cli/commands/review/utils/__tests__/name-to-location.test.ts +39 -0
  584. package/src/cli/commands/review/utils/__tests__/set-version.test.ts +84 -0
  585. package/src/cli/commands/review/utils/apply-filter.ts +14 -0
  586. package/src/cli/commands/review/utils/collate-dependencies.ts +46 -0
  587. package/src/cli/commands/review/utils/compare-version.ts +82 -0
  588. package/src/cli/commands/review/utils/format-depends-on.ts +11 -0
  589. package/src/cli/commands/review/utils/format-location.ts +8 -0
  590. package/src/cli/commands/review/utils/get-key.ts +10 -0
  591. package/src/cli/commands/review/utils/get-max-version.ts +5 -0
  592. package/src/cli/commands/review/utils/indent.ts +8 -0
  593. package/src/cli/commands/review/utils/index.ts +13 -0
  594. package/src/cli/commands/review/utils/is-library.ts +5 -0
  595. package/src/cli/commands/review/utils/name-to-location.ts +7 -0
  596. package/src/cli/commands/review/utils/pluralize.ts +3 -0
  597. package/src/cli/commands/review/utils/set-version.ts +26 -0
  598. package/src/cli/commands/review/utils/summarize.ts +21 -0
  599. package/src/cli/commands/run-task.test.ts +60 -0
  600. package/src/cli/commands/start.ts +130 -55
  601. package/src/cli/commands/tests.ts +2 -0
  602. package/src/cli/commands/types.ts +1 -0
  603. package/src/cli/index.ts +4 -4
  604. package/src/cli/tasks/__tests__/cli-task.test.ts +16 -4
  605. package/src/cli/tasks/__tests__/{swc-compile.test.ts → swc-compile-package.test.ts} +75 -36
  606. package/src/cli/tasks/__tests__/tsc-compile-package.test.ts +1 -0
  607. package/src/cli/tasks/__tests__/tsc-compile.test.ts +12 -23
  608. package/src/cli/tasks/cli-task.ts +12 -18
  609. package/src/cli/tasks/swc-cli.d.ts +12 -1
  610. package/src/cli/tasks/swc-compile-package.ts +71 -45
  611. package/src/cli/tasks/task.ts +2 -11
  612. package/src/cli/tasks/tsc-compile-package.ts +0 -4
  613. package/src/cli/tasks/tsc-compile.ts +14 -17
  614. package/src/cli/types/cpx2.d.ts +8 -1
  615. package/src/cli/utils/__tests__/bundle.test.ts +1 -1
  616. package/src/cli/utils/__tests__/check-args.test.ts +34 -0
  617. package/src/cli/utils/__tests__/compile.test.ts +59 -0
  618. package/src/cli/utils/__tests__/copy-files.test.ts +157 -0
  619. package/src/cli/utils/__tests__/get-module-type.test.ts +19 -0
  620. package/src/cli/utils/__tests__/lerna-exec.test.ts +58 -11
  621. package/src/cli/utils/__tests__/pipe-stdout.test.ts +39 -0
  622. package/src/cli/utils/__tests__/process-tree.test.ts +175 -0
  623. package/src/cli/utils/__tests__/set-node-options.test.ts +51 -6
  624. package/src/cli/utils/__tests__/tcm.test.ts +90 -86
  625. package/src/cli/utils/__tests__/type-check.test.ts +47 -0
  626. package/src/cli/utils/__tests__/watch-stdout.test.ts +68 -0
  627. package/src/cli/utils/bundle.ts +5 -18
  628. package/src/cli/utils/check-args.ts +13 -0
  629. package/src/cli/utils/compile-less.ts +0 -1
  630. package/src/cli/utils/compile-sass.ts +0 -1
  631. package/src/cli/utils/compile.ts +22 -0
  632. package/src/cli/utils/copy-files.ts +76 -0
  633. package/src/cli/utils/eslint.ts +1 -0
  634. package/src/cli/utils/get-module-type.ts +4 -6
  635. package/src/cli/utils/index.ts +7 -6
  636. package/src/cli/utils/lerna-exec.ts +17 -10
  637. package/src/cli/utils/pipe-stdout.ts +10 -0
  638. package/src/cli/utils/process-tree.ts +57 -0
  639. package/src/cli/utils/set-node-options.ts +15 -12
  640. package/src/cli/utils/style-extensions.ts +1 -0
  641. package/src/cli/utils/tcm.ts +22 -32
  642. package/src/cli/utils/type-check.ts +19 -0
  643. package/src/cli/utils/watch-stdout.ts +24 -0
  644. package/src/utils/__tests__/format-duration.test.ts +22 -0
  645. package/src/utils/__tests__/get-configuration.test.ts +44 -2
  646. package/src/utils/__tests__/get-packages.test.ts +58 -49
  647. package/src/utils/__tests__/log-errors.test.ts +102 -0
  648. package/src/utils/__tests__/log.test.ts +1 -86
  649. package/src/utils/find-packages.ts +12 -6
  650. package/src/utils/format-duration.ts +13 -0
  651. package/src/utils/get-configuration.ts +19 -5
  652. package/src/utils/get-folders.ts +3 -1
  653. package/src/utils/get-packages.ts +9 -16
  654. package/src/utils/index.ts +3 -0
  655. package/src/utils/log-errors.ts +29 -0
  656. package/src/utils/log.ts +0 -26
  657. package/src/webpack/__mocks__/file-rules.ts +0 -5
  658. package/src/webpack/__tests__/create-webpack-config-web-component.test.ts +4 -5
  659. package/src/webpack/__tests__/create-webpack-config.test.ts +33 -112
  660. package/src/webpack/configs/dev-server-config.ts +4 -27
  661. package/src/webpack/configs/devtool-config.ts +2 -2
  662. package/src/webpack/configs/entry.config.ts +7 -2
  663. package/src/webpack/configs/index.ts +2 -1
  664. package/src/webpack/configs/loaders/index.ts +1 -1
  665. package/src/webpack/configs/optimization-config.ts +2 -2
  666. package/src/webpack/configs/plugins/index.ts +0 -2
  667. package/src/webpack/configs/plugins/virtual-modules-plugin.ts +3 -3
  668. package/src/webpack/configs/plugins-config.ts +0 -4
  669. package/src/webpack/configs/resolve-config.ts +1 -1
  670. package/src/webpack/configs/rules/index.ts +0 -1
  671. package/src/webpack/configs/rules/js-rules.ts +27 -2
  672. package/src/webpack/configs/rules-config.ts +1 -11
  673. package/src/webpack/configs/types.ts +1 -3
  674. package/src/webpack/configs/watch-options-config.ts +17 -0
  675. package/src/webpack/create-webpack-config.ts +3 -4
  676. package/src/webpack/index.ts +1 -1
  677. package/src/webpack/types.ts +0 -4
  678. package/src/webpack/utils/index.ts +1 -1
  679. package/dist/__mocks__/create-package.js +0 -17
  680. package/dist/__mocks__/create-package.js.map +0 -1
  681. package/dist/__mocks__/index.js +0 -18
  682. package/dist/__mocks__/index.js.map +0 -1
  683. package/dist/cli/utils/assets-copy.d.ts +0 -3
  684. package/dist/cli/utils/assets-copy.d.ts.map +0 -1
  685. package/dist/cli/utils/assets-copy.js +0 -25
  686. package/dist/cli/utils/assets-copy.js.map +0 -1
  687. package/dist/cli/utils/styles-copy.d.ts +0 -3
  688. package/dist/cli/utils/styles-copy.d.ts.map +0 -1
  689. package/dist/cli/utils/styles-copy.js +0 -25
  690. package/dist/cli/utils/styles-copy.js.map +0 -1
  691. package/dist/cli/utils/tsc.d.ts +0 -5
  692. package/dist/cli/utils/tsc.d.ts.map +0 -1
  693. package/dist/cli/utils/tsc.js +0 -37
  694. package/dist/cli/utils/tsc.js.map +0 -1
  695. package/dist/webpack/__mocks__/file-rules.js +0 -79
  696. package/dist/webpack/__mocks__/file-rules.js.map +0 -1
  697. package/dist/webpack/__mocks__/index.js +0 -19
  698. package/dist/webpack/__mocks__/index.js.map +0 -1
  699. package/dist/webpack/__mocks__/style-rules.js +0 -124
  700. package/dist/webpack/__mocks__/style-rules.js.map +0 -1
  701. package/dist/webpack/configs/plugins/provide-react-plugin.d.ts +0 -4
  702. package/dist/webpack/configs/plugins/provide-react-plugin.d.ts.map +0 -1
  703. package/dist/webpack/configs/plugins/provide-react-plugin.js +0 -13
  704. package/dist/webpack/configs/plugins/provide-react-plugin.js.map +0 -1
  705. package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts +0 -4
  706. package/dist/webpack/configs/plugins/ts-checker-plugin.d.ts.map +0 -1
  707. package/dist/webpack/configs/plugins/ts-checker-plugin.js +0 -30
  708. package/dist/webpack/configs/plugins/ts-checker-plugin.js.map +0 -1
  709. package/dist/webpack/configs/rules/tsx-rules.d.ts +0 -4
  710. package/dist/webpack/configs/rules/tsx-rules.d.ts.map +0 -1
  711. package/dist/webpack/configs/rules/tsx-rules.js +0 -44
  712. package/dist/webpack/configs/rules/tsx-rules.js.map +0 -1
  713. package/dist/webpack/utils/bundle.d.ts.map +0 -1
  714. package/dist/webpack/utils/bundle.js +0 -19
  715. package/dist/webpack/utils/bundle.js.map +0 -1
  716. package/src/cli/utils/__tests__/assets-copy.test.ts +0 -52
  717. package/src/cli/utils/__tests__/styles-copy.test.ts +0 -52
  718. package/src/cli/utils/__tests__/tsc.test.ts +0 -63
  719. package/src/cli/utils/assets-copy.ts +0 -23
  720. package/src/cli/utils/styles-copy.ts +0 -23
  721. package/src/cli/utils/tsc.ts +0 -38
  722. package/src/webpack/configs/plugins/provide-react-plugin.ts +0 -12
  723. package/src/webpack/configs/plugins/ts-checker-plugin.ts +0 -33
  724. package/src/webpack/configs/rules/tsx-rules.ts +0 -48
  725. /package/src/webpack/utils/{bundle.ts → get-module-entry-path.ts} +0 -0
@@ -1,8 +1,9 @@
1
- import execa from 'execa';
1
+ import { execSync } from 'child_process';
2
+ import { log } from '../../../utils';
2
3
 
3
4
  import { Install } from '../install';
4
5
 
5
- jest.mock('execa', () => jest.fn());
6
+ jest.mock('child_process', () => ({ execSync: jest.fn() }));
6
7
  jest.mock('../../../utils', () => ({
7
8
  ...jest.requireActual('../../../utils'),
8
9
  log: { info: jest.fn() }, // suppress log output
@@ -10,17 +11,31 @@ jest.mock('../../../utils', () => ({
10
11
 
11
12
  describe(`${Install.name}`, () => {
12
13
  const OLD_ENV = process.env;
13
- const options = ['--no-audit', '--legacy-peer-deps'];
14
+ const options = ['--audit=false', '--fund=false', '--legacy-peer-deps'];
15
+ let args: ConstructorParameters<typeof Install>[0];
16
+
17
+ beforeEach(() => {
18
+ process.env = {};
19
+ args = undefined;
20
+ jest.clearAllMocks();
21
+ });
14
22
 
15
- beforeEach(() => (process.env = {}));
16
23
  afterEach(() => (process.env = OLD_ENV));
17
24
 
18
- const subject = async () => new Install().execute();
25
+ const subject = async () => new Install(args).execute();
26
+
27
+ test(`runs npm i ${options.join(' ')}`, async () => {
28
+ await subject();
29
+
30
+ expect(execSync).toHaveBeenCalledWith(`npm i ${options.join(' ')}`, {
31
+ stdio: 'inherit',
32
+ });
33
+ });
19
34
 
20
- test('runs npm i', async () => {
35
+ test('logs progress', async () => {
21
36
  await subject();
22
37
 
23
- expect(execa).toHaveBeenCalledWith('npm', ['i', ...options], expect.anything());
38
+ expect(log.info).toHaveBeenCalled();
24
39
  });
25
40
 
26
41
  describe('when in CI environment', () => {
@@ -29,7 +44,34 @@ describe(`${Install.name}`, () => {
29
44
  test('runs npm ci', async () => {
30
45
  await subject();
31
46
 
32
- expect(execa).toHaveBeenCalledWith('npm', ['ci', ...options], expect.anything());
47
+ expect(execSync).toHaveBeenCalledWith(`npm ci ${options.join(' ')}`, {
48
+ stdio: 'inherit',
49
+ });
50
+ });
51
+ });
52
+
53
+ describe('with --quite', () => {
54
+ beforeEach(() => (args = { quiet: true }));
55
+
56
+ test('does not log progress', async () => {
57
+ await subject();
58
+
59
+ expect(log.info).not.toHaveBeenCalled();
60
+ });
61
+ });
62
+
63
+ describe('with --fix', () => {
64
+ const fixOptions = [...options, '--package-lock-only', '--prefer-dedupe'];
65
+
66
+ beforeEach(() => (args = { fix: true }));
67
+
68
+ test(`runs npm i ${fixOptions.join(' ')}`, async () => {
69
+ await subject();
70
+
71
+ expect(execSync).toHaveBeenCalledWith(
72
+ `npm i ${fixOptions.join(' ')}`,
73
+ expect.anything()
74
+ );
33
75
  });
34
76
  });
35
77
  });
@@ -1,15 +1,14 @@
1
1
  import execa from 'execa';
2
2
 
3
- import { log } from '../../../utils/log';
3
+ import { log } from '../../../utils';
4
4
  import { isModuleInstalled } from '../../utils';
5
5
  import { kendoUILicense } from '../kendo-ui-license';
6
6
 
7
7
  jest.mock('execa', () => jest.fn());
8
8
 
9
- jest.mock('../../../utils/log', () => ({
10
- log: {
11
- info: jest.fn(),
12
- },
9
+ jest.mock('../../../utils', () => ({
10
+ ...jest.requireActual('../../../utils'),
11
+ log: { info: jest.fn() },
13
12
  }));
14
13
 
15
14
  jest.mock('../../utils/is-module-installed', () => ({
@@ -75,6 +74,7 @@ describe(`${kendoUILicense.name}`, () => {
75
74
  beforeEach(() => (execa as any).mockRejectedValue({ exitCode }));
76
75
 
77
76
  test('throws error', async () => {
77
+ jest.spyOn(process.stdout, 'write').mockImplementationOnce(jest.fn()); // suppress error output
78
78
  await expect(subject()).rejects.toThrow(`command failed with exit code ${exitCode}`);
79
79
  });
80
80
  });
@@ -38,6 +38,10 @@ describe(`[startup] ${Lint.name}`, () => {
38
38
  );
39
39
  });
40
40
 
41
+ test('command is greedy', () => {
42
+ expect(new Lint(args).greedy).toBe(true);
43
+ });
44
+
41
45
  test('runs eslint directly', async () => {
42
46
  await subject();
43
47
 
@@ -176,8 +176,27 @@ describe(`[startup] ${MFEPackagePublish.name}`, () => {
176
176
  test('sets package files to "package.json"', async () => {
177
177
  await subject();
178
178
 
179
- expect(npmPackageSet).toHaveBeenCalledWith('files[0]', 'dist');
180
- expect(npmPackageSet).toHaveBeenCalledWith('files[1]', 'package.json');
179
+ ['dist/bundle', 'dist/metadata.json', 'package.json'].forEach((file, index) => {
180
+ expect(npmPackageSet).toHaveBeenCalledWith(`files[${index}]`, file);
181
+ });
182
+ });
183
+ });
184
+
185
+ describe('when package files contains "dist"', () => {
186
+ const files = ['dist', 'package.json', 'other.json'];
187
+
188
+ beforeEach(() =>
189
+ vol.fromJSON({
190
+ 'package.json': JSON.stringify({ name: packageName, files }),
191
+ })
192
+ );
193
+
194
+ test('replaces "dist" with "dist/bundle" and "dist/metadata.json"', async () => {
195
+ await subject();
196
+
197
+ ['dist/bundle', 'dist/metadata.json', ...files.slice(1)].forEach((file, index) => {
198
+ expect(npmPackageSet).toHaveBeenCalledWith(`files[${index}]`, file);
199
+ });
181
200
  });
182
201
  });
183
202
 
@@ -39,8 +39,18 @@ describe(`[startup] ${MFEPublish.name}`, () => {
39
39
  });
40
40
  }
41
41
 
42
- describe('with TSC package', () => {
43
- beforeEach(() => packages.push(createPackage({ type: PackageType.TSC })));
42
+ test('selects Webpack packages', async () => {
43
+ jest.spyOn(process.stdout, 'write').mockImplementation(jest.fn()); // suppress error output
44
+ try {
45
+ await subject();
46
+ } catch {
47
+ /* ignore */
48
+ }
49
+ expect(getPackages).toHaveBeenCalledWith({ type: PackageType.Webpack });
50
+ });
51
+
52
+ describe('with no packages', () => {
53
+ beforeEach(() => (packages = []));
44
54
 
45
55
  itReportsError();
46
56
  });
@@ -73,7 +83,7 @@ describe(`[startup] ${MFEPublish.name}`, () => {
73
83
  'cmd': 'startup mfe-package-publish',
74
84
  'scope': packages.map(({ name }) => name),
75
85
  'stream': true,
76
- 'concurrency': 1,
86
+ 'parallel': 1,
77
87
  '--': [],
78
88
  });
79
89
  });
@@ -155,7 +165,7 @@ describe(`[startup] ${MFEPublish.name}`, () => {
155
165
  test('runs lernaExec with {concurrency: 0}', async () => {
156
166
  await subject();
157
167
 
158
- expect(lernaExec).toHaveBeenCalledWith(expect.objectContaining({ concurrency: 0 }));
168
+ expect(lernaExec).toHaveBeenCalledWith(expect.objectContaining({ parallel: 0 }));
159
169
  });
160
170
  });
161
171
 
@@ -184,28 +194,14 @@ describe(`[startup] ${MFEPublish.name}`, () => {
184
194
  );
185
195
  });
186
196
 
187
- describe('with "{scope: string}"', () => {
188
- beforeEach(() => (args.scope = packages[0].name));
197
+ describe('with "{scope}"', () => {
198
+ beforeEach(() => (args.scope = [packages[0].name]));
189
199
 
190
- test('publishes specified packages', async () => {
200
+ test('selects specified packages', async () => {
191
201
  await subject();
192
202
 
193
- expect(lernaExec).toHaveBeenCalledWith(
194
- expect.objectContaining({ scope: [packages[0].name] })
195
- );
196
- });
197
- });
198
-
199
- describe('with "{scope: Array<string>}"', () => {
200
- beforeEach(() => (args.scope = packages.slice(1).map(({ name }) => name)));
201
-
202
- test('publishes the specified packages', async () => {
203
- await subject();
204
-
205
- expect(lernaExec).toHaveBeenCalledWith(
206
- expect.objectContaining({
207
- scope: packages.slice(1).map(({ name }) => name),
208
- })
203
+ expect(getPackages).toHaveBeenCalledWith(
204
+ expect.objectContaining({ scope: args.scope })
209
205
  );
210
206
  });
211
207
  });
@@ -1,35 +1,16 @@
1
- import { isBundle } from '../../../utils';
2
- import {
3
- assetsCopy,
4
- assetsCopyWatch,
5
- stylesCopy,
6
- stylesCopyWatch,
7
- tcm,
8
- tcmWatch,
9
- } from '../../utils';
10
-
1
+ import { tcm, copyFiles } from '../../utils';
11
2
  import { PreparePackage } from '../prepare-package';
12
3
 
13
- jest.mock('../../../utils', () => ({
14
- ...jest.requireActual('../../../utils'),
15
- isBundle: jest.fn(),
16
- }));
17
-
18
4
  jest.mock('../../utils', () => ({
19
5
  ...jest.requireActual('../../utils'),
20
- assetsCopy: jest.fn().mockResolvedValue(undefined),
21
- assetsCopyWatch: jest.fn().mockResolvedValue(undefined),
22
- stylesCopy: jest.fn().mockResolvedValue(undefined),
23
- stylesCopyWatch: jest.fn().mockResolvedValue(undefined),
24
- tcm: jest.fn().mockResolvedValue(undefined),
25
- tcmWatch: jest.fn().mockResolvedValue(undefined),
6
+ tcm: jest.fn(),
7
+ copyFiles: jest.fn(),
26
8
  }));
27
9
 
28
10
  describe(`[startup] ${PreparePackage.name}`, () => {
29
11
  let args: ConstructorParameters<typeof PreparePackage>[0];
30
12
 
31
13
  beforeEach(() => {
32
- jest.mocked(isBundle).mockReturnValue(true);
33
14
  args = {};
34
15
  });
35
16
 
@@ -41,34 +22,34 @@ describe(`[startup] ${PreparePackage.name}`, () => {
41
22
  expect(tcm).toHaveBeenCalled();
42
23
  });
43
24
 
44
- describe('when package is not a bundle', () => {
45
- beforeEach(() => jest.mocked(isBundle).mockReturnValue(false));
25
+ describe('with "watch"', () => {
26
+ beforeEach(() => (args.watch = true));
46
27
 
47
- test('copies assets and styles', async () => {
28
+ test('runs tcm in watch mode', async () => {
48
29
  await subject();
49
30
 
50
- expect(assetsCopy).toHaveBeenCalled();
51
- expect(stylesCopy).toHaveBeenCalled();
31
+ expect(tcm).toHaveBeenCalledWith({ watch: true });
52
32
  });
53
33
  });
54
34
 
55
- describe('with "watch"', () => {
56
- beforeEach(() => (args.watch = true));
35
+ describe('with --copy-files flag', () => {
36
+ beforeEach(() => {
37
+ args['copy-files'] = true;
38
+ });
57
39
 
58
- test('runs tcm in watch mode', async () => {
40
+ test('runs copyFiles', async () => {
59
41
  await subject();
60
42
 
61
- expect(tcmWatch).toHaveBeenCalled();
43
+ expect(copyFiles).toHaveBeenCalled();
62
44
  });
63
45
 
64
- describe('when package is not a bundle', () => {
65
- beforeEach(() => jest.mocked(isBundle).mockReturnValue(false));
46
+ describe('with "watch"', () => {
47
+ beforeEach(() => (args.watch = true));
66
48
 
67
- test('copies assets and styles in watch mode', async () => {
49
+ test('runs copyFiles in watch mode', async () => {
68
50
  await subject();
69
51
 
70
- expect(assetsCopyWatch).toHaveBeenCalled();
71
- expect(stylesCopyWatch).toHaveBeenCalled();
52
+ expect(copyFiles).toHaveBeenCalledWith({ watch: true });
72
53
  });
73
54
  });
74
55
  });
@@ -1,6 +1,6 @@
1
- import { Package, PackageType, getPackages } from '../../../utils';
1
+ import { Package, PackageType, getPackages, log } from '../../../utils';
2
2
  import { createPackage } from '../../../__mocks__';
3
- import { lernaExec, tsc, tscWatch } from '../../utils';
3
+ import { lernaExec, compile, typeCheck, watchStdout } from '../../utils';
4
4
 
5
5
  import { Start } from '../start';
6
6
 
@@ -8,7 +8,26 @@ jest.mock('../../../utils', () => ({
8
8
  ...jest.requireActual('../../../utils'),
9
9
  getPackages: jest.fn(),
10
10
  }));
11
- jest.mock('../../utils');
11
+ jest.mock('../../utils', () => ({
12
+ ...jest.requireActual('../../utils'),
13
+ lernaExec: jest.fn(() => Promise.resolve()),
14
+ compile: jest.fn(() =>
15
+ Object.assign(Promise.resolve(), {
16
+ stdout: {
17
+ on: jest.fn(),
18
+ off: jest.fn(),
19
+ },
20
+ })
21
+ ),
22
+ typeCheck: jest.fn(() =>
23
+ Object.assign(Promise.resolve(), {
24
+ stdout: {
25
+ on: jest.fn(),
26
+ },
27
+ })
28
+ ),
29
+ watchStdout: jest.fn(),
30
+ }));
12
31
 
13
32
  describe(`[startup] ${Start.name}`, () => {
14
33
  let args: ConstructorParameters<typeof Start>[0];
@@ -17,20 +36,26 @@ describe(`[startup] ${Start.name}`, () => {
17
36
  beforeEach(() => {
18
37
  args = {};
19
38
  packages = [];
20
- jest.resetAllMocks();
39
+ jest.clearAllMocks();
21
40
  jest.mocked(getPackages).mockImplementation(() => packages);
41
+ jest.mocked(watchStdout).mockImplementation((_process, _indicator, handler) => {
42
+ handler(packages.length);
43
+ return jest.fn();
44
+ });
22
45
  });
23
46
 
24
- const subject = async () => new Start(args).execute();
47
+ const subject = () => new Start(args).execute();
25
48
 
26
- function itPreparesThePackages() {
49
+ function itPreparesThePackages({ copyFiles = false }: { copyFiles?: boolean } = {}) {
27
50
  test('prepares the package, then again in watch mode', async () => {
28
51
  await subject();
29
52
 
30
53
  expect(lernaExec).toHaveBeenCalledWith({
31
54
  cmd: 'startup prepare-package',
55
+ parallel: true,
32
56
  scope: packages.map(({ name }) => name),
33
57
  stream: true,
58
+ ...(copyFiles ? { '--': ['--copy-files'] } : {}),
34
59
  });
35
60
 
36
61
  expect(lernaExec).toHaveBeenCalledWith({
@@ -38,21 +63,42 @@ describe(`[startup] ${Start.name}`, () => {
38
63
  'scope': packages.map(({ name }) => name),
39
64
  'parallel': true,
40
65
  'stream': true,
41
- '--': ['--watch'],
66
+ '--': ['--watch', ...(copyFiles ? ['--copy-files'] : [])],
42
67
  });
43
68
  });
44
69
  }
45
70
 
71
+ function itRunsCompileAndTypeCheck({ useTsc = false }: { useTsc?: boolean } = {}) {
72
+ test('runs compile and typeCheck', async () => {
73
+ await subject();
74
+
75
+ expect(compile).toHaveBeenCalledWith({
76
+ packages: packages.map(({ name }) => name),
77
+ watch: true,
78
+ ...(useTsc ? { useTsc } : {}),
79
+ });
80
+ expect(typeCheck).toHaveBeenCalledWith({
81
+ packages: packages.map(({ name }) => name),
82
+ watch: true,
83
+ });
84
+ });
85
+ }
86
+
87
+ test('command is greedy', () => {
88
+ expect(new Start(args).greedy).toBe(true);
89
+ });
90
+
46
91
  describe('with TSC package', () => {
47
92
  beforeEach(() => packages.push(createPackage({ type: PackageType.TSC })));
48
93
 
49
94
  itPreparesThePackages();
95
+ itRunsCompileAndTypeCheck();
50
96
 
51
- test('runs tsc, then again in watch mode', async () => {
52
- await subject();
97
+ describe('with --use-tsc flag', () => {
98
+ beforeEach(() => (args['use-tsc'] = true));
53
99
 
54
- expect(tsc).toHaveBeenCalledWith(packages);
55
- expect(tscWatch).toHaveBeenCalledWith(packages);
100
+ itPreparesThePackages({ copyFiles: true });
101
+ itRunsCompileAndTypeCheck({ useTsc: true });
56
102
  });
57
103
  });
58
104
 
@@ -60,6 +106,7 @@ describe(`[startup] ${Start.name}`, () => {
60
106
  beforeEach(() => packages.push(createPackage({ type: PackageType.Webpack })));
61
107
 
62
108
  itPreparesThePackages();
109
+ itRunsCompileAndTypeCheck();
63
110
 
64
111
  test('bundles the package in watch mode', async () => {
65
112
  await subject();
@@ -69,7 +116,7 @@ describe(`[startup] ${Start.name}`, () => {
69
116
  'scope': packages.map(({ name }) => name),
70
117
  'parallel': true,
71
118
  'stream': true,
72
- '--': ['--color', '--watch'],
119
+ '--': ['--watch'],
73
120
  });
74
121
  });
75
122
 
@@ -81,35 +128,7 @@ describe(`[startup] ${Start.name}`, () => {
81
128
 
82
129
  expect(lernaExec).toHaveBeenCalledWith(
83
130
  expect.objectContaining({
84
- '--': ['--color', '--watch', '--code-coverage'],
85
- })
86
- );
87
- });
88
- });
89
-
90
- describe('with "esbuild"', () => {
91
- beforeEach(() => (args.esbuild = true));
92
-
93
- test('enables esbuild loader', async () => {
94
- await subject();
95
-
96
- expect(lernaExec).toHaveBeenCalledWith(
97
- expect.objectContaining({
98
- '--': ['--color', '--watch', '--esbuild'],
99
- })
100
- );
101
- });
102
- });
103
-
104
- describe('with "experimental-bundlers"', () => {
105
- beforeEach(() => (args['experimental-bundlers'] = true));
106
-
107
- test('enables swc-loader', async () => {
108
- await subject();
109
-
110
- expect(lernaExec).toHaveBeenCalledWith(
111
- expect.objectContaining({
112
- '--': ['--color', '--watch', '--experimental-bundlers'],
131
+ '--': ['--watch', '--code-coverage'],
113
132
  })
114
133
  );
115
134
  });
@@ -123,7 +142,7 @@ describe(`[startup] ${Start.name}`, () => {
123
142
 
124
143
  expect(lernaExec).toHaveBeenCalledWith(
125
144
  expect.objectContaining({
126
- '--': ['--color', '--watch', `--config "${args.config}"`],
145
+ '--': ['--watch', `--config "${args.config}"`],
127
146
  })
128
147
  );
129
148
  });
@@ -136,7 +155,9 @@ describe(`[startup] ${Start.name}`, () => {
136
155
  test('selects scoped packages', async () => {
137
156
  await subject();
138
157
 
139
- expect(getPackages).toHaveBeenCalledWith({ scope: args.scope });
158
+ expect(getPackages).toHaveBeenCalledWith(
159
+ expect.objectContaining({ scope: args.scope })
160
+ );
140
161
  });
141
162
  });
142
163
 
@@ -146,7 +167,23 @@ describe(`[startup] ${Start.name}`, () => {
146
167
  test('selectively ignores packages', async () => {
147
168
  await subject();
148
169
 
149
- expect(getPackages).toHaveBeenCalledWith({ ignore: args.ignore });
170
+ expect(getPackages).toHaveBeenCalledWith(
171
+ expect.objectContaining({ ignore: args.ignore })
172
+ );
173
+ });
174
+ });
175
+
176
+ describe.each(['esbuild', 'experimental-bundlers'])('with "%s"', arg => {
177
+ beforeEach(() => ((args as Record<string, any>)[arg] = true));
178
+
179
+ test('logs warning', async () => {
180
+ const logSpy = jest.spyOn(log, 'warning');
181
+
182
+ await subject();
183
+
184
+ expect(logSpy).toHaveBeenCalledWith(
185
+ expect.stringContaining(`--${arg} option is obsolete`)
186
+ );
150
187
  });
151
188
  });
152
189
  });
@@ -22,6 +22,10 @@ describe(`[startup] ${Tests.name}`, () => {
22
22
 
23
23
  const subject = async () => new Tests(args).execute();
24
24
 
25
+ test('command is greedy', () => {
26
+ expect(new Tests(args).greedy).toBe(true);
27
+ });
28
+
25
29
  test('runs Jest CLI', async () => {
26
30
  await subject();
27
31
 
@@ -1,19 +1,29 @@
1
- import { getPackages, logErrors, PackageType, splitPackagesByType } from '../../utils';
2
- import { lernaExec, tsc } from '../utils';
3
- import { Command, kendoUILicense } from '.';
1
+ import { getPackages, logErrors, PackageType } from '../../utils';
2
+ import { checkArgs, compile, lernaExec, typeCheck, ProcessTree } from '../utils';
3
+ import { kendoUILicense } from './kendo-ui-license';
4
+ import { Command } from './types';
4
5
 
5
6
  interface Args {
6
7
  'cdn-path'?: string;
7
8
  'code-coverage'?: boolean;
8
9
  'config'?: string;
9
- 'esbuild'?: boolean;
10
- 'experimental-bundlers'?: boolean;
11
10
  'ignore'?: string | string[];
12
11
  'scope'?: string | string[];
13
12
  'stat'?: boolean;
13
+ 'use-tsc'?: boolean;
14
+ }
15
+
16
+ export enum BuildProcesses {
17
+ 'Compile',
18
+ 'KendoUILicense',
19
+ 'PreparePackage',
20
+ 'TypeCheck',
21
+ 'BundlePackage',
14
22
  }
15
23
 
16
24
  export class Build implements Command {
25
+ readonly greedy = true;
26
+
17
27
  constructor(private args: Args) {}
18
28
 
19
29
  description() {
@@ -22,44 +32,72 @@ export class Build implements Command {
22
32
 
23
33
  @logErrors
24
34
  async execute() {
25
- const packages = splitPackagesByType(
26
- getPackages({ scope: this.args.scope, ignore: this.args.ignore })
27
- );
28
- const packagesWithPreparation = [
29
- ...packages[PackageType.TSC],
30
- ...packages[PackageType.Webpack],
31
- ];
35
+ checkArgs(this.args, { obsolete: ['--esbuild', '--experimental-bundlers'] });
36
+
37
+ const useTsc = this.args['use-tsc'];
38
+
39
+ const packages = getPackages({
40
+ scope: this.args.scope,
41
+ ignore: this.args.ignore,
42
+ type: [PackageType.TSC, PackageType.Webpack],
43
+ });
44
+ if (packages.length === 0) {
45
+ return;
46
+ }
32
47
 
33
48
  if (this.args['cdn-path']) {
34
49
  process.env.CLIENT_CDN_PATH = this.args['cdn-path'];
35
50
  }
36
51
 
37
- if (packagesWithPreparation.length) {
38
- await lernaExec({
52
+ const scope = packages.map(({ name }) => name);
53
+
54
+ const processTree = new ProcessTree<typeof BuildProcesses>();
55
+
56
+ processTree.add(BuildProcesses.Compile, () => compile({ packages: scope, useTsc }));
57
+ processTree.add(BuildProcesses.KendoUILicense, () => kendoUILicense());
58
+ processTree.add(BuildProcesses.PreparePackage, () =>
59
+ lernaExec({
39
60
  cmd: 'startup prepare-package',
40
- scope: packagesWithPreparation.map(({ name }) => name),
61
+ parallel: true,
62
+ scope,
41
63
  stream: true,
42
- });
43
- }
64
+ ...(useTsc ? { '--': ['--copy-files'] } : {}),
65
+ })
66
+ );
67
+ processTree.add(BuildProcesses.TypeCheck, () => typeCheck({ packages: scope }), {
68
+ dependsOn: [BuildProcesses.PreparePackage],
69
+ });
70
+ processTree.add(
71
+ BuildProcesses.BundlePackage,
72
+ () => {
73
+ const webpackScope = packages
74
+ .filter(({ type }) => type === PackageType.Webpack)
75
+ .map(({ name }) => name);
44
76
 
45
- if (packages[PackageType.TSC].length) {
46
- await tsc(packages[PackageType.TSC]);
47
- }
77
+ if (webpackScope.length === 0) {
78
+ return Promise.resolve();
79
+ }
48
80
 
49
- if (packages[PackageType.Webpack].length) {
50
- await kendoUILicense();
51
- await lernaExec({
52
- 'cmd': 'startup bundle-package',
53
- 'scope': packages[PackageType.Webpack].map(({ name }) => name),
54
- 'stream': true,
55
- '--': [
56
- ...[this.args.config ? `--config "${this.args.config}"` : undefined],
57
- ...[this.args['code-coverage'] ? '--code-coverage' : undefined],
58
- ...[this.args.esbuild ? '--esbuild' : undefined],
59
- ...[this.args['experimental-bundlers'] ? '--experimental-bundlers' : undefined],
60
- ...[this.args.stat ? '--stat' : undefined],
61
- ].filter(item => !!item) as string[],
62
- });
63
- }
81
+ return lernaExec({
82
+ 'cmd': 'startup bundle-package',
83
+ 'scope': webpackScope,
84
+ 'stream': true,
85
+ '--': [
86
+ ...[this.args.config ? `--config "${this.args.config}"` : undefined],
87
+ ...[this.args['code-coverage'] ? '--code-coverage' : undefined],
88
+ ...[this.args.stat ? '--stat' : undefined],
89
+ ].filter(item => !!item) as string[],
90
+ });
91
+ },
92
+ {
93
+ dependsOn: [
94
+ BuildProcesses.Compile,
95
+ BuildProcesses.KendoUILicense,
96
+ BuildProcesses.PreparePackage,
97
+ ],
98
+ }
99
+ );
100
+
101
+ await processTree.run();
64
102
  }
65
103
  }