@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
@@ -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 { CommandName } from '../../../utils/get-configuration';
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 command = CommandName.build;
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("prepends cli's NODE_OPTIONS to existing NODE_OPTIONS", () => {
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, envOptions].join(' ')
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
- [command]: { NODE_OPTIONS: options },
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, tcmWatch } from '../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: undefined });
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
- describe(`${tcmWatch.name}`, () => {
79
- type Listener = (path: string) => Promise<void>;
80
- let watchSpy: jest.SpyInstance;
81
- let fsWatcher: Partial<ReturnType<typeof chokidar.watch>>;
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
- beforeEach(() => {
84
- fsWatcher = { on: jest.fn() };
85
- watchSpy = jest.spyOn(chokidar, 'watch').mockReturnValue(fsWatcher as any);
86
- fs.writeFileSync(`${source}/foo.bar`, '');
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
- test('watches for new and changed style modules', async () => {
92
- await subject();
94
+ test('watches for new and changed style modules', async () => {
95
+ await subject();
93
96
 
94
- expect(watchSpy).toHaveBeenCalledWith(source, {
95
- ignored: expect.any(Function),
96
- ignoreInitial: true,
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
- function getListener(name: string) {
103
- const { calls } = jest.mocked(fsWatcher.on)!.mock;
104
- return calls.find(([event]) => event === name)![1] as Listener;
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
- const subject = () => ignored(filePath, stats);
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
- function itReturns(value: boolean) {
123
- test(`returns ${value}`, () => expect(subject()).toBe(value));
124
- }
123
+ const subject = () => ignored(filePath, stats);
125
124
 
126
- describe.each(styleExtensions)('when path ends with %s', ext => {
127
- beforeEach(() => (filePath = `foo${ext}`));
125
+ function itReturns(value: boolean) {
126
+ test(`returns ${value}`, () => expect(subject()).toBe(value));
127
+ }
128
128
 
129
- itReturns(false);
130
- });
129
+ describe.each(styleExtensions)('when path ends with %s', ext => {
130
+ beforeEach(() => (filePath = `foo${ext}`));
131
131
 
132
- describe.each(styleExtensions)('when path contains %s', ext => {
133
- beforeEach(() => (filePath = `foo${ext}.d.ts`));
132
+ itReturns(false);
133
+ });
134
134
 
135
- itReturns(true);
136
- });
135
+ describe.each(styleExtensions)('when path contains %s', ext => {
136
+ beforeEach(() => (filePath = `foo${ext}.d.ts`));
137
137
 
138
- describe.each(['', '.scss', '.tsx'])('when path ends with "%s"', ext => {
139
- beforeEach(() => (filePath = `foo${ext}`));
138
+ itReturns(true);
139
+ });
140
140
 
141
- itReturns(true);
141
+ describe.each(['', '.scss', '.tsx'])('when path ends with "%s"', ext => {
142
+ beforeEach(() => (filePath = `foo${ext}`));
142
143
 
143
- describe('when stats is undefined', () => {
144
- beforeEach(() => (stats = undefined));
144
+ itReturns(true);
145
145
 
146
- itReturns(false);
147
- });
146
+ describe('when stats is undefined', () => {
147
+ beforeEach(() => (stats = undefined));
148
148
 
149
- describe('when stats.isFile returns false', () => {
150
- beforeEach(() => (stats = { isFile: () => false }));
149
+ itReturns(false);
150
+ });
151
151
 
152
- itReturns(false);
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
- describe('when module is added', () => {
158
- const module = 'bar.module.scss';
160
+ describe('when module is added', () => {
161
+ const module = 'bar.module.scss';
159
162
 
160
- const setup = async () => {
161
- await subject();
162
- mockStylesModule(module, 'bar');
163
- await getListener('add')(`${source}/${module}`);
164
- };
163
+ const setup = async () => {
164
+ await subject();
165
+ mockStylesModule(module, 'bar');
166
+ await getListener('add')(`${source}/${module}`);
167
+ };
165
168
 
166
- test('generates Typescript definitions for new module', async () => {
167
- await setup();
169
+ test('generates Typescript definitions for new module', async () => {
170
+ await setup();
168
171
 
169
- expectTypeDefinitions(module, 'bar');
172
+ expectTypeDefinitions(module, 'bar');
173
+ });
170
174
  });
171
- });
172
175
 
173
- describe('when module is changed', () => {
174
- const module = 'baz.module.less';
176
+ describe('when module is changed', () => {
177
+ const module = 'baz.module.less';
175
178
 
176
- const setup = async () => {
177
- mockStylesModule(module, 'foo');
178
- await subject();
179
+ const setup = async () => {
180
+ mockStylesModule(module, 'foo');
181
+ await subject();
179
182
 
180
- mockStylesModule(module, 'baz');
181
- await getListener('change')(`${source}/${module}`);
182
- };
183
+ mockStylesModule(module, 'baz');
184
+ await getListener('change')(`${source}/${module}`);
185
+ };
183
186
 
184
- test('generates Typescript definitions for changed module', async () => {
185
- await setup();
187
+ test('generates Typescript definitions for changed module', async () => {
188
+ await setup();
186
189
 
187
- expectTypeDefinitions(module, 'baz');
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
+ });