skuba 14.0.0-replace-global-vars-20251121010036 → 14.0.0-tsdown-package-templates-20251225094805

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 (415) hide show
  1. package/config/eslint.js +1 -1
  2. package/config/jest.js +1 -0
  3. package/config/prettier.d.ts +4 -8
  4. package/config/prettier.js +2 -10
  5. package/jest/moduleNameMapper.js +64 -0
  6. package/jest/transform.js +62 -0
  7. package/jest/tsConfig.js +26 -0
  8. package/jest-preset.js +37 -0
  9. package/lib/api/jest/index.d.ts +15 -0
  10. package/lib/api/jest/index.js +59 -0
  11. package/lib/api/jest/index.js.map +7 -0
  12. package/lib/cli/adapter/eslint.js +45 -11
  13. package/lib/cli/adapter/eslint.js.map +2 -2
  14. package/lib/cli/adapter/prettier.js +67 -39
  15. package/lib/cli/adapter/prettier.js.map +2 -2
  16. package/lib/cli/build/args.js +42 -8
  17. package/lib/cli/build/args.js.map +2 -2
  18. package/lib/cli/build/assets.d.ts +0 -9
  19. package/lib/cli/build/assets.js +57 -45
  20. package/lib/cli/build/assets.js.map +3 -3
  21. package/lib/cli/build/esbuild.js +45 -21
  22. package/lib/cli/build/esbuild.js.map +2 -2
  23. package/lib/cli/build/index.js +45 -21
  24. package/lib/cli/build/index.js.map +1 -1
  25. package/lib/cli/build/tsc.js +59 -22
  26. package/lib/cli/build/tsc.js.map +2 -2
  27. package/lib/cli/configure/analyseConfiguration.js +50 -16
  28. package/lib/cli/configure/analyseConfiguration.js.map +2 -2
  29. package/lib/cli/configure/analyseDependencies.d.ts +1 -1
  30. package/lib/cli/configure/analyseDependencies.js +59 -25
  31. package/lib/cli/configure/analyseDependencies.js.map +3 -3
  32. package/lib/cli/configure/analysis/diff.js +29 -5
  33. package/lib/cli/configure/analysis/diff.js.map +1 -1
  34. package/lib/cli/configure/analysis/files.js +42 -8
  35. package/lib/cli/configure/analysis/files.js.map +2 -2
  36. package/lib/cli/configure/analysis/git.js +46 -12
  37. package/lib/cli/configure/analysis/git.js.map +2 -2
  38. package/lib/cli/configure/analysis/package.d.ts +3 -2
  39. package/lib/cli/configure/analysis/package.js +45 -10
  40. package/lib/cli/configure/analysis/package.js.map +3 -3
  41. package/lib/cli/configure/analysis/project.js +50 -18
  42. package/lib/cli/configure/analysis/project.js.map +2 -2
  43. package/lib/cli/configure/dependencies/index.js +35 -7
  44. package/lib/cli/configure/dependencies/index.js.map +1 -1
  45. package/lib/cli/configure/dependencies/seekDatadogCustomMetrics.js +28 -4
  46. package/lib/cli/configure/dependencies/seekDatadogCustomMetrics.js.map +1 -1
  47. package/lib/cli/configure/dependencies/seekKoala.js +28 -4
  48. package/lib/cli/configure/dependencies/seekKoala.js.map +1 -1
  49. package/lib/cli/configure/dependencies/skuba.js +28 -4
  50. package/lib/cli/configure/dependencies/skuba.js.map +1 -1
  51. package/lib/cli/configure/dependencies/skubaDeps.js +26 -2
  52. package/lib/cli/configure/dependencies/skubaDeps.js.map +1 -1
  53. package/lib/cli/configure/dependencies/skubaDive.js +29 -4
  54. package/lib/cli/configure/dependencies/skubaDive.js.map +1 -1
  55. package/lib/cli/configure/ensureTemplateCompletion.d.ts +1 -1
  56. package/lib/cli/configure/ensureTemplateCompletion.js +61 -33
  57. package/lib/cli/configure/ensureTemplateCompletion.js.map +3 -3
  58. package/lib/cli/configure/getEntryPoint.d.ts +1 -1
  59. package/lib/cli/configure/getEntryPoint.js +48 -14
  60. package/lib/cli/configure/getEntryPoint.js.map +3 -3
  61. package/lib/cli/configure/getProjectType.d.ts +1 -1
  62. package/lib/cli/configure/getProjectType.js +35 -14
  63. package/lib/cli/configure/getProjectType.js.map +2 -2
  64. package/lib/cli/configure/index.js +84 -50
  65. package/lib/cli/configure/index.js.map +2 -2
  66. package/lib/cli/configure/modules/eslint.js +34 -10
  67. package/lib/cli/configure/modules/eslint.js.map +1 -1
  68. package/lib/cli/configure/modules/ignore.js +32 -8
  69. package/lib/cli/configure/modules/ignore.js.map +1 -1
  70. package/lib/cli/configure/modules/index.js +44 -18
  71. package/lib/cli/configure/modules/index.js.map +2 -2
  72. package/lib/cli/configure/modules/jest.d.ts +2 -0
  73. package/lib/cli/configure/modules/jest.js +86 -0
  74. package/lib/cli/configure/modules/jest.js.map +7 -0
  75. package/lib/cli/configure/modules/nodemon.js +28 -4
  76. package/lib/cli/configure/modules/nodemon.js.map +1 -1
  77. package/lib/cli/configure/modules/package.js +34 -10
  78. package/lib/cli/configure/modules/package.js.map +1 -1
  79. package/lib/cli/configure/modules/prettier.js +35 -11
  80. package/lib/cli/configure/modules/prettier.js.map +1 -1
  81. package/lib/cli/configure/modules/renovate.js +40 -17
  82. package/lib/cli/configure/modules/renovate.js.map +2 -2
  83. package/lib/cli/configure/modules/serverless.js +26 -2
  84. package/lib/cli/configure/modules/serverless.js.map +1 -1
  85. package/lib/cli/configure/modules/tslint.js +28 -4
  86. package/lib/cli/configure/modules/tslint.js.map +1 -1
  87. package/lib/cli/configure/processing/configFile.js +39 -3
  88. package/lib/cli/configure/processing/configFile.js.map +1 -1
  89. package/lib/cli/configure/processing/deleteFiles.js +26 -2
  90. package/lib/cli/configure/processing/deleteFiles.js.map +1 -1
  91. package/lib/cli/configure/processing/javascript.js +27 -2
  92. package/lib/cli/configure/processing/javascript.js.map +1 -1
  93. package/lib/cli/configure/processing/json.js +31 -6
  94. package/lib/cli/configure/processing/json.js.map +1 -1
  95. package/lib/cli/configure/processing/loadFiles.js +26 -2
  96. package/lib/cli/configure/processing/loadFiles.js.map +1 -1
  97. package/lib/cli/configure/processing/module.js +28 -4
  98. package/lib/cli/configure/processing/module.js.map +1 -1
  99. package/lib/cli/configure/processing/package.d.ts +67 -1
  100. package/lib/cli/configure/processing/package.js +45 -8
  101. package/lib/cli/configure/processing/package.js.map +3 -3
  102. package/lib/cli/configure/processing/prettier.js +38 -4
  103. package/lib/cli/configure/processing/prettier.js.map +2 -2
  104. package/lib/cli/configure/processing/record.js +41 -5
  105. package/lib/cli/configure/processing/record.js.map +2 -2
  106. package/lib/cli/configure/processing/typescript.js +63 -26
  107. package/lib/cli/configure/processing/typescript.js.map +2 -2
  108. package/lib/cli/configure/types.d.ts +4 -15
  109. package/lib/cli/configure/types.js +16 -0
  110. package/lib/cli/configure/types.js.map +3 -3
  111. package/lib/cli/format/index.js +44 -20
  112. package/lib/cli/format/index.js.map +1 -1
  113. package/lib/cli/help/index.js +30 -6
  114. package/lib/cli/help/index.js.map +1 -1
  115. package/lib/cli/init/getConfig.d.ts +1 -1
  116. package/lib/cli/init/getConfig.js +100 -74
  117. package/lib/cli/init/getConfig.js.map +3 -3
  118. package/lib/cli/init/git.js +51 -16
  119. package/lib/cli/init/git.js.map +2 -2
  120. package/lib/cli/init/index.js +98 -67
  121. package/lib/cli/init/index.js.map +2 -2
  122. package/lib/cli/init/prompts.d.ts +4 -4
  123. package/lib/cli/init/prompts.js +48 -27
  124. package/lib/cli/init/prompts.js.map +2 -2
  125. package/lib/cli/init/types.js +41 -7
  126. package/lib/cli/init/types.js.map +1 -1
  127. package/lib/cli/init/validation.js +30 -2
  128. package/lib/cli/init/validation.js.map +1 -1
  129. package/lib/cli/init/writePackageJson.js +42 -8
  130. package/lib/cli/init/writePackageJson.js.map +2 -2
  131. package/lib/cli/lint/annotate/buildkite/eslint.js +37 -3
  132. package/lib/cli/lint/annotate/buildkite/eslint.js.map +1 -1
  133. package/lib/cli/lint/annotate/buildkite/index.js +45 -11
  134. package/lib/cli/lint/annotate/buildkite/index.js.map +1 -1
  135. package/lib/cli/lint/annotate/buildkite/internal.js +37 -3
  136. package/lib/cli/lint/annotate/buildkite/internal.js.map +1 -1
  137. package/lib/cli/lint/annotate/buildkite/prettier.js +37 -3
  138. package/lib/cli/lint/annotate/buildkite/prettier.js.map +1 -1
  139. package/lib/cli/lint/annotate/buildkite/tsc.js +37 -3
  140. package/lib/cli/lint/annotate/buildkite/tsc.js.map +1 -1
  141. package/lib/cli/lint/annotate/github/eslint.js +26 -2
  142. package/lib/cli/lint/annotate/github/eslint.js.map +1 -1
  143. package/lib/cli/lint/annotate/github/index.js +45 -11
  144. package/lib/cli/lint/annotate/github/index.js.map +1 -1
  145. package/lib/cli/lint/annotate/github/internal.js +26 -2
  146. package/lib/cli/lint/annotate/github/internal.js.map +1 -1
  147. package/lib/cli/lint/annotate/github/prettier.js +26 -2
  148. package/lib/cli/lint/annotate/github/prettier.js.map +1 -1
  149. package/lib/cli/lint/annotate/github/tsc.js +28 -4
  150. package/lib/cli/lint/annotate/github/tsc.js.map +2 -2
  151. package/lib/cli/lint/annotate/index.js +30 -6
  152. package/lib/cli/lint/annotate/index.js.map +1 -1
  153. package/lib/cli/lint/autofix.js +73 -37
  154. package/lib/cli/lint/autofix.js.map +1 -1
  155. package/lib/cli/lint/eslint.js +51 -16
  156. package/lib/cli/lint/eslint.js.map +3 -3
  157. package/lib/cli/lint/external.js +51 -19
  158. package/lib/cli/lint/external.js.map +2 -2
  159. package/lib/cli/lint/index.js +49 -25
  160. package/lib/cli/lint/index.js.map +1 -1
  161. package/lib/cli/lint/internal.js +42 -18
  162. package/lib/cli/lint/internal.js.map +1 -1
  163. package/lib/cli/lint/internalLints/detectBadCodeowners.js +33 -8
  164. package/lib/cli/lint/internalLints/detectBadCodeowners.js.map +1 -1
  165. package/lib/cli/lint/internalLints/noSkubaTemplateJs.js +45 -11
  166. package/lib/cli/lint/internalLints/noSkubaTemplateJs.js.map +2 -2
  167. package/lib/cli/lint/internalLints/patchRenovateConfig.js +55 -21
  168. package/lib/cli/lint/internalLints/patchRenovateConfig.js.map +2 -2
  169. package/lib/cli/lint/internalLints/refreshConfigFiles.js +63 -32
  170. package/lib/cli/lint/internalLints/refreshConfigFiles.js.map +2 -2
  171. package/lib/cli/lint/internalLints/upgrade/index.d.ts +1 -1
  172. package/lib/cli/lint/internalLints/upgrade/index.js +53 -22
  173. package/lib/cli/lint/internalLints/upgrade/index.js.map +3 -3
  174. package/lib/cli/lint/internalLints/upgrade/patches/10.0.4/index.js +28 -4
  175. package/lib/cli/lint/internalLints/upgrade/patches/10.0.4/index.js.map +1 -1
  176. package/lib/cli/lint/internalLints/upgrade/patches/10.0.4/removeYarnIgnoreOptionalFlags.js +45 -11
  177. package/lib/cli/lint/internalLints/upgrade/patches/10.0.4/removeYarnIgnoreOptionalFlags.js.map +2 -2
  178. package/lib/cli/lint/internalLints/upgrade/patches/10.1.0/index.js +30 -6
  179. package/lib/cli/lint/internalLints/upgrade/patches/10.1.0/index.js.map +1 -1
  180. package/lib/cli/lint/internalLints/upgrade/patches/10.1.0/migrateNpmrcToPnpmWorkspace.js +65 -34
  181. package/lib/cli/lint/internalLints/upgrade/patches/10.1.0/migrateNpmrcToPnpmWorkspace.js.map +2 -2
  182. package/lib/cli/lint/internalLints/upgrade/patches/10.1.0/stopBundlingInCDKTests.js +46 -11
  183. package/lib/cli/lint/internalLints/upgrade/patches/10.1.0/stopBundlingInCDKTests.js.map +2 -2
  184. package/lib/cli/lint/internalLints/upgrade/patches/12.0.2/index.js +28 -4
  185. package/lib/cli/lint/internalLints/upgrade/patches/12.0.2/index.js.map +1 -1
  186. package/lib/cli/lint/internalLints/upgrade/patches/12.0.2/unhandledRejections.js +59 -23
  187. package/lib/cli/lint/internalLints/upgrade/patches/12.0.2/unhandledRejections.js.map +2 -2
  188. package/lib/cli/lint/internalLints/upgrade/patches/12.1.1/index.js +28 -4
  189. package/lib/cli/lint/internalLints/upgrade/patches/12.1.1/index.js.map +1 -1
  190. package/lib/cli/lint/internalLints/upgrade/patches/12.1.1/patchJestSnapshots.js +46 -11
  191. package/lib/cli/lint/internalLints/upgrade/patches/12.1.1/patchJestSnapshots.js.map +2 -2
  192. package/lib/cli/lint/internalLints/upgrade/patches/12.3.0/index.js +30 -6
  193. package/lib/cli/lint/internalLints/upgrade/patches/12.3.0/index.js.map +1 -1
  194. package/lib/cli/lint/internalLints/upgrade/patches/12.3.0/patchApiTokenFromEnvironment.js +46 -11
  195. package/lib/cli/lint/internalLints/upgrade/patches/12.3.0/patchApiTokenFromEnvironment.js.map +2 -2
  196. package/lib/cli/lint/internalLints/upgrade/patches/12.3.0/patchDockerfileSyntaxDirective.js +46 -11
  197. package/lib/cli/lint/internalLints/upgrade/patches/12.3.0/patchDockerfileSyntaxDirective.js.map +2 -2
  198. package/lib/cli/lint/internalLints/upgrade/patches/12.4.0/index.js +28 -4
  199. package/lib/cli/lint/internalLints/upgrade/patches/12.4.0/index.js.map +1 -1
  200. package/lib/cli/lint/internalLints/upgrade/patches/12.4.0/patchDockerfileCIVariable.js +46 -11
  201. package/lib/cli/lint/internalLints/upgrade/patches/12.4.0/patchDockerfileCIVariable.js.map +2 -2
  202. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/configureTsConfigForESM.js +67 -29
  203. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/configureTsConfigForESM.js.map +2 -2
  204. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/index.js +34 -10
  205. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/index.js.map +1 -1
  206. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/patchApiDockerfiles.js +45 -11
  207. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/patchApiDockerfiles.js.map +2 -2
  208. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/rewriteSrcImports.d.ts +0 -4
  209. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/rewriteSrcImports.js +63 -18
  210. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/rewriteSrcImports.js.map +3 -3
  211. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/updateLambdaConfigs.js +50 -15
  212. package/lib/cli/lint/internalLints/upgrade/patches/12.4.1/updateLambdaConfigs.js.map +2 -2
  213. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/index.js +40 -0
  214. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/index.js.map +7 -0
  215. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/patchRootTsconfig.d.ts +3 -0
  216. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/patchRootTsconfig.js +133 -0
  217. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/patchRootTsconfig.js.map +7 -0
  218. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/upgradeNode.js +55 -0
  219. package/lib/cli/lint/internalLints/upgrade/patches/13.1.1/upgradeNode.js.map +7 -0
  220. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/addEmptyExports.js +51 -17
  221. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/addEmptyExports.js.map +2 -2
  222. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/index.js +34 -10
  223. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/index.js.map +1 -1
  224. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/patchDockerfile.js +44 -10
  225. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/patchDockerfile.js.map +2 -2
  226. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/patchServerListener.js +46 -12
  227. package/lib/cli/lint/internalLints/upgrade/patches/7.3.1/patchServerListener.js.map +2 -2
  228. package/lib/cli/lint/internalLints/upgrade/patches/8.0.0/index.js +28 -4
  229. package/lib/cli/lint/internalLints/upgrade/patches/8.0.0/index.js.map +1 -1
  230. package/lib/cli/lint/internalLints/upgrade/patches/8.0.0/patchPnpmPackageManager.js +49 -15
  231. package/lib/cli/lint/internalLints/upgrade/patches/8.0.0/patchPnpmPackageManager.js.map +2 -2
  232. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/collapseDuplicateMergeKeys.js +45 -11
  233. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/collapseDuplicateMergeKeys.js.map +2 -2
  234. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/index.js +34 -10
  235. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/index.js.map +1 -1
  236. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/moveNpmrcMounts.js +45 -11
  237. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/moveNpmrcMounts.js.map +2 -2
  238. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/patchDockerCompose.js +45 -11
  239. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/patchDockerCompose.js.map +2 -2
  240. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/patchDockerImages.js +47 -13
  241. package/lib/cli/lint/internalLints/upgrade/patches/8.2.1/patchDockerImages.js.map +2 -2
  242. package/lib/cli/lint/internalLints/upgrade/patches/9.0.1/index.js +28 -4
  243. package/lib/cli/lint/internalLints/upgrade/patches/9.0.1/index.js.map +1 -1
  244. package/lib/cli/lint/internalLints/upgrade/patches/9.0.1/patchPnpmDockerImages.js +45 -11
  245. package/lib/cli/lint/internalLints/upgrade/patches/9.0.1/patchPnpmDockerImages.js.map +2 -2
  246. package/lib/cli/lint/prettier.js +50 -15
  247. package/lib/cli/lint/prettier.js.map +3 -3
  248. package/lib/cli/lint/tsc.js +28 -4
  249. package/lib/cli/lint/tsc.js.map +1 -1
  250. package/lib/cli/lint/types.js +16 -0
  251. package/lib/cli/lint/types.js.map +3 -3
  252. package/lib/cli/migrate/index.d.ts +5 -0
  253. package/lib/cli/migrate/index.js +79 -15
  254. package/lib/cli/migrate/index.js.map +2 -2
  255. package/lib/cli/migrate/nodeVersion/checks.d.ts +1 -14
  256. package/lib/cli/migrate/nodeVersion/checks.js +51 -120
  257. package/lib/cli/migrate/nodeVersion/checks.js.map +2 -2
  258. package/lib/cli/migrate/nodeVersion/index.d.ts +8 -2
  259. package/lib/cli/migrate/nodeVersion/index.js +239 -65
  260. package/lib/cli/migrate/nodeVersion/index.js.map +3 -3
  261. package/lib/cli/migrate/nodeVersion/upgrade.d.ts +8 -0
  262. package/lib/cli/migrate/nodeVersion/upgrade.js +179 -0
  263. package/lib/cli/migrate/nodeVersion/upgrade.js.map +7 -0
  264. package/lib/cli/node/index.js +57 -20
  265. package/lib/cli/node/index.js.map +3 -3
  266. package/lib/cli/release/index.js +28 -4
  267. package/lib/cli/release/index.js.map +1 -1
  268. package/lib/cli/start/index.js +50 -16
  269. package/lib/cli/start/index.js.map +3 -3
  270. package/lib/cli/test/index.js +44 -4
  271. package/lib/cli/test/index.js.map +2 -2
  272. package/lib/cli/test/reporters/github/annotations.d.ts +9 -0
  273. package/lib/cli/test/reporters/github/annotations.js +102 -0
  274. package/lib/cli/test/reporters/github/annotations.js.map +7 -0
  275. package/lib/cli/test/reporters/github/index.d.ts +5 -0
  276. package/lib/cli/test/reporters/github/index.js +74 -0
  277. package/lib/cli/test/reporters/github/index.js.map +7 -0
  278. package/lib/cli/version/index.js +30 -6
  279. package/lib/cli/version/index.js.map +1 -1
  280. package/lib/index.d.ts +1 -0
  281. package/lib/index.js +46 -6
  282. package/lib/index.js.map +2 -2
  283. package/lib/skuba.js +45 -26
  284. package/lib/skuba.js.map +3 -3
  285. package/lib/utils/args.js +43 -6
  286. package/lib/utils/args.js.map +2 -2
  287. package/lib/utils/command.js +42 -4
  288. package/lib/utils/command.js.map +3 -3
  289. package/lib/utils/copy.js +57 -20
  290. package/lib/utils/copy.js.map +2 -2
  291. package/lib/utils/dir.js +72 -32
  292. package/lib/utils/dir.js.map +2 -2
  293. package/lib/utils/env.js +26 -2
  294. package/lib/utils/env.js.map +1 -1
  295. package/lib/utils/error.js +47 -10
  296. package/lib/utils/error.js.map +1 -1
  297. package/lib/utils/exec.js +61 -23
  298. package/lib/utils/exec.js.map +3 -3
  299. package/lib/utils/fs.js +40 -6
  300. package/lib/utils/fs.js.map +2 -2
  301. package/lib/utils/help.js +30 -6
  302. package/lib/utils/help.js.map +1 -1
  303. package/lib/utils/logging.js +38 -11
  304. package/lib/utils/logging.js.map +1 -1
  305. package/lib/utils/logo.js +48 -24
  306. package/lib/utils/logo.js.map +1 -1
  307. package/lib/utils/manifest.d.ts +2 -3
  308. package/lib/utils/manifest.js +48 -8
  309. package/lib/utils/manifest.js.map +3 -3
  310. package/lib/utils/npmrc.js +26 -2
  311. package/lib/utils/npmrc.js.map +1 -1
  312. package/lib/utils/packageManager.js +49 -12
  313. package/lib/utils/packageManager.js.map +2 -2
  314. package/lib/utils/port.js +39 -4
  315. package/lib/utils/port.js.map +2 -2
  316. package/lib/utils/sleep.js +26 -2
  317. package/lib/utils/sleep.js.map +1 -1
  318. package/lib/utils/template.js +55 -18
  319. package/lib/utils/template.js.map +3 -3
  320. package/lib/utils/validation.js +31 -2
  321. package/lib/utils/validation.js.map +1 -1
  322. package/lib/utils/version.js +46 -9
  323. package/lib/utils/version.js.map +2 -2
  324. package/lib/utils/wait.js +32 -7
  325. package/lib/utils/wait.js.map +1 -1
  326. package/lib/utils/worker.js +35 -10
  327. package/lib/utils/worker.js.map +1 -1
  328. package/lib/wrapper/function-arguments.d.js +1 -0
  329. package/lib/wrapper/functionHandler.js +49 -18
  330. package/lib/wrapper/functionHandler.js.map +2 -2
  331. package/lib/wrapper/http.js +43 -8
  332. package/lib/wrapper/http.js.map +2 -2
  333. package/lib/wrapper/index.js +7 -6
  334. package/lib/wrapper/index.js.map +1 -1
  335. package/lib/wrapper/main.js +42 -8
  336. package/lib/wrapper/main.js.map +3 -3
  337. package/lib/wrapper/requestListener.js +47 -13
  338. package/lib/wrapper/requestListener.js.map +2 -2
  339. package/lib/wrapper/server.js +28 -4
  340. package/lib/wrapper/server.js.map +1 -1
  341. package/package.json +42 -43
  342. package/template/base/_.prettierrc.js +1 -1
  343. package/template/base/_eslint.config.js +1 -1
  344. package/template/base/_pnpm-workspace.yaml +4 -3
  345. package/template/base/jest.config.ts +19 -0
  346. package/template/base/jest.setup.ts +3 -0
  347. package/template/express-rest-api/.buildkite/pipeline.yml +1 -1
  348. package/template/express-rest-api/.nvmrc +1 -1
  349. package/template/express-rest-api/package.json +7 -8
  350. package/template/express-rest-api/skuba.template.js +1 -1
  351. package/template/express-rest-api/src/app.test.ts +0 -1
  352. package/template/greeter/.buildkite/pipeline.yml +1 -1
  353. package/template/greeter/.nvmrc +1 -1
  354. package/template/greeter/package.json +4 -5
  355. package/template/greeter/skuba.template.js +1 -1
  356. package/template/greeter/src/app.test.ts +1 -3
  357. package/template/koa-rest-api/.buildkite/pipeline.yml +1 -1
  358. package/template/koa-rest-api/.nvmrc +1 -1
  359. package/template/koa-rest-api/package.json +8 -10
  360. package/template/koa-rest-api/skuba.template.js +1 -1
  361. package/template/koa-rest-api/src/api/jobs/getJobs.test.ts +0 -2
  362. package/template/koa-rest-api/src/api/jobs/postJob.test.ts +0 -2
  363. package/template/koa-rest-api/src/app.test.ts +0 -2
  364. package/template/koa-rest-api/src/framework/server.test.ts +2 -2
  365. package/template/koa-rest-api/src/framework/validation.test.ts +0 -2
  366. package/template/koa-rest-api/src/testing/metrics.ts +0 -2
  367. package/template/lambda-sqs-worker-cdk/.buildkite/pipeline.yml +2 -2
  368. package/template/lambda-sqs-worker-cdk/.nvmrc +1 -1
  369. package/template/lambda-sqs-worker-cdk/infra/__snapshots__/appStack.test.ts.snap +7 -19
  370. package/template/lambda-sqs-worker-cdk/infra/appStack.test.ts +9 -11
  371. package/template/lambda-sqs-worker-cdk/infra/appStack.ts +3 -3
  372. package/template/lambda-sqs-worker-cdk/infra/config.ts +2 -4
  373. package/template/lambda-sqs-worker-cdk/package.json +9 -9
  374. package/template/lambda-sqs-worker-cdk/skuba.template.js +13 -1
  375. package/template/lambda-sqs-worker-cdk/src/app.test.ts +13 -22
  376. package/template/lambda-sqs-worker-cdk/src/framework/handler.test.ts +0 -1
  377. package/template/lambda-sqs-worker-cdk/src/framework/validation.test.ts +31 -33
  378. package/template/lambda-sqs-worker-cdk/src/services/jobScorer.test.ts +2 -8
  379. package/template/lambda-sqs-worker-cdk/src/services/pipelineEventSender.test.ts +2 -3
  380. package/template/lambda-sqs-worker-cdk/src/testing/services.ts +3 -4
  381. package/template/oss-npm-package/.github/workflows/release.yml +1 -1
  382. package/template/oss-npm-package/.github/workflows/validate.yml +1 -1
  383. package/template/oss-npm-package/.nvmrc +1 -1
  384. package/template/oss-npm-package/_package.json +10 -3
  385. package/template/oss-npm-package/skuba.template.js +1 -1
  386. package/template/oss-npm-package/src/index.test.ts +0 -2
  387. package/template/oss-npm-package/tsconfig.json +2 -1
  388. package/template/oss-npm-package/tsdown.config.ts +11 -0
  389. package/template/private-npm-package/.nvmrc +1 -1
  390. package/template/private-npm-package/_package.json +11 -4
  391. package/template/private-npm-package/skuba.template.js +2 -2
  392. package/template/private-npm-package/src/index.test.ts +0 -2
  393. package/template/private-npm-package/tsconfig.json +2 -1
  394. package/template/private-npm-package/tsdown.config.ts +11 -0
  395. package/lib/cli/buildPackage/index.d.ts +0 -1
  396. package/lib/cli/buildPackage/index.js +0 -43
  397. package/lib/cli/buildPackage/index.js.map +0 -7
  398. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/addTypeModuleToPackageJson.d.ts +0 -6
  399. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/addTypeModuleToPackageJson.js +0 -86
  400. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/addTypeModuleToPackageJson.js.map +0 -7
  401. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/index.js +0 -16
  402. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/index.js.map +0 -7
  403. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/rewriteGlobalVars.d.ts +0 -7
  404. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/rewriteGlobalVars.js +0 -76
  405. package/lib/cli/lint/internalLints/upgrade/patches/12.5.0/rewriteGlobalVars.js.map +0 -7
  406. package/lib/cli/lint/internalLints/upgrade/patches/9.1.0/index.d.ts +0 -2
  407. package/lib/cli/lint/internalLints/upgrade/patches/9.1.0/index.js +0 -11
  408. package/lib/cli/lint/internalLints/upgrade/patches/9.1.0/index.js.map +0 -7
  409. package/lib/cli/lint/internalLints/upgrade/patches/9.1.0/upgradeNode.js +0 -34
  410. package/lib/cli/lint/internalLints/upgrade/patches/9.1.0/upgradeNode.js.map +0 -7
  411. package/lib/eslint.d.js +0 -1
  412. package/lib/eslint.d.js.map +0 -7
  413. package/template/base/vitest.config.ts +0 -25
  414. /package/lib/cli/lint/internalLints/upgrade/patches/{12.5.0 → 13.1.1}/index.d.ts +0 -0
  415. /package/lib/cli/lint/internalLints/upgrade/patches/{9.1.0 → 13.1.1}/upgradeNode.d.ts +0 -0
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/cli/migrate/nodeVersion/index.ts"],
4
- "sourcesContent": ["import { inspect } from 'util';\n\nimport { glob } from 'fast-glob';\nimport fs from 'fs-extra';\n\nimport { log } from '../../../utils/logging.js';\nimport { createDestinationFileReader } from '../../configure/analysis/project.js';\n\nimport {\n isPatchableNodeVersion,\n isPatchableServerlessVersion,\n isPatchableSkubaType,\n} from './checks.js';\n\ntype FileSelector =\n | { files: string; file?: never }\n | { file: string; files?: never };\n\ntype SubPatch = FileSelector & {\n tests?: Array<(path: string) => Promise<boolean>>;\n regex?: () => RegExp;\n replace: string;\n};\n\nconst subPatches = ({\n nodeVersion,\n ECMAScriptVersion,\n}: Versions): SubPatch[] => [\n { file: '.nvmrc', replace: `${nodeVersion}\\n` },\n {\n files: '**/Dockerfile*',\n\n regex: () =>\n /^FROM(.*) (public.ecr.aws\\/docker\\/library\\/)?node:([0-9]+(?:\\.[0-9]+(?:\\.[0-9]+)?)?)(-[a-z0-9]+)?(@sha256:[a-f0-9]{64})?( .*)?$/gm,\n replace: `FROM$1 $2node:${nodeVersion}$4$6`,\n },\n {\n files: '**/Dockerfile*',\n regex: () =>\n /^FROM(.*) gcr.io\\/distroless\\/nodejs\\d+-debian(\\d+)(@sha256:[a-f0-9]{64})?(\\.[^- \\n]+)?(-[^ \\n]+)?( .+|)$/gm,\n replace: `FROM$1 gcr.io/distroless/nodejs${nodeVersion}-debian$2$4$5$6`,\n },\n\n {\n files: '**/serverless*.y*ml',\n regex: () => /\\bnodejs\\d+.x\\b/gm,\n tests: [isPatchableServerlessVersion],\n replace: `nodejs${nodeVersion}.x`,\n },\n {\n files: '**/serverless*.y*ml',\n regex: () => /\\bnode\\d+\\b/gm,\n tests: [isPatchableServerlessVersion],\n replace: `node${nodeVersion}`,\n },\n\n {\n files: '**/infra/**/*.ts',\n regex: () => /NODEJS_\\d+_X/g,\n replace: `NODEJS_${nodeVersion}_X`,\n },\n {\n files: '**/infra/**/*.ts',\n regex: () => /(target:\\s*'node)(\\d+)(.+)$/gm,\n replace: `$1${nodeVersion}$3`,\n },\n\n {\n files: '**/.buildkite/*',\n regex: () =>\n /(image: )(public.ecr.aws\\/docker\\/library\\/)?(node:)[0-9.]+(\\.[^- \\n]+)?(-[^ \\n]+)?$/gm,\n replace: `$1$2$3${nodeVersion}$5`,\n },\n {\n files: '.node-version*',\n regex: () => /(\\d+(?:\\.\\d+)*)/g,\n replace: `${nodeVersion}`,\n },\n\n {\n files: '**/package.json',\n regex: () =>\n /([\"']engines[\"']:\\s*{[\\s\\S]*?[\"']node[\"']:\\s*[\"']>=)(\\d+(?:\\.\\d+)*)(['\"]\\s*})/gm,\n tests: [isPatchableServerlessVersion, isPatchableSkubaType],\n replace: `$1${nodeVersion}$3`,\n },\n\n {\n files: '**/tsconfig*.json',\n regex: () => /(\"target\":\\s*\")(ES\\d+)\"/gim,\n tests: [isPatchableServerlessVersion, isPatchableSkubaType],\n replace: `$1${ECMAScriptVersion}\"`,\n },\n {\n files: '**/tsconfig*.json',\n regex: () => /(\"lib\":\\s*\\[)([\\S\\s]*?)(ES\\d+)([\\S\\s]*?)(\\])/gim,\n tests: [isPatchableServerlessVersion, isPatchableSkubaType],\n replace: `$1$2${ECMAScriptVersion}$4$5`,\n },\n\n {\n files: '**/docker-compose*.y*ml',\n regex: () =>\n /(image: )(public.ecr.aws\\/docker\\/library\\/)?(node:)[0-9.]+(\\.[^- \\n]+)?(-[^ \\n]+)?$/gm,\n\n replace: `$1$2$3${nodeVersion}$5`,\n },\n];\n\ntype Versions = {\n nodeVersion: number;\n ECMAScriptVersion: string;\n};\n\nconst runSubPatch = async (dir: string, patch: SubPatch) => {\n const readFile = createDestinationFileReader(dir);\n const paths = patch.file\n ? [patch.file]\n : await glob(patch.files ?? [], {\n cwd: dir,\n ignore: ['**/node_modules/**'],\n });\n\n await Promise.all(\n paths.map(async (path) => {\n const contents = await readFile(path);\n if (!contents) {\n return;\n }\n\n if (patch.regex && !patch.regex().test(contents)) {\n return;\n }\n\n if (patch.tests) {\n const results = await Promise.all(\n patch.tests.map((test) => test(path)),\n );\n if (!results.every(Boolean)) {\n return;\n }\n }\n\n await writePatchedContents({\n path,\n contents,\n templated: patch.replace,\n regex: patch.regex,\n });\n }),\n );\n};\n\nconst writePatchedContents = async ({\n path,\n contents,\n templated,\n regex,\n}: {\n path: string;\n contents: string;\n templated: string;\n regex?: () => RegExp;\n}) =>\n await fs.promises.writeFile(\n path,\n regex ? contents.replaceAll(regex(), templated) : templated,\n );\n\nconst upgrade = async (versions: Versions, dir: string) => {\n for (const subPatch of subPatches(versions)) {\n await runSubPatch(dir, subPatch);\n }\n};\n\nexport const nodeVersionMigration = async (\n {\n nodeVersion,\n ECMAScriptVersion,\n }: {\n nodeVersion: number;\n ECMAScriptVersion: string;\n },\n dir = process.cwd(),\n) => {\n log.ok(`Upgrading to Node.js ${nodeVersion}`);\n try {\n if (!(await isPatchableNodeVersion(nodeVersion, dir))) {\n throw new Error('Node.js version is not patchable');\n }\n\n await upgrade({ nodeVersion, ECMAScriptVersion }, dir);\n\n log.ok('Upgraded to Node.js', nodeVersion);\n } catch (error) {\n log.err('Failed to upgrade');\n log.subtle(inspect(error));\n process.exitCode = 1;\n }\n};\n"],
5
- "mappings": "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",
6
- "names": []
4
+ "sourcesContent": ["import { inspect } from 'util';\n\nimport { glob } from 'fast-glob';\nimport fs from 'fs-extra';\nimport { coerce, lt } from 'semver';\n\nimport { log } from '../../../utils/logging.js';\nimport { createDestinationFileReader } from '../../configure/analysis/project.js';\n\nimport { isLikelyPackage } from './checks.js';\nimport { tryUpgradeInfraPackages } from './upgrade.js';\n\ntype FileSelector =\n | { files: string; file?: never }\n | { file: string; files?: never };\n\ntype ReplaceOptions = {\n version: string;\n string: string;\n captureGroup: number;\n};\n\ntype SubPatch = FileSelector & {\n type: 'nodejs' | 'ecmascript';\n regex: () => RegExp;\n replace: {\n package?: ReplaceOptions;\n default: ReplaceOptions;\n };\n};\n\nconst subPatches = ({\n nodeVersion,\n ECMAScriptVersion,\n packageECMAScriptVersion,\n packageNodeVersion,\n}: Versions): SubPatch[] => [\n {\n type: 'nodejs',\n file: '.nvmrc',\n regex: () => /.*([0-9.]+).*/gm,\n replace: {\n default: {\n captureGroup: 1,\n string: nodeVersion,\n version: nodeVersion,\n },\n },\n },\n {\n type: 'nodejs',\n files: '**/Dockerfile*',\n\n regex: () =>\n /^FROM(.*) (public.ecr.aws\\/docker\\/library\\/)?node:([0-9]+(?:\\.[0-9]+(?:\\.[0-9]+)?)?)(-[a-z0-9]+)?(@sha256:[a-f0-9]{64})?( .*)?$/gm,\n replace: {\n default: {\n captureGroup: 3,\n string: `FROM$1 $2node:${nodeVersion}$4$6`,\n version: nodeVersion,\n },\n },\n },\n {\n type: 'nodejs',\n files: '**/Dockerfile*',\n regex: () =>\n /^FROM(.*) gcr.io\\/distroless\\/nodejs(\\d+)-debian(\\d+)(@sha256:[a-f0-9]{64})?(\\.[^- \\n]+)?(-[^ \\n]+)?( .+|)$/gm,\n replace: {\n default: {\n captureGroup: 2,\n string: `FROM$1 gcr.io/distroless/nodejs${nodeVersion}-debian$3$6$7`,\n version: nodeVersion,\n },\n },\n },\n\n {\n type: 'nodejs',\n files: '**/serverless*.y*ml',\n regex: () => /\\bnodejs(\\d+).x\\b/gm,\n replace: {\n default: {\n captureGroup: 1,\n string: `nodejs${nodeVersion}.x`,\n version: nodeVersion,\n },\n },\n },\n {\n type: 'nodejs',\n files: '**/serverless*.y*ml',\n regex: () => /\\bnode(\\d+)\\b/gm,\n replace: {\n default: {\n captureGroup: 1,\n string: `node${nodeVersion}`,\n version: nodeVersion,\n },\n },\n },\n\n {\n type: 'nodejs',\n files: '**/infra/**/*.ts',\n regex: () => /NODEJS_(\\d+)_X/g,\n replace: {\n default: {\n captureGroup: 1,\n string: `NODEJS_${nodeVersion}_X`,\n version: nodeVersion,\n },\n },\n },\n {\n type: 'nodejs',\n files: '**/infra/**/*.ts',\n regex: () => /(target:\\s*'node)(\\d+)(.+)$/gm,\n replace: {\n default: {\n captureGroup: 2,\n string: `$1${nodeVersion}$3`,\n version: nodeVersion,\n },\n },\n },\n\n {\n type: 'nodejs',\n files: '**/.buildkite/*',\n regex: () =>\n /(image: )(public.ecr.aws\\/docker\\/library\\/)?(node:)([0-9.]+)(\\.[^- \\n]+)?(-[^ \\n]+)?$/gm,\n replace: {\n default: {\n captureGroup: 4,\n string: `$1$2$3${nodeVersion}$5$6`,\n version: nodeVersion,\n },\n },\n },\n {\n type: 'nodejs',\n files: '.node-version*',\n regex: () => /(\\d+(?:\\.\\d+)*)/g,\n replace: {\n default: {\n captureGroup: 1,\n string: `${nodeVersion}`,\n version: nodeVersion,\n },\n },\n },\n\n {\n type: 'nodejs',\n files: '**/package.json',\n regex: () =>\n /([\"']engines[\"']:\\s*{[\\s\\S]*?[\"']node[\"']:\\s*[\"']>=)(\\d+(?:\\.\\d+)*)(['\"]\\s*})/gm,\n replace: {\n package: {\n string: `$1${packageNodeVersion}$3`,\n version: packageNodeVersion,\n captureGroup: 2,\n },\n default: {\n string: `$1${nodeVersion}$3`,\n version: nodeVersion,\n captureGroup: 2,\n },\n },\n },\n {\n type: 'nodejs',\n files: '**/docker-compose*.y*ml',\n regex: () =>\n /(image: )(public.ecr.aws\\/docker\\/library\\/)?(node:)([0-9.]+)(\\.[^- \\n]+)?(-[^ \\n]+)?$/gm,\n\n replace: {\n default: {\n captureGroup: 4,\n string: `$1$2$3${nodeVersion}$5$6`,\n version: nodeVersion,\n },\n },\n },\n {\n type: 'ecmascript',\n files: '**/tsconfig*.json',\n regex: () => /(\"target\":\\s*\")(ES\\d+)\"/gim,\n replace: {\n package: {\n string: `$1${packageECMAScriptVersion}\"`,\n version: packageECMAScriptVersion,\n captureGroup: 2,\n },\n default: {\n string: `$1${ECMAScriptVersion}\"`,\n version: ECMAScriptVersion,\n captureGroup: 2,\n },\n },\n },\n {\n type: 'ecmascript',\n files: '**/tsconfig*.json',\n regex: () => /(\"lib\":\\s*\\[)([\\S\\s]*?)(ES\\d+)([\\S\\s]*?)(\\])/gim,\n replace: {\n package: {\n string: `$1$2${packageECMAScriptVersion}$4$5`,\n version: packageECMAScriptVersion,\n captureGroup: 3,\n },\n default: {\n string: `$1$2${ECMAScriptVersion}$4$5`,\n version: ECMAScriptVersion,\n captureGroup: 3,\n },\n },\n },\n];\n\ntype Versions = {\n nodeVersion: string;\n ECMAScriptVersion: string;\n packageNodeVersion: string;\n packageECMAScriptVersion: string;\n};\n\nconst getTemplatedReplace = async (\n path: string,\n replace: SubPatch['replace'],\n): Promise<ReplaceOptions> => {\n if (!replace.package) {\n return replace.default;\n }\n\n const isPackage = await isLikelyPackage(path);\n\n if (isPackage) {\n return replace.package;\n }\n\n return replace.default;\n};\n\nconst runSubPatch = async (dir: string, patch: SubPatch) => {\n const readFile = createDestinationFileReader(dir);\n const paths = patch.file\n ? [patch.file]\n : await glob(patch.files ?? [], {\n cwd: dir,\n ignore: ['**/node_modules/**'],\n });\n\n await Promise.all(\n paths.map(async (path) => {\n const contents = await readFile(path);\n if (!contents) {\n return;\n }\n\n const regexResult = patch.regex().exec(contents);\n\n if (!regexResult) {\n return;\n }\n\n const templateReplace = await getTemplatedReplace(path, patch.replace);\n\n if (\n !lessThan(\n regexResult[templateReplace.captureGroup] as string,\n templateReplace.version,\n )\n ) {\n return;\n }\n\n await writePatchedContents({\n path,\n contents,\n templated: templateReplace.string,\n regex: patch.regex,\n });\n }),\n );\n};\n\nconst lessThan = (versionA: string, versionB: string) => {\n if (versionA.toLowerCase().startsWith('es')) {\n return Number(versionA.slice(2)) < Number(versionB.slice(2));\n }\n\n const coersedA = coerce(versionA);\n const coersedB = coerce(versionB);\n\n if (!coersedA || !coersedB) {\n throw new Error(\n `Unable to coerce versions for comparison: \"${versionA}\" and \"${versionB}\"`,\n );\n }\n\n return lt(coersedA, coersedB);\n};\n\nconst writePatchedContents = async ({\n path,\n contents,\n templated,\n regex,\n}: {\n path: string;\n contents: string;\n templated: string;\n regex: () => RegExp;\n}) => {\n const modified = contents.replaceAll(regex(), templated);\n await fs.promises.writeFile(path, modified);\n};\n\nconst upgrade = async (versions: Versions, dir: string) => {\n for (const subPatch of subPatches(versions)) {\n await runSubPatch(dir, subPatch);\n }\n};\n\nexport const nodeVersionMigration = async (\n {\n nodeVersion,\n ECMAScriptVersion,\n packageNodeVersion,\n packageECMAScriptVersion,\n infraPackages,\n }: {\n nodeVersion: string;\n ECMAScriptVersion: string;\n packageNodeVersion: string;\n packageECMAScriptVersion: string;\n infraPackages: Array<{ name: string; version: string }>;\n },\n dir = process.cwd(),\n) => {\n log.ok(\n `Upgrading project to Node.js ${nodeVersion} and package targets to Node.js ${packageNodeVersion}`,\n );\n\n try {\n await tryUpgradeInfraPackages('format', infraPackages);\n await upgrade(\n {\n nodeVersion,\n ECMAScriptVersion,\n packageNodeVersion,\n packageECMAScriptVersion,\n },\n dir,\n );\n\n log.ok(\n `Upgraded project to Node.js ${nodeVersion} and package targets to Node.js ${packageNodeVersion}`,\n );\n } catch (error) {\n log.err('Failed to upgrade');\n log.subtle(inspect(error));\n process.exitCode = 1;\n }\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["fs"]
7
7
  }
@@ -0,0 +1,8 @@
1
+ import type { PatchReturnType } from '../../lint/internalLints/upgrade/index.js';
2
+ type PackageInfo = {
3
+ name: string;
4
+ version: string;
5
+ };
6
+ export declare const upgradeInfraPackages: (mode: "lint" | "format", packages: PackageInfo[]) => Promise<PatchReturnType>;
7
+ export declare const tryUpgradeInfraPackages: (mode: "lint" | "format", packages: PackageInfo[]) => Promise<PatchReturnType>;
8
+ export {};
@@ -0,0 +1,179 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var upgrade_exports = {};
30
+ __export(upgrade_exports, {
31
+ tryUpgradeInfraPackages: () => tryUpgradeInfraPackages,
32
+ upgradeInfraPackages: () => upgradeInfraPackages
33
+ });
34
+ module.exports = __toCommonJS(upgrade_exports);
35
+ var import_node_util = require("node:util");
36
+ var import_fast_glob = require("fast-glob");
37
+ var import_fs_extra = __toESM(require("fs-extra"));
38
+ var import_semver = require("semver");
39
+ var import_exec = require("../../../utils/exec.js");
40
+ var import_logging = require("../../../utils/logging.js");
41
+ var import_packageManager = require("../../../utils/packageManager.js");
42
+ const packageVersionRegex = (packageName) => new RegExp(`"\\b${packageName}\\b"\\s*:\\s*"([^"]+)"`, "g");
43
+ const yamlPackageVersionRegex = (packageName) => new RegExp(`\\b${packageName}\\b:\\s*([^\\s]+)`, "g");
44
+ const normalizeVersionRange = (currentVersion, newVersion) => {
45
+ if (currentVersion.startsWith("^")) {
46
+ return `^${newVersion}`;
47
+ }
48
+ if (currentVersion.startsWith("~")) {
49
+ return `~${newVersion}`;
50
+ }
51
+ if (currentVersion.startsWith(">=") || currentVersion.startsWith(">") || currentVersion.startsWith("<=") || currentVersion.startsWith("<")) {
52
+ return `^${newVersion}`;
53
+ }
54
+ if (currentVersion.includes("x") || currentVersion.includes("X")) {
55
+ return `^${newVersion}`;
56
+ }
57
+ if (currentVersion.includes(" - ")) {
58
+ return `^${newVersion}`;
59
+ }
60
+ const coercedCurrent = (0, import_semver.coerce)(currentVersion);
61
+ if (coercedCurrent && (0, import_semver.lt)(coercedCurrent, newVersion)) {
62
+ return newVersion;
63
+ }
64
+ return currentVersion;
65
+ };
66
+ const upgradeInfraPackages = async (mode, packages) => {
67
+ const [packageJsonPaths, pnpmWorkspacePaths] = await Promise.all([
68
+ (0, import_fast_glob.glob)(["**/package.json"], {
69
+ ignore: ["**/.git", "**/node_modules"]
70
+ }),
71
+ (0, import_fast_glob.glob)("**/pnpm-workspace.yaml", {
72
+ ignore: ["**/.git", "**/node_modules"]
73
+ })
74
+ ]);
75
+ if (packageJsonPaths.length === 0 && pnpmWorkspacePaths.length === 0) {
76
+ return {
77
+ result: "skip",
78
+ reason: "no package.json or pnpm-workspace.yaml files found"
79
+ };
80
+ }
81
+ const [packageJsons, pnpmWorkspaces] = await Promise.all([
82
+ Promise.all(
83
+ packageJsonPaths.map(async (file) => {
84
+ const contents = await import_fs_extra.default.readFile(file, "utf8");
85
+ return {
86
+ file,
87
+ contents
88
+ };
89
+ })
90
+ ),
91
+ Promise.all(
92
+ pnpmWorkspacePaths.map(async (file) => {
93
+ const contents = await import_fs_extra.default.readFile(file, "utf8");
94
+ return {
95
+ file,
96
+ contents
97
+ };
98
+ })
99
+ )
100
+ ]);
101
+ const patchedPackageJsons = packageJsons.map((file) => {
102
+ const updated = packages.reduce((contents, packageName) => {
103
+ const regex = packageVersionRegex(packageName.name);
104
+ return contents.replaceAll(regex, (match, currentVersion) => {
105
+ if (currentVersion.startsWith("*") || currentVersion.startsWith("workspace:") || currentVersion.startsWith("link:") || currentVersion.startsWith("file:") || currentVersion.startsWith("catalog:")) {
106
+ return match;
107
+ }
108
+ const newVersion = normalizeVersionRange(
109
+ currentVersion,
110
+ packageName.version
111
+ );
112
+ return newVersion === currentVersion ? match : `"${packageName.name}":"${newVersion}"`;
113
+ });
114
+ }, file.contents);
115
+ return {
116
+ ...file,
117
+ updated
118
+ };
119
+ }).filter(({ contents, updated }) => contents !== updated);
120
+ const patchedPnpmWorkspaces = pnpmWorkspaces.map((file) => {
121
+ const updated = packages.reduce((contents, packageName) => {
122
+ const regex = yamlPackageVersionRegex(packageName.name);
123
+ return contents.replace(regex, (match, currentVersion) => {
124
+ const newVersion = normalizeVersionRange(
125
+ currentVersion,
126
+ packageName.version
127
+ );
128
+ return newVersion === currentVersion ? match : `${packageName.name}: ${newVersion}`;
129
+ });
130
+ }, file.contents);
131
+ return {
132
+ ...file,
133
+ updated
134
+ };
135
+ }).filter(({ contents, updated }) => contents !== updated);
136
+ if (patchedPackageJsons.length === 0 && patchedPnpmWorkspaces.length === 0) {
137
+ return {
138
+ result: "skip",
139
+ reason: "no package.json or pnpm-workspace.yaml files to patch"
140
+ };
141
+ }
142
+ if (mode === "lint") {
143
+ return {
144
+ result: "apply"
145
+ };
146
+ }
147
+ await Promise.all(
148
+ [...patchedPackageJsons, ...patchedPnpmWorkspaces].map(
149
+ async ({ file, updated }) => {
150
+ await import_fs_extra.default.writeFile(file, updated, "utf8");
151
+ }
152
+ )
153
+ );
154
+ const packageManager = await (0, import_packageManager.detectPackageManager)();
155
+ await (0, import_exec.exec)(
156
+ packageManager.command,
157
+ "install",
158
+ "--frozen-lockfile=false",
159
+ "--prefer-offline"
160
+ );
161
+ return {
162
+ result: "apply"
163
+ };
164
+ };
165
+ const tryUpgradeInfraPackages = async (mode, packages) => {
166
+ try {
167
+ return await upgradeInfraPackages(mode, packages);
168
+ } catch (err) {
169
+ import_logging.log.err("Failed to upgrade infrastructure packages");
170
+ import_logging.log.subtle((0, import_node_util.inspect)(err));
171
+ return { result: "skip", reason: "due to an error" };
172
+ }
173
+ };
174
+ // Annotate the CommonJS export names for ESM import in node:
175
+ 0 && (module.exports = {
176
+ tryUpgradeInfraPackages,
177
+ upgradeInfraPackages
178
+ });
179
+ //# sourceMappingURL=upgrade.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/cli/migrate/nodeVersion/upgrade.ts"],
4
+ "sourcesContent": ["import { inspect } from 'node:util';\n\nimport { glob } from 'fast-glob';\nimport fs from 'fs-extra';\nimport { coerce, lt } from 'semver';\n\nimport { exec } from '../../../utils/exec.js';\nimport { log } from '../../../utils/logging.js';\nimport { detectPackageManager } from '../../../utils/packageManager.js';\nimport type { PatchReturnType } from '../../lint/internalLints/upgrade/index.js';\n\nconst packageVersionRegex = (packageName: string) =>\n new RegExp(`\"\\\\b${packageName}\\\\b\"\\\\s*:\\\\s*\"([^\"]+)\"`, 'g');\n\nconst yamlPackageVersionRegex = (packageName: string) =>\n new RegExp(`\\\\b${packageName}\\\\b:\\\\s*([^\\\\s]+)`, 'g');\n\nconst normalizeVersionRange = (\n currentVersion: string,\n newVersion: string,\n): string => {\n if (currentVersion.startsWith('^')) {\n return `^${newVersion}`;\n }\n\n if (currentVersion.startsWith('~')) {\n return `~${newVersion}`;\n }\n\n // >=1.2.3, >1.2.3, <=1.2.3, <1.2.3\n if (\n currentVersion.startsWith('>=') ||\n currentVersion.startsWith('>') ||\n currentVersion.startsWith('<=') ||\n currentVersion.startsWith('<')\n ) {\n return `^${newVersion}`;\n }\n\n // 1.x, 1.2.x, 1.x.x\n if (currentVersion.includes('x') || currentVersion.includes('X')) {\n return `^${newVersion}`;\n }\n\n // 1.0.0 - 2.0.0\n if (currentVersion.includes(' - ')) {\n return `^${newVersion}`;\n }\n\n const coercedCurrent = coerce(currentVersion);\n if (coercedCurrent && lt(coercedCurrent, newVersion)) {\n return newVersion;\n }\n\n return currentVersion;\n};\n\ntype PackageInfo = {\n name: string;\n version: string;\n};\n\nexport const upgradeInfraPackages = async (\n mode: 'lint' | 'format',\n packages: PackageInfo[],\n): Promise<PatchReturnType> => {\n const [packageJsonPaths, pnpmWorkspacePaths] = await Promise.all([\n glob(['**/package.json'], {\n ignore: ['**/.git', '**/node_modules'],\n }),\n glob('**/pnpm-workspace.yaml', {\n ignore: ['**/.git', '**/node_modules'],\n }),\n ]);\n\n if (packageJsonPaths.length === 0 && pnpmWorkspacePaths.length === 0) {\n return {\n result: 'skip',\n reason: 'no package.json or pnpm-workspace.yaml files found',\n };\n }\n\n const [packageJsons, pnpmWorkspaces] = await Promise.all([\n Promise.all(\n packageJsonPaths.map(async (file) => {\n const contents = await fs.readFile(file, 'utf8');\n\n return {\n file,\n contents,\n };\n }),\n ),\n Promise.all(\n pnpmWorkspacePaths.map(async (file) => {\n const contents = await fs.readFile(file, 'utf8');\n\n return {\n file,\n contents,\n };\n }),\n ),\n ]);\n\n const patchedPackageJsons = packageJsons\n .map((file) => {\n const updated = packages.reduce((contents, packageName) => {\n const regex = packageVersionRegex(packageName.name);\n return contents.replaceAll(regex, (match, currentVersion: string) => {\n if (\n currentVersion.startsWith('*') ||\n currentVersion.startsWith('workspace:') ||\n currentVersion.startsWith('link:') ||\n currentVersion.startsWith('file:') ||\n currentVersion.startsWith('catalog:')\n ) {\n return match;\n }\n\n const newVersion = normalizeVersionRange(\n currentVersion,\n packageName.version,\n );\n\n return newVersion === currentVersion\n ? match\n : `\"${packageName.name}\":\"${newVersion}\"`;\n });\n }, file.contents);\n\n return {\n ...file,\n updated,\n };\n })\n .filter(({ contents, updated }) => contents !== updated);\n\n const patchedPnpmWorkspaces = pnpmWorkspaces\n .map((file) => {\n const updated = packages.reduce((contents, packageName) => {\n const regex = yamlPackageVersionRegex(packageName.name);\n return contents.replace(regex, (match, currentVersion: string) => {\n const newVersion = normalizeVersionRange(\n currentVersion,\n packageName.version,\n );\n\n return newVersion === currentVersion\n ? match\n : `${packageName.name}: ${newVersion}`;\n });\n }, file.contents);\n\n return {\n ...file,\n updated,\n };\n })\n .filter(({ contents, updated }) => contents !== updated);\n\n if (patchedPackageJsons.length === 0 && patchedPnpmWorkspaces.length === 0) {\n return {\n result: 'skip',\n reason: 'no package.json or pnpm-workspace.yaml files to patch',\n };\n }\n\n if (mode === 'lint') {\n return {\n result: 'apply',\n };\n }\n\n await Promise.all(\n [...patchedPackageJsons, ...patchedPnpmWorkspaces].map(\n async ({ file, updated }) => {\n await fs.writeFile(file, updated, 'utf8');\n },\n ),\n );\n\n const packageManager = await detectPackageManager();\n\n await exec(\n packageManager.command,\n 'install',\n '--frozen-lockfile=false',\n '--prefer-offline',\n );\n\n return {\n result: 'apply',\n };\n};\n\nexport const tryUpgradeInfraPackages = async (\n mode: 'lint' | 'format',\n packages: PackageInfo[],\n): Promise<PatchReturnType> => {\n try {\n return await upgradeInfraPackages(mode, packages);\n } catch (err) {\n log.err('Failed to upgrade infrastructure packages');\n log.subtle(inspect(err));\n return { result: 'skip', reason: 'due to an error' };\n }\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["fs"]
7
+ }
@@ -1,54 +1,91 @@
1
- import path from "path";
2
- import execa from "execa";
3
- import getPort from "get-port";
4
- import { parseRunArgs } from "../../utils/args.js";
5
- import { createExec } from "../../utils/exec.js";
6
- import { isIpPort } from "../../utils/validation.js";
7
- import { getCustomConditions } from "../build/tsc.js";
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var node_exports = {};
30
+ __export(node_exports, {
31
+ longRunning: () => longRunning,
32
+ node: () => node
33
+ });
34
+ module.exports = __toCommonJS(node_exports);
35
+ var import_path = __toESM(require("path"));
36
+ var import_execa = __toESM(require("execa"));
37
+ var import_get_port = __toESM(require("get-port"));
38
+ var import_args = require("../../utils/args.js");
39
+ var import_exec = require("../../utils/exec.js");
40
+ var import_validation = require("../../utils/validation.js");
41
+ var import_tsc = require("../build/tsc.js");
8
42
  const longRunning = true;
9
43
  const node = async () => {
10
- const args = parseRunArgs(process.argv.slice(2));
11
- const customConditions = getCustomConditions();
44
+ const args = (0, import_args.parseRunArgs)(process.argv.slice(2));
45
+ const customConditions = (0, import_tsc.getCustomConditions)();
12
46
  const uniqueConditions = [
13
47
  .../* @__PURE__ */ new Set([...args.conditions ?? [], ...customConditions])
14
48
  ];
15
- const availablePort = await getPort();
49
+ const availablePort = await (0, import_get_port.default)();
16
50
  const commonArgs = [
17
51
  ...args.node,
18
52
  ...uniqueConditions.map((condition) => `--conditions=${condition}`),
19
53
  "--env-file-if-exists",
20
- ".env"
54
+ ".env",
55
+ "--require",
56
+ require.resolve("tsconfig-paths/register")
21
57
  ];
22
58
  if (args.entryPoint) {
23
- const exec = createExec({
59
+ const exec = (0, import_exec.createExec)({
24
60
  env: {
25
61
  __SKUBA_ENTRY_POINT: args.entryPoint,
26
- __SKUBA_PORT: String(isIpPort(args.port) ? args.port : availablePort)
62
+ __SKUBA_PORT: String((0, import_validation.isIpPort)(args.port) ? args.port : availablePort)
27
63
  }
28
64
  });
29
65
  return exec(
30
66
  "tsx",
31
67
  ...commonArgs,
32
- path.join(import.meta.dirname, "..", "..", "wrapper", "index.js"),
68
+ import_path.default.join(__dirname, "..", "..", "wrapper", "index.js"),
33
69
  ...args.script
34
70
  );
35
71
  }
36
- return execa(
37
- new URL(import.meta.resolve("tsx/cli")).pathname,
72
+ return (0, import_execa.default)(
73
+ require.resolve("tsx/cli"),
38
74
  [
39
75
  ...commonArgs,
40
- "--import",
76
+ "--require",
41
77
  // Unsure if bug or feature that this is needed, but tsx appears to not do anything typescript in the REPL without this!
42
78
  // Doesn't occur when just running the tsx binary directly 🧐
43
- new URL(import.meta.resolve("tsx/patch-repl")).pathname
79
+ require.resolve("tsx/patch-repl")
44
80
  ],
45
81
  {
46
82
  stdio: "inherit"
47
83
  }
48
84
  );
49
85
  };
50
- export {
86
+ // Annotate the CommonJS export names for ESM import in node:
87
+ 0 && (module.exports = {
51
88
  longRunning,
52
89
  node
53
- };
90
+ });
54
91
  //# sourceMappingURL=index.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/node/index.ts"],
4
- "sourcesContent": ["import path from 'path';\n\nimport execa from 'execa';\nimport getPort from 'get-port';\n\nimport { parseRunArgs } from '../../utils/args.js';\nimport { createExec } from '../../utils/exec.js';\nimport { isIpPort } from '../../utils/validation.js';\nimport { getCustomConditions } from '../build/tsc.js';\n\nexport const longRunning = true;\n\nexport const node = async () => {\n const args = parseRunArgs(process.argv.slice(2));\n const customConditions = getCustomConditions();\n\n const uniqueConditions = [\n ...new Set([...(args.conditions ?? []), ...customConditions]),\n ];\n\n const availablePort = await getPort();\n\n const commonArgs = [\n ...args.node,\n ...uniqueConditions.map((condition) => `--conditions=${condition}`),\n '--env-file-if-exists',\n '.env',\n ];\n\n if (args.entryPoint) {\n const exec = createExec({\n env: {\n __SKUBA_ENTRY_POINT: args.entryPoint,\n __SKUBA_PORT: String(isIpPort(args.port) ? args.port : availablePort),\n },\n });\n\n return exec(\n 'tsx',\n ...commonArgs,\n path.join(import.meta.dirname, '..', '..', 'wrapper', 'index.js'),\n ...args.script,\n );\n }\n\n return execa(\n new URL(import.meta.resolve('tsx/cli')).pathname,\n [\n ...commonArgs,\n '--import',\n // Unsure if bug or feature that this is needed, but tsx appears to not do anything typescript in the REPL without this!\n // Doesn't occur when just running the tsx binary directly \uD83E\uDDD0\n new URL(import.meta.resolve('tsx/patch-repl')).pathname,\n ],\n {\n stdio: 'inherit',\n },\n );\n};\n"],
5
- "mappings": "AAAA,OAAO,UAAU;AAEjB,OAAO,WAAW;AAClB,OAAO,aAAa;AAEpB,SAAS,oBAAoB;AAC7B,SAAS,kBAAkB;AAC3B,SAAS,gBAAgB;AACzB,SAAS,2BAA2B;AAE7B,MAAM,cAAc;AAEpB,MAAM,OAAO,YAAY;AAC9B,QAAM,OAAO,aAAa,QAAQ,KAAK,MAAM,CAAC,CAAC;AAC/C,QAAM,mBAAmB,oBAAoB;AAE7C,QAAM,mBAAmB;AAAA,IACvB,GAAG,oBAAI,IAAI,CAAC,GAAI,KAAK,cAAc,CAAC,GAAI,GAAG,gBAAgB,CAAC;AAAA,EAC9D;AAEA,QAAM,gBAAgB,MAAM,QAAQ;AAEpC,QAAM,aAAa;AAAA,IACjB,GAAG,KAAK;AAAA,IACR,GAAG,iBAAiB,IAAI,CAAC,cAAc,gBAAgB,SAAS,EAAE;AAAA,IAClE;AAAA,IACA;AAAA,EACF;AAEA,MAAI,KAAK,YAAY;AACnB,UAAM,OAAO,WAAW;AAAA,MACtB,KAAK;AAAA,QACH,qBAAqB,KAAK;AAAA,QAC1B,cAAc,OAAO,SAAS,KAAK,IAAI,IAAI,KAAK,OAAO,aAAa;AAAA,MACtE;AAAA,IACF,CAAC;AAED,WAAO;AAAA,MACL;AAAA,MACA,GAAG;AAAA,MACH,KAAK,KAAK,YAAY,SAAS,MAAM,MAAM,WAAW,UAAU;AAAA,MAChE,GAAG,KAAK;AAAA,IACV;AAAA,EACF;AAEA,SAAO;AAAA,IACL,IAAI,IAAI,YAAY,QAAQ,SAAS,CAAC,EAAE;AAAA,IACxC;AAAA,MACE,GAAG;AAAA,MACH;AAAA;AAAA;AAAA,MAGA,IAAI,IAAI,YAAY,QAAQ,gBAAgB,CAAC,EAAE;AAAA,IACjD;AAAA,IACA;AAAA,MACE,OAAO;AAAA,IACT;AAAA,EACF;AACF;",
6
- "names": []
4
+ "sourcesContent": ["import path from 'path';\n\nimport execa from 'execa';\nimport getPort from 'get-port';\n\nimport { parseRunArgs } from '../../utils/args.js';\nimport { createExec } from '../../utils/exec.js';\nimport { isIpPort } from '../../utils/validation.js';\nimport { getCustomConditions } from '../build/tsc.js';\n\nexport const longRunning = true;\n\nexport const node = async () => {\n const args = parseRunArgs(process.argv.slice(2));\n const customConditions = getCustomConditions();\n\n const uniqueConditions = [\n ...new Set([...(args.conditions ?? []), ...customConditions]),\n ];\n\n const availablePort = await getPort();\n\n const commonArgs = [\n ...args.node,\n ...uniqueConditions.map((condition) => `--conditions=${condition}`),\n '--env-file-if-exists',\n '.env',\n '--require',\n require.resolve('tsconfig-paths/register'),\n ];\n\n if (args.entryPoint) {\n const exec = createExec({\n env: {\n __SKUBA_ENTRY_POINT: args.entryPoint,\n __SKUBA_PORT: String(isIpPort(args.port) ? args.port : availablePort),\n },\n });\n\n return exec(\n 'tsx',\n ...commonArgs,\n path.join(__dirname, '..', '..', 'wrapper', 'index.js'),\n ...args.script,\n );\n }\n\n return execa(\n require.resolve('tsx/cli'),\n [\n ...commonArgs,\n '--require',\n // Unsure if bug or feature that this is needed, but tsx appears to not do anything typescript in the REPL without this!\n // Doesn't occur when just running the tsx binary directly \uD83E\uDDD0\n require.resolve('tsx/patch-repl'),\n ],\n {\n stdio: 'inherit',\n },\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAAiB;AAEjB,mBAAkB;AAClB,sBAAoB;AAEpB,kBAA6B;AAC7B,kBAA2B;AAC3B,wBAAyB;AACzB,iBAAoC;AAE7B,MAAM,cAAc;AAEpB,MAAM,OAAO,YAAY;AAC9B,QAAM,WAAO,0BAAa,QAAQ,KAAK,MAAM,CAAC,CAAC;AAC/C,QAAM,uBAAmB,gCAAoB;AAE7C,QAAM,mBAAmB;AAAA,IACvB,GAAG,oBAAI,IAAI,CAAC,GAAI,KAAK,cAAc,CAAC,GAAI,GAAG,gBAAgB,CAAC;AAAA,EAC9D;AAEA,QAAM,gBAAgB,UAAM,gBAAAA,SAAQ;AAEpC,QAAM,aAAa;AAAA,IACjB,GAAG,KAAK;AAAA,IACR,GAAG,iBAAiB,IAAI,CAAC,cAAc,gBAAgB,SAAS,EAAE;AAAA,IAClE;AAAA,IACA;AAAA,IACA;AAAA,IACA,gBAAgB,yBAAyB;AAAA,EAC3C;AAEA,MAAI,KAAK,YAAY;AACnB,UAAM,WAAO,wBAAW;AAAA,MACtB,KAAK;AAAA,QACH,qBAAqB,KAAK;AAAA,QAC1B,cAAc,WAAO,4BAAS,KAAK,IAAI,IAAI,KAAK,OAAO,aAAa;AAAA,MACtE;AAAA,IACF,CAAC;AAED,WAAO;AAAA,MACL;AAAA,MACA,GAAG;AAAA,MACH,YAAAC,QAAK,KAAK,WAAW,MAAM,MAAM,WAAW,UAAU;AAAA,MACtD,GAAG,KAAK;AAAA,IACV;AAAA,EACF;AAEA,aAAO,aAAAC;AAAA,IACL,gBAAgB,SAAS;AAAA,IACzB;AAAA,MACE,GAAG;AAAA,MACH;AAAA;AAAA;AAAA,MAGA,gBAAgB,gBAAgB;AAAA,IAClC;AAAA,IACA;AAAA,MACE,OAAO;AAAA,IACT;AAAA,EACF;AACF;",
6
+ "names": ["getPort", "path", "execa"]
7
7
  }
@@ -1,8 +1,32 @@
1
- import { exec } from "../../utils/exec.js";
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var release_exports = {};
20
+ __export(release_exports, {
21
+ release: () => release
22
+ });
23
+ module.exports = __toCommonJS(release_exports);
24
+ var import_exec = require("../../utils/exec.js");
2
25
  const release = async () => {
3
- await exec("semantic-release", "--success", "false");
26
+ await (0, import_exec.exec)("semantic-release", "--success", "false");
4
27
  };
5
- export {
28
+ // Annotate the CommonJS export names for ESM import in node:
29
+ 0 && (module.exports = {
6
30
  release
7
- };
31
+ });
8
32
  //# sourceMappingURL=index.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/release/index.ts"],
4
4
  "sourcesContent": ["import { exec } from '../../utils/exec.js';\n\nexport const release = async () => {\n await exec('semantic-release', '--success', 'false');\n};\n"],
5
- "mappings": "AAAA,SAAS,YAAY;AAEd,MAAM,UAAU,YAAY;AACjC,QAAM,KAAK,oBAAoB,aAAa,OAAO;AACrD;",
5
+ "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAAqB;AAEd,MAAM,UAAU,YAAY;AACjC,YAAM,kBAAK,oBAAoB,aAAa,OAAO;AACrD;",
6
6
  "names": []
7
7
  }
@@ -1,22 +1,55 @@
1
- import path from "path";
2
- import getPort from "get-port";
3
- import { parseRunArgs } from "../../utils/args.js";
4
- import { createExec } from "../../utils/exec.js";
5
- import { getEntryPointFromManifest } from "../../utils/manifest.js";
6
- import { isIpPort } from "../../utils/validation.js";
7
- import { getCustomConditions } from "../build/tsc.js";
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var start_exports = {};
30
+ __export(start_exports, {
31
+ start: () => start
32
+ });
33
+ module.exports = __toCommonJS(start_exports);
34
+ var import_path = __toESM(require("path"));
35
+ var import_get_port = __toESM(require("get-port"));
36
+ var import_args = require("../../utils/args.js");
37
+ var import_exec = require("../../utils/exec.js");
38
+ var import_manifest = require("../../utils/manifest.js");
39
+ var import_validation = require("../../utils/validation.js");
40
+ var import_tsc = require("../build/tsc.js");
8
41
  const start = async () => {
9
- const customConditions = getCustomConditions();
10
- const args = parseRunArgs(process.argv.slice(2));
11
- const availablePort = await getPort();
42
+ const customConditions = (0, import_tsc.getCustomConditions)();
43
+ const args = (0, import_args.parseRunArgs)(process.argv.slice(2));
44
+ const availablePort = await (0, import_get_port.default)();
12
45
  const uniqueConditions = [
13
46
  .../* @__PURE__ */ new Set([...args.conditions ?? [], ...customConditions])
14
47
  ];
15
- args.entryPoint ??= await getEntryPointFromManifest();
16
- const execProcess = createExec({
48
+ args.entryPoint ??= await (0, import_manifest.getEntryPointFromManifest)();
49
+ const execProcess = (0, import_exec.createExec)({
17
50
  env: {
18
51
  __SKUBA_ENTRY_POINT: args.entryPoint,
19
- __SKUBA_PORT: String(isIpPort(args.port) ? args.port : availablePort)
52
+ __SKUBA_PORT: String((0, import_validation.isIpPort)(args.port) ? args.port : availablePort)
20
53
  }
21
54
  });
22
55
  return execProcess(
@@ -29,11 +62,12 @@ const start = async () => {
29
62
  ".env",
30
63
  "--require",
31
64
  "tsconfig-paths/register",
32
- path.join(import.meta.dirname, "..", "..", "wrapper", "index.js"),
65
+ import_path.default.join(__dirname, "..", "..", "wrapper", "index.js"),
33
66
  ...args.script
34
67
  );
35
68
  };
36
- export {
69
+ // Annotate the CommonJS export names for ESM import in node:
70
+ 0 && (module.exports = {
37
71
  start
38
- };
72
+ });
39
73
  //# sourceMappingURL=index.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/cli/start/index.ts"],
4
- "sourcesContent": ["import path from 'path';\n\nimport getPort from 'get-port';\n\nimport { parseRunArgs } from '../../utils/args.js';\nimport { createExec } from '../../utils/exec.js';\nimport { getEntryPointFromManifest } from '../../utils/manifest.js';\nimport { isIpPort } from '../../utils/validation.js';\nimport { getCustomConditions } from '../build/tsc.js';\n\nexport const start = async () => {\n const customConditions = getCustomConditions();\n const args = parseRunArgs(process.argv.slice(2));\n const availablePort = await getPort();\n\n const uniqueConditions = [\n ...new Set([...(args.conditions ?? []), ...customConditions]),\n ];\n\n args.entryPoint ??= await getEntryPointFromManifest();\n\n const execProcess = createExec({\n env: {\n __SKUBA_ENTRY_POINT: args.entryPoint,\n __SKUBA_PORT: String(isIpPort(args.port) ? args.port : availablePort),\n },\n });\n\n return execProcess(\n 'tsx',\n 'watch',\n '--clear-screen=false',\n ...args.node,\n ...uniqueConditions.map((condition) => `--conditions=${condition}`),\n '--env-file-if-exists',\n '.env',\n '--require',\n 'tsconfig-paths/register',\n path.join(import.meta.dirname, '..', '..', 'wrapper', 'index.js'),\n ...args.script,\n );\n};\n"],
5
- "mappings": "AAAA,OAAO,UAAU;AAEjB,OAAO,aAAa;AAEpB,SAAS,oBAAoB;AAC7B,SAAS,kBAAkB;AAC3B,SAAS,iCAAiC;AAC1C,SAAS,gBAAgB;AACzB,SAAS,2BAA2B;AAE7B,MAAM,QAAQ,YAAY;AAC/B,QAAM,mBAAmB,oBAAoB;AAC7C,QAAM,OAAO,aAAa,QAAQ,KAAK,MAAM,CAAC,CAAC;AAC/C,QAAM,gBAAgB,MAAM,QAAQ;AAEpC,QAAM,mBAAmB;AAAA,IACvB,GAAG,oBAAI,IAAI,CAAC,GAAI,KAAK,cAAc,CAAC,GAAI,GAAG,gBAAgB,CAAC;AAAA,EAC9D;AAEA,OAAK,eAAe,MAAM,0BAA0B;AAEpD,QAAM,cAAc,WAAW;AAAA,IAC7B,KAAK;AAAA,MACH,qBAAqB,KAAK;AAAA,MAC1B,cAAc,OAAO,SAAS,KAAK,IAAI,IAAI,KAAK,OAAO,aAAa;AAAA,IACtE;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG,KAAK;AAAA,IACR,GAAG,iBAAiB,IAAI,CAAC,cAAc,gBAAgB,SAAS,EAAE;AAAA,IAClE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,KAAK,KAAK,YAAY,SAAS,MAAM,MAAM,WAAW,UAAU;AAAA,IAChE,GAAG,KAAK;AAAA,EACV;AACF;",
6
- "names": []
4
+ "sourcesContent": ["import path from 'path';\n\nimport getPort from 'get-port';\n\nimport { parseRunArgs } from '../../utils/args.js';\nimport { createExec } from '../../utils/exec.js';\nimport { getEntryPointFromManifest } from '../../utils/manifest.js';\nimport { isIpPort } from '../../utils/validation.js';\nimport { getCustomConditions } from '../build/tsc.js';\n\nexport const start = async () => {\n const customConditions = getCustomConditions();\n const args = parseRunArgs(process.argv.slice(2));\n const availablePort = await getPort();\n\n const uniqueConditions = [\n ...new Set([...(args.conditions ?? []), ...customConditions]),\n ];\n\n args.entryPoint ??= await getEntryPointFromManifest();\n\n const execProcess = createExec({\n env: {\n __SKUBA_ENTRY_POINT: args.entryPoint,\n __SKUBA_PORT: String(isIpPort(args.port) ? args.port : availablePort),\n },\n });\n\n return execProcess(\n 'tsx',\n 'watch',\n '--clear-screen=false',\n ...args.node,\n ...uniqueConditions.map((condition) => `--conditions=${condition}`),\n '--env-file-if-exists',\n '.env',\n '--require',\n 'tsconfig-paths/register',\n path.join(__dirname, '..', '..', 'wrapper', 'index.js'),\n ...args.script,\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAAiB;AAEjB,sBAAoB;AAEpB,kBAA6B;AAC7B,kBAA2B;AAC3B,sBAA0C;AAC1C,wBAAyB;AACzB,iBAAoC;AAE7B,MAAM,QAAQ,YAAY;AAC/B,QAAM,uBAAmB,gCAAoB;AAC7C,QAAM,WAAO,0BAAa,QAAQ,KAAK,MAAM,CAAC,CAAC;AAC/C,QAAM,gBAAgB,UAAM,gBAAAA,SAAQ;AAEpC,QAAM,mBAAmB;AAAA,IACvB,GAAG,oBAAI,IAAI,CAAC,GAAI,KAAK,cAAc,CAAC,GAAI,GAAG,gBAAgB,CAAC;AAAA,EAC9D;AAEA,OAAK,eAAe,UAAM,2CAA0B;AAEpD,QAAM,kBAAc,wBAAW;AAAA,IAC7B,KAAK;AAAA,MACH,qBAAqB,KAAK;AAAA,MAC1B,cAAc,WAAO,4BAAS,KAAK,IAAI,IAAI,KAAK,OAAO,aAAa;AAAA,IACtE;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAG,KAAK;AAAA,IACR,GAAG,iBAAiB,IAAI,CAAC,cAAc,gBAAgB,SAAS,EAAE;AAAA,IAClE;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,YAAAC,QAAK,KAAK,WAAW,MAAM,MAAM,WAAW,UAAU;AAAA,IACtD,GAAG,KAAK;AAAA,EACV;AACF;",
6
+ "names": ["getPort", "path"]
7
7
  }
@@ -1,9 +1,49 @@
1
- import { exec } from "../../utils/exec.js";
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var test_exports = {};
30
+ __export(test_exports, {
31
+ test: () => test
32
+ });
33
+ module.exports = __toCommonJS(test_exports);
34
+ var import_exec = require("../../utils/exec.js");
2
35
  const test = async () => {
3
36
  const argv = process.argv.slice(2);
4
- return exec("vitest", ...argv);
37
+ const nodeOptions = process.env.NODE_OPTIONS ?? "";
38
+ const execWithEnv = (0, import_exec.createExec)({
39
+ env: {
40
+ NODE_OPTIONS: !nodeOptions.includes("--experimental-vm-modules") ? `${nodeOptions} --experimental-vm-modules --no-warnings=ExperimentalWarning` : nodeOptions
41
+ }
42
+ });
43
+ return execWithEnv(require.resolve("jest/bin/jest"), ...argv);
5
44
  };
6
- export {
45
+ // Annotate the CommonJS export names for ESM import in node:
46
+ 0 && (module.exports = {
7
47
  test
8
- };
48
+ });
9
49
  //# sourceMappingURL=index.js.map