dotenv-diff 2.7.9 → 2.7.10

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 (393) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/dist/src/commands/compare.js +1 -1
  3. package/dist/src/commands/compare.js.map +1 -1
  4. package/dist/src/commands/prompts/promptEnsureFiles.d.ts.map +1 -1
  5. package/dist/src/commands/prompts/promptEnsureFiles.js +10 -5
  6. package/dist/src/commands/prompts/promptEnsureFiles.js.map +1 -1
  7. package/dist/src/commands/scanUsage.js +9 -9
  8. package/dist/src/commands/scanUsage.js.map +1 -1
  9. package/dist/src/config/types.d.ts +2 -1
  10. package/dist/src/config/types.d.ts.map +1 -1
  11. package/dist/src/core/fixEnv.d.ts.map +1 -1
  12. package/dist/src/core/fixEnv.js +8 -5
  13. package/dist/src/core/fixEnv.js.map +1 -1
  14. package/dist/src/core/helpers/isLikelyMinified.d.ts +2 -0
  15. package/dist/src/core/helpers/isLikelyMinified.d.ts.map +1 -1
  16. package/dist/src/core/helpers/isLikelyMinified.js +2 -0
  17. package/dist/src/core/helpers/isLikelyMinified.js.map +1 -1
  18. package/dist/src/core/scan/patterns.d.ts +9 -1
  19. package/dist/src/core/scan/patterns.d.ts.map +1 -1
  20. package/dist/src/core/scan/patterns.js +32 -0
  21. package/dist/src/core/scan/patterns.js.map +1 -1
  22. package/dist/src/core/scan/scanFile.d.ts.map +1 -1
  23. package/dist/src/core/scan/scanFile.js +9 -2
  24. package/dist/src/core/scan/scanFile.js.map +1 -1
  25. package/dist/src/core/security/secretDetectors.js +1 -1
  26. package/dist/src/core/security/secretDetectors.js.map +1 -1
  27. package/dist/src/services/detectEnvExpirations.js +0 -2
  28. package/dist/src/services/detectEnvExpirations.js.map +1 -1
  29. package/dist/src/services/envDiscovery.js +6 -6
  30. package/dist/src/services/envDiscovery.js.map +1 -1
  31. package/dist/src/services/processComparisonFile.d.ts +1 -2
  32. package/dist/src/services/processComparisonFile.d.ts.map +1 -1
  33. package/dist/test/e2e/cli.autoscan.e2e.test.d.ts +2 -0
  34. package/dist/test/e2e/cli.autoscan.e2e.test.d.ts.map +1 -0
  35. package/dist/test/e2e/cli.autoscan.e2e.test.js +263 -0
  36. package/dist/test/e2e/cli.autoscan.e2e.test.js.map +1 -0
  37. package/dist/test/e2e/cli.compare.e2e.test.d.ts +2 -0
  38. package/dist/test/e2e/cli.compare.e2e.test.d.ts.map +1 -0
  39. package/dist/test/e2e/cli.compare.e2e.test.js +94 -0
  40. package/dist/test/e2e/cli.compare.e2e.test.js.map +1 -0
  41. package/dist/test/e2e/cli.detectExpired.e2e.test.d.ts +2 -0
  42. package/dist/test/e2e/cli.detectExpired.e2e.test.d.ts.map +1 -0
  43. package/dist/test/e2e/cli.detectExpired.e2e.test.js +148 -0
  44. package/dist/test/e2e/cli.detectExpired.e2e.test.js.map +1 -0
  45. package/dist/test/e2e/cli.flags.e2e.test.d.ts +2 -0
  46. package/dist/test/e2e/cli.flags.e2e.test.d.ts.map +1 -0
  47. package/dist/test/e2e/cli.flags.e2e.test.js +424 -0
  48. package/dist/test/e2e/cli.flags.e2e.test.js.map +1 -0
  49. package/dist/test/e2e/cli.healthscore.test.d.ts +2 -0
  50. package/dist/test/e2e/cli.healthscore.test.d.ts.map +1 -0
  51. package/dist/test/e2e/cli.healthscore.test.js +79 -0
  52. package/dist/test/e2e/cli.healthscore.test.js.map +1 -0
  53. package/dist/test/e2e/cli.ignore.e2e.test.d.ts +2 -0
  54. package/dist/test/e2e/cli.ignore.e2e.test.d.ts.map +1 -0
  55. package/dist/test/e2e/cli.ignore.e2e.test.js +88 -0
  56. package/dist/test/e2e/cli.ignore.e2e.test.js.map +1 -0
  57. package/dist/test/e2e/cli.inconsistentNaming.e2e.test.d.ts +2 -0
  58. package/dist/test/e2e/cli.inconsistentNaming.e2e.test.d.ts.map +1 -0
  59. package/dist/test/e2e/cli.inconsistentNaming.e2e.test.js +94 -0
  60. package/dist/test/e2e/cli.inconsistentNaming.e2e.test.js.map +1 -0
  61. package/dist/test/e2e/cli.jsonOutput.e2e.test.d.ts +2 -0
  62. package/dist/test/e2e/cli.jsonOutput.e2e.test.d.ts.map +1 -0
  63. package/dist/test/e2e/cli.jsonOutput.e2e.test.js +39 -0
  64. package/dist/test/e2e/cli.jsonOutput.e2e.test.js.map +1 -0
  65. package/dist/test/e2e/cli.loggedWarnings.e2e.test.d.ts +2 -0
  66. package/dist/test/e2e/cli.loggedWarnings.e2e.test.d.ts.map +1 -0
  67. package/dist/test/e2e/cli.loggedWarnings.e2e.test.js +118 -0
  68. package/dist/test/e2e/cli.loggedWarnings.e2e.test.js.map +1 -0
  69. package/dist/test/e2e/cli.secrets.e2e.test.d.ts +2 -0
  70. package/dist/test/e2e/cli.secrets.e2e.test.d.ts.map +1 -0
  71. package/dist/test/e2e/cli.secrets.e2e.test.js +344 -0
  72. package/dist/test/e2e/cli.secrets.e2e.test.js.map +1 -0
  73. package/dist/test/e2e/cli.strict.e2e.test.d.ts +2 -0
  74. package/dist/test/e2e/cli.strict.e2e.test.d.ts.map +1 -0
  75. package/dist/test/e2e/cli.strict.e2e.test.js +76 -0
  76. package/dist/test/e2e/cli.strict.e2e.test.js.map +1 -0
  77. package/dist/test/e2e/cli.uppercaseWarnings.e2e.test.d.ts +2 -0
  78. package/dist/test/e2e/cli.uppercaseWarnings.e2e.test.d.ts.map +1 -0
  79. package/dist/test/e2e/cli.uppercaseWarnings.e2e.test.js +59 -0
  80. package/dist/test/e2e/cli.uppercaseWarnings.e2e.test.js.map +1 -0
  81. package/dist/test/e2e/cli.warningsCount.e2e.test.d.ts +2 -0
  82. package/dist/test/e2e/cli.warningsCount.e2e.test.d.ts.map +1 -0
  83. package/dist/test/e2e/cli.warningsCount.e2e.test.js +54 -0
  84. package/dist/test/e2e/cli.warningsCount.e2e.test.js.map +1 -0
  85. package/dist/test/e2e/frameworks/cli.nextJs.e2e.test.d.ts +2 -0
  86. package/dist/test/e2e/frameworks/cli.nextJs.e2e.test.d.ts.map +1 -0
  87. package/dist/test/e2e/frameworks/cli.nextJs.e2e.test.js +182 -0
  88. package/dist/test/e2e/frameworks/cli.nextJs.e2e.test.js.map +1 -0
  89. package/dist/test/e2e/frameworks/cli.sveltekit.e2e.test.d.ts +2 -0
  90. package/dist/test/e2e/frameworks/cli.sveltekit.e2e.test.d.ts.map +1 -0
  91. package/dist/test/e2e/frameworks/cli.sveltekit.e2e.test.js +333 -0
  92. package/dist/test/e2e/frameworks/cli.sveltekit.e2e.test.js.map +1 -0
  93. package/dist/test/integration/compare-flow.integration.test.d.ts +2 -0
  94. package/dist/test/integration/compare-flow.integration.test.d.ts.map +1 -0
  95. package/dist/test/integration/compare-flow.integration.test.js +26 -0
  96. package/dist/test/integration/compare-flow.integration.test.js.map +1 -0
  97. package/dist/test/unit/cli/program.test.d.ts +2 -0
  98. package/dist/test/unit/cli/program.test.d.ts.map +1 -0
  99. package/dist/test/unit/cli/program.test.js +49 -0
  100. package/dist/test/unit/cli/program.test.js.map +1 -0
  101. package/dist/test/unit/cli/run.test.d.ts +2 -0
  102. package/dist/test/unit/cli/run.test.d.ts.map +1 -0
  103. package/dist/test/unit/cli/run.test.js +331 -0
  104. package/dist/test/unit/cli/run.test.js.map +1 -0
  105. package/dist/test/unit/commands/compare.test.d.ts +2 -0
  106. package/dist/test/unit/commands/compare.test.d.ts.map +1 -0
  107. package/dist/test/unit/commands/compare.test.js +664 -0
  108. package/dist/test/unit/commands/compare.test.js.map +1 -0
  109. package/dist/test/unit/commands/init.test.d.ts +2 -0
  110. package/dist/test/unit/commands/init.test.d.ts.map +1 -0
  111. package/dist/test/unit/commands/init.test.js +54 -0
  112. package/dist/test/unit/commands/init.test.js.map +1 -0
  113. package/dist/test/unit/commands/prompts/promptEnsureFiles.test.d.ts +2 -0
  114. package/dist/test/unit/commands/prompts/promptEnsureFiles.test.d.ts.map +1 -0
  115. package/dist/test/unit/commands/prompts/promptEnsureFiles.test.js +225 -0
  116. package/dist/test/unit/commands/prompts/promptEnsureFiles.test.js.map +1 -0
  117. package/dist/test/unit/commands/prompts/promptNoEnvScenario.test.d.ts +2 -0
  118. package/dist/test/unit/commands/prompts/promptNoEnvScenario.test.d.ts.map +1 -0
  119. package/dist/test/unit/commands/prompts/promptNoEnvScenario.test.js +109 -0
  120. package/dist/test/unit/commands/prompts/promptNoEnvScenario.test.js.map +1 -0
  121. package/dist/test/unit/commands/prompts/prompts.test.d.ts +2 -0
  122. package/dist/test/unit/commands/prompts/prompts.test.d.ts.map +1 -0
  123. package/dist/test/unit/commands/prompts/prompts.test.js +75 -0
  124. package/dist/test/unit/commands/prompts/prompts.test.js.map +1 -0
  125. package/dist/test/unit/commands/scanUsage.test.d.ts +2 -0
  126. package/dist/test/unit/commands/scanUsage.test.d.ts.map +1 -0
  127. package/dist/test/unit/commands/scanUsage.test.js +639 -0
  128. package/dist/test/unit/commands/scanUsage.test.js.map +1 -0
  129. package/dist/test/unit/config/loadConfig.test.d.ts +2 -0
  130. package/dist/test/unit/config/loadConfig.test.d.ts.map +1 -0
  131. package/dist/test/unit/config/loadConfig.test.js +106 -0
  132. package/dist/test/unit/config/loadConfig.test.js.map +1 -0
  133. package/dist/test/unit/config/options.test.d.ts +2 -0
  134. package/dist/test/unit/config/options.test.d.ts.map +1 -0
  135. package/dist/test/unit/config/options.test.js +69 -0
  136. package/dist/test/unit/config/options.test.js.map +1 -0
  137. package/dist/test/unit/core/compare/calculateStats.test.d.ts +2 -0
  138. package/dist/test/unit/core/compare/calculateStats.test.d.ts.map +1 -0
  139. package/dist/test/unit/core/compare/calculateStats.test.js +33 -0
  140. package/dist/test/unit/core/compare/calculateStats.test.js.map +1 -0
  141. package/dist/test/unit/core/compare/parseAndFilterEnv.test.d.ts +2 -0
  142. package/dist/test/unit/core/compare/parseAndFilterEnv.test.d.ts.map +1 -0
  143. package/dist/test/unit/core/compare/parseAndFilterEnv.test.js +227 -0
  144. package/dist/test/unit/core/compare/parseAndFilterEnv.test.js.map +1 -0
  145. package/dist/test/unit/core/compare/updateTotals.test.d.ts +2 -0
  146. package/dist/test/unit/core/compare/updateTotals.test.d.ts.map +1 -0
  147. package/dist/test/unit/core/compare/updateTotals.test.js +106 -0
  148. package/dist/test/unit/core/compare/updateTotals.test.js.map +1 -0
  149. package/dist/test/unit/core/detectInconsistentNaming.test.d.ts +2 -0
  150. package/dist/test/unit/core/detectInconsistentNaming.test.d.ts.map +1 -0
  151. package/dist/test/unit/core/detectInconsistentNaming.test.js +79 -0
  152. package/dist/test/unit/core/detectInconsistentNaming.test.js.map +1 -0
  153. package/dist/test/unit/core/diffEnv.test.d.ts +2 -0
  154. package/dist/test/unit/core/diffEnv.test.d.ts.map +1 -0
  155. package/dist/test/unit/core/diffEnv.test.js +74 -0
  156. package/dist/test/unit/core/diffEnv.test.js.map +1 -0
  157. package/dist/test/unit/core/duplicates.unit.test.d.ts +2 -0
  158. package/dist/test/unit/core/duplicates.unit.test.d.ts.map +1 -0
  159. package/dist/test/unit/core/duplicates.unit.test.js +91 -0
  160. package/dist/test/unit/core/duplicates.unit.test.js.map +1 -0
  161. package/dist/test/unit/core/filterIgnoredKeys.test.d.ts +2 -0
  162. package/dist/test/unit/core/filterIgnoredKeys.test.d.ts.map +1 -0
  163. package/dist/test/unit/core/filterIgnoredKeys.test.js +61 -0
  164. package/dist/test/unit/core/filterIgnoredKeys.test.js.map +1 -0
  165. package/dist/test/unit/core/fixEnv.test.d.ts +2 -0
  166. package/dist/test/unit/core/fixEnv.test.d.ts.map +1 -0
  167. package/dist/test/unit/core/fixEnv.test.js +323 -0
  168. package/dist/test/unit/core/fixEnv.test.js.map +1 -0
  169. package/dist/test/unit/core/frameworks/frameworkDetector.test.d.ts +2 -0
  170. package/dist/test/unit/core/frameworks/frameworkDetector.test.d.ts.map +1 -0
  171. package/dist/test/unit/core/frameworks/frameworkDetector.test.js +44 -0
  172. package/dist/test/unit/core/frameworks/frameworkDetector.test.js.map +1 -0
  173. package/dist/test/unit/core/frameworks/frameworkValidator.test.d.ts +2 -0
  174. package/dist/test/unit/core/frameworks/frameworkValidator.test.d.ts.map +1 -0
  175. package/dist/test/unit/core/frameworks/frameworkValidator.test.js +51 -0
  176. package/dist/test/unit/core/frameworks/frameworkValidator.test.js.map +1 -0
  177. package/dist/test/unit/core/frameworks/nextJsRules.test.d.ts +2 -0
  178. package/dist/test/unit/core/frameworks/nextJsRules.test.d.ts.map +1 -0
  179. package/dist/test/unit/core/frameworks/nextJsRules.test.js +97 -0
  180. package/dist/test/unit/core/frameworks/nextJsRules.test.js.map +1 -0
  181. package/dist/test/unit/core/frameworks/sveltekitRules.test.d.ts +2 -0
  182. package/dist/test/unit/core/frameworks/sveltekitRules.test.d.ts.map +1 -0
  183. package/dist/test/unit/core/frameworks/sveltekitRules.test.js +177 -0
  184. package/dist/test/unit/core/frameworks/sveltekitRules.test.js.map +1 -0
  185. package/dist/test/unit/core/helpers/resolveFromCwd.test.d.ts +2 -0
  186. package/dist/test/unit/core/helpers/resolveFromCwd.test.d.ts.map +1 -0
  187. package/dist/test/unit/core/helpers/resolveFromCwd.test.js +35 -0
  188. package/dist/test/unit/core/helpers/resolveFromCwd.test.js.map +1 -0
  189. package/dist/test/unit/core/helpers/toUpperSnakeCase.test.d.ts +2 -0
  190. package/dist/test/unit/core/helpers/toUpperSnakeCase.test.d.ts.map +1 -0
  191. package/dist/test/unit/core/helpers/toUpperSnakeCase.test.js +47 -0
  192. package/dist/test/unit/core/helpers/toUpperSnakeCase.test.js.map +1 -0
  193. package/dist/test/unit/core/parseEnv.test.d.ts +2 -0
  194. package/dist/test/unit/core/parseEnv.test.d.ts.map +1 -0
  195. package/dist/test/unit/core/parseEnv.test.js +169 -0
  196. package/dist/test/unit/core/parseEnv.test.js.map +1 -0
  197. package/dist/test/unit/core/scan/compareScan.test.d.ts +2 -0
  198. package/dist/test/unit/core/scan/compareScan.test.d.ts.map +1 -0
  199. package/dist/test/unit/core/scan/compareScan.test.js +40 -0
  200. package/dist/test/unit/core/scan/compareScan.test.js.map +1 -0
  201. package/dist/test/unit/core/scan/computeHealthScore.test.d.ts +2 -0
  202. package/dist/test/unit/core/scan/computeHealthScore.test.d.ts.map +1 -0
  203. package/dist/test/unit/core/scan/computeHealthScore.test.js +41 -0
  204. package/dist/test/unit/core/scan/computeHealthScore.test.js.map +1 -0
  205. package/dist/test/unit/core/scan/determineComparisonFile.test.d.ts +2 -0
  206. package/dist/test/unit/core/scan/determineComparisonFile.test.d.ts.map +1 -0
  207. package/dist/test/unit/core/scan/determineComparisonFile.test.js +162 -0
  208. package/dist/test/unit/core/scan/determineComparisonFile.test.js.map +1 -0
  209. package/dist/test/unit/core/scan/patterns.test.d.ts +2 -0
  210. package/dist/test/unit/core/scan/patterns.test.d.ts.map +1 -0
  211. package/dist/test/unit/core/scan/patterns.test.js +483 -0
  212. package/dist/test/unit/core/scan/patterns.test.js.map +1 -0
  213. package/dist/test/unit/core/scan/scanFile.test.d.ts +2 -0
  214. package/dist/test/unit/core/scan/scanFile.test.d.ts.map +1 -0
  215. package/dist/test/unit/core/scan/scanFile.test.js +258 -0
  216. package/dist/test/unit/core/scan/scanFile.test.js.map +1 -0
  217. package/dist/test/unit/core/security/entropy.test.d.ts +2 -0
  218. package/dist/test/unit/core/security/entropy.test.d.ts.map +1 -0
  219. package/dist/test/unit/core/security/entropy.test.js +34 -0
  220. package/dist/test/unit/core/security/entropy.test.js.map +1 -0
  221. package/dist/test/unit/core/security/exampleSecretDetector.test.d.ts +2 -0
  222. package/dist/test/unit/core/security/exampleSecretDetector.test.d.ts.map +1 -0
  223. package/dist/test/unit/core/security/exampleSecretDetector.test.js +57 -0
  224. package/dist/test/unit/core/security/exampleSecretDetector.test.js.map +1 -0
  225. package/dist/test/unit/core/security/secretDetectors.test.d.ts +2 -0
  226. package/dist/test/unit/core/security/secretDetectors.test.d.ts.map +1 -0
  227. package/dist/test/unit/core/security/secretDetectors.test.js +490 -0
  228. package/dist/test/unit/core/security/secretDetectors.test.js.map +1 -0
  229. package/dist/test/unit/index.test.d.ts +2 -0
  230. package/dist/test/unit/index.test.d.ts.map +1 -0
  231. package/dist/test/unit/index.test.js +17 -0
  232. package/dist/test/unit/index.test.js.map +1 -0
  233. package/dist/test/unit/services/detectEnvExpirations.test.d.ts +2 -0
  234. package/dist/test/unit/services/detectEnvExpirations.test.d.ts.map +1 -0
  235. package/dist/test/unit/services/detectEnvExpirations.test.js +120 -0
  236. package/dist/test/unit/services/detectEnvExpirations.test.js.map +1 -0
  237. package/dist/test/unit/services/envDiscovery.test.d.ts +2 -0
  238. package/dist/test/unit/services/envDiscovery.test.d.ts.map +1 -0
  239. package/dist/test/unit/services/envDiscovery.test.js +177 -0
  240. package/dist/test/unit/services/envDiscovery.test.js.map +1 -0
  241. package/dist/test/unit/services/envPairing.test.d.ts +2 -0
  242. package/dist/test/unit/services/envPairing.test.d.ts.map +1 -0
  243. package/dist/test/unit/services/envPairing.test.js +103 -0
  244. package/dist/test/unit/services/envPairing.test.js.map +1 -0
  245. package/dist/test/unit/services/filewalker.test.d.ts +2 -0
  246. package/dist/test/unit/services/filewalker.test.d.ts.map +1 -0
  247. package/dist/test/unit/services/filewalker.test.js +422 -0
  248. package/dist/test/unit/services/filewalker.test.js.map +1 -0
  249. package/dist/test/unit/services/git.test.d.ts +2 -0
  250. package/dist/test/unit/services/git.test.d.ts.map +1 -0
  251. package/dist/test/unit/services/git.test.js +357 -0
  252. package/dist/test/unit/services/git.test.js.map +1 -0
  253. package/dist/test/unit/services/printScanResult.test.d.ts +2 -0
  254. package/dist/test/unit/services/printScanResult.test.d.ts.map +1 -0
  255. package/dist/test/unit/services/printScanResult.test.js +275 -0
  256. package/dist/test/unit/services/printScanResult.test.js.map +1 -0
  257. package/dist/test/unit/services/processComparisonFile.test.d.ts +2 -0
  258. package/dist/test/unit/services/processComparisonFile.test.d.ts.map +1 -0
  259. package/dist/test/unit/services/processComparisonFile.test.js +261 -0
  260. package/dist/test/unit/services/processComparisonFile.test.js.map +1 -0
  261. package/dist/test/unit/services/scanCodebase.test.d.ts +2 -0
  262. package/dist/test/unit/services/scanCodebase.test.d.ts.map +1 -0
  263. package/dist/test/unit/services/scanCodebase.test.js +433 -0
  264. package/dist/test/unit/services/scanCodebase.test.js.map +1 -0
  265. package/dist/test/unit/ui/compare/compareJsonOutput.test.d.ts +2 -0
  266. package/dist/test/unit/ui/compare/compareJsonOutput.test.d.ts.map +1 -0
  267. package/dist/test/unit/ui/compare/compareJsonOutput.test.js +137 -0
  268. package/dist/test/unit/ui/compare/compareJsonOutput.test.js.map +1 -0
  269. package/dist/test/unit/ui/compare/printErrorNotFound.test.d.ts +2 -0
  270. package/dist/test/unit/ui/compare/printErrorNotFound.test.d.ts.map +1 -0
  271. package/dist/test/unit/ui/compare/printErrorNotFound.test.js +36 -0
  272. package/dist/test/unit/ui/compare/printErrorNotFound.test.js.map +1 -0
  273. package/dist/test/unit/ui/compare/printHeader.test.d.ts +2 -0
  274. package/dist/test/unit/ui/compare/printHeader.test.d.ts.map +1 -0
  275. package/dist/test/unit/ui/compare/printHeader.test.js +23 -0
  276. package/dist/test/unit/ui/compare/printHeader.test.js.map +1 -0
  277. package/dist/test/unit/ui/compare/printIssues.test.d.ts +2 -0
  278. package/dist/test/unit/ui/compare/printIssues.test.d.ts.map +1 -0
  279. package/dist/test/unit/ui/compare/printIssues.test.js +69 -0
  280. package/dist/test/unit/ui/compare/printIssues.test.js.map +1 -0
  281. package/dist/test/unit/ui/compare/printPrompt.test.d.ts +2 -0
  282. package/dist/test/unit/ui/compare/printPrompt.test.d.ts.map +1 -0
  283. package/dist/test/unit/ui/compare/printPrompt.test.js +40 -0
  284. package/dist/test/unit/ui/compare/printPrompt.test.js.map +1 -0
  285. package/dist/test/unit/ui/compare/printStats.test.d.ts +2 -0
  286. package/dist/test/unit/ui/compare/printStats.test.d.ts.map +1 -0
  287. package/dist/test/unit/ui/compare/printStats.test.js +52 -0
  288. package/dist/test/unit/ui/compare/printStats.test.js.map +1 -0
  289. package/dist/test/unit/ui/scan/printComparisonError.test.d.ts +2 -0
  290. package/dist/test/unit/ui/scan/printComparisonError.test.d.ts.map +1 -0
  291. package/dist/test/unit/ui/scan/printComparisonError.test.js +28 -0
  292. package/dist/test/unit/ui/scan/printComparisonError.test.js.map +1 -0
  293. package/dist/test/unit/ui/scan/printConsolelogWarning.test.d.ts +2 -0
  294. package/dist/test/unit/ui/scan/printConsolelogWarning.test.d.ts.map +1 -0
  295. package/dist/test/unit/ui/scan/printConsolelogWarning.test.js +118 -0
  296. package/dist/test/unit/ui/scan/printConsolelogWarning.test.js.map +1 -0
  297. package/dist/test/unit/ui/scan/printExampleWarnings.test.d.ts +2 -0
  298. package/dist/test/unit/ui/scan/printExampleWarnings.test.d.ts.map +1 -0
  299. package/dist/test/unit/ui/scan/printExampleWarnings.test.js +63 -0
  300. package/dist/test/unit/ui/scan/printExampleWarnings.test.js.map +1 -0
  301. package/dist/test/unit/ui/scan/printExpireWarnings.test.d.ts +2 -0
  302. package/dist/test/unit/ui/scan/printExpireWarnings.test.d.ts.map +1 -0
  303. package/dist/test/unit/ui/scan/printExpireWarnings.test.js +100 -0
  304. package/dist/test/unit/ui/scan/printExpireWarnings.test.js.map +1 -0
  305. package/dist/test/unit/ui/scan/printFrameworkWarnings.test.d.ts +2 -0
  306. package/dist/test/unit/ui/scan/printFrameworkWarnings.test.d.ts.map +1 -0
  307. package/dist/test/unit/ui/scan/printFrameworkWarnings.test.js +95 -0
  308. package/dist/test/unit/ui/scan/printFrameworkWarnings.test.js.map +1 -0
  309. package/dist/test/unit/ui/scan/printHeader.test.d.ts +2 -0
  310. package/dist/test/unit/ui/scan/printHeader.test.d.ts.map +1 -0
  311. package/dist/test/unit/ui/scan/printHeader.test.js +23 -0
  312. package/dist/test/unit/ui/scan/printHeader.test.js.map +1 -0
  313. package/dist/test/unit/ui/scan/printHealthScore.test.d.ts +2 -0
  314. package/dist/test/unit/ui/scan/printHealthScore.test.d.ts.map +1 -0
  315. package/dist/test/unit/ui/scan/printHealthScore.test.js +44 -0
  316. package/dist/test/unit/ui/scan/printHealthScore.test.js.map +1 -0
  317. package/dist/test/unit/ui/scan/printInconsistentNamingWarning.test.d.ts +2 -0
  318. package/dist/test/unit/ui/scan/printInconsistentNamingWarning.test.d.ts.map +1 -0
  319. package/dist/test/unit/ui/scan/printInconsistentNamingWarning.test.js +55 -0
  320. package/dist/test/unit/ui/scan/printInconsistentNamingWarning.test.js.map +1 -0
  321. package/dist/test/unit/ui/scan/printMissing.test.d.ts +2 -0
  322. package/dist/test/unit/ui/scan/printMissing.test.d.ts.map +1 -0
  323. package/dist/test/unit/ui/scan/printMissing.test.js +71 -0
  324. package/dist/test/unit/ui/scan/printMissing.test.js.map +1 -0
  325. package/dist/test/unit/ui/scan/printMissingExample.test.d.ts +2 -0
  326. package/dist/test/unit/ui/scan/printMissingExample.test.d.ts.map +1 -0
  327. package/dist/test/unit/ui/scan/printMissingExample.test.js +77 -0
  328. package/dist/test/unit/ui/scan/printMissingExample.test.js.map +1 -0
  329. package/dist/test/unit/ui/scan/printSecrets.test.d.ts +2 -0
  330. package/dist/test/unit/ui/scan/printSecrets.test.d.ts.map +1 -0
  331. package/dist/test/unit/ui/scan/printSecrets.test.js +108 -0
  332. package/dist/test/unit/ui/scan/printSecrets.test.js.map +1 -0
  333. package/dist/test/unit/ui/scan/printStats.test.d.ts +2 -0
  334. package/dist/test/unit/ui/scan/printStats.test.d.ts.map +1 -0
  335. package/dist/test/unit/ui/scan/printStats.test.js +42 -0
  336. package/dist/test/unit/ui/scan/printStats.test.js.map +1 -0
  337. package/dist/test/unit/ui/scan/printUnused.test.d.ts +2 -0
  338. package/dist/test/unit/ui/scan/printUnused.test.d.ts.map +1 -0
  339. package/dist/test/unit/ui/scan/printUnused.test.js +35 -0
  340. package/dist/test/unit/ui/scan/printUnused.test.js.map +1 -0
  341. package/dist/test/unit/ui/scan/printUppercaseWarning.test.d.ts +2 -0
  342. package/dist/test/unit/ui/scan/printUppercaseWarning.test.d.ts.map +1 -0
  343. package/dist/test/unit/ui/scan/printUppercaseWarning.test.js +44 -0
  344. package/dist/test/unit/ui/scan/printUppercaseWarning.test.js.map +1 -0
  345. package/dist/test/unit/ui/scan/scanJsonOutput.test.d.ts +2 -0
  346. package/dist/test/unit/ui/scan/scanJsonOutput.test.d.ts.map +1 -0
  347. package/dist/test/unit/ui/scan/scanJsonOutput.test.js +270 -0
  348. package/dist/test/unit/ui/scan/scanJsonOutput.test.js.map +1 -0
  349. package/dist/test/unit/ui/shared/printAutoFix.test.d.ts +2 -0
  350. package/dist/test/unit/ui/shared/printAutoFix.test.d.ts.map +1 -0
  351. package/dist/test/unit/ui/shared/printAutoFix.test.js +54 -0
  352. package/dist/test/unit/ui/shared/printAutoFix.test.js.map +1 -0
  353. package/dist/test/unit/ui/shared/printConfigStatus.test.d.ts +2 -0
  354. package/dist/test/unit/ui/shared/printConfigStatus.test.d.ts.map +1 -0
  355. package/dist/test/unit/ui/shared/printConfigStatus.test.js +44 -0
  356. package/dist/test/unit/ui/shared/printConfigStatus.test.js.map +1 -0
  357. package/dist/test/unit/ui/shared/printDuplicates.test.d.ts +2 -0
  358. package/dist/test/unit/ui/shared/printDuplicates.test.d.ts.map +1 -0
  359. package/dist/test/unit/ui/shared/printDuplicates.test.js +43 -0
  360. package/dist/test/unit/ui/shared/printDuplicates.test.js.map +1 -0
  361. package/dist/test/unit/ui/shared/printFixTips.test.d.ts +2 -0
  362. package/dist/test/unit/ui/shared/printFixTips.test.d.ts.map +1 -0
  363. package/dist/test/unit/ui/shared/printFixTips.test.js +67 -0
  364. package/dist/test/unit/ui/shared/printFixTips.test.js.map +1 -0
  365. package/dist/test/unit/ui/shared/printGitignore.test.d.ts +2 -0
  366. package/dist/test/unit/ui/shared/printGitignore.test.d.ts.map +1 -0
  367. package/dist/test/unit/ui/shared/printGitignore.test.js +59 -0
  368. package/dist/test/unit/ui/shared/printGitignore.test.js.map +1 -0
  369. package/dist/test/unit/ui/shared/printInitStatus.test.d.ts +2 -0
  370. package/dist/test/unit/ui/shared/printInitStatus.test.d.ts.map +1 -0
  371. package/dist/test/unit/ui/shared/printInitStatus.test.js +43 -0
  372. package/dist/test/unit/ui/shared/printInitStatus.test.js.map +1 -0
  373. package/dist/test/unit/ui/shared/printOptionErrors.test.d.ts +2 -0
  374. package/dist/test/unit/ui/shared/printOptionErrors.test.d.ts.map +1 -0
  375. package/dist/test/unit/ui/shared/printOptionErrors.test.js +57 -0
  376. package/dist/test/unit/ui/shared/printOptionErrors.test.js.map +1 -0
  377. package/dist/test/unit/ui/shared/setupGlobalConfig.test.d.ts +2 -0
  378. package/dist/test/unit/ui/shared/setupGlobalConfig.test.d.ts.map +1 -0
  379. package/dist/test/unit/ui/shared/setupGlobalConfig.test.js +27 -0
  380. package/dist/test/unit/ui/shared/setupGlobalConfig.test.js.map +1 -0
  381. package/dist/test/unit/ui/theme.test.d.ts +2 -0
  382. package/dist/test/unit/ui/theme.test.d.ts.map +1 -0
  383. package/dist/test/unit/ui/theme.test.js +61 -0
  384. package/dist/test/unit/ui/theme.test.js.map +1 -0
  385. package/dist/test/utils/cli-helpers.d.ts +27 -0
  386. package/dist/test/utils/cli-helpers.d.ts.map +1 -0
  387. package/dist/test/utils/cli-helpers.js +46 -0
  388. package/dist/test/utils/cli-helpers.js.map +1 -0
  389. package/dist/test/utils/fs-helpers.d.ts +20 -0
  390. package/dist/test/utils/fs-helpers.d.ts.map +1 -0
  391. package/dist/test/utils/fs-helpers.js +30 -0
  392. package/dist/test/utils/fs-helpers.js.map +1 -0
  393. package/package.json +3 -1
@@ -0,0 +1,344 @@
1
+ import { describe, it, expect, beforeAll, afterAll, afterEach } from 'vitest';
2
+ import fs from 'fs';
3
+ import path from 'path';
4
+ import { makeTmpDir, rmrf } from '../utils/fs-helpers.js';
5
+ import { buildOnce, runCli, cleanupBuild } from '../utils/cli-helpers.js';
6
+ const tmpDirs = [];
7
+ beforeAll(() => {
8
+ buildOnce();
9
+ });
10
+ afterAll(() => {
11
+ cleanupBuild();
12
+ });
13
+ afterEach(() => {
14
+ while (tmpDirs.length) {
15
+ const dir = tmpDirs.pop();
16
+ if (dir)
17
+ rmrf(dir);
18
+ }
19
+ });
20
+ function tmpDir() {
21
+ const dir = makeTmpDir();
22
+ tmpDirs.push(dir);
23
+ return dir;
24
+ }
25
+ describe('secrets detection (default scan mode)', () => {
26
+ it('warns on provider-like tokens and high-entropy literals (no CI break)', () => {
27
+ const cwd = tmpDir();
28
+ fs.writeFileSync(path.join(cwd, '.env'), 'API_KEY=\nNEW_API_KEY=\n');
29
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
30
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
31
+ // kendt mønster: GitHub PAT
32
+ const gh = "ghp_1234567890ABCDEFGHijklmnopqrstuvwxYZ";
33
+
34
+ // høj entropi & lang literal
35
+ const password = "3fg400asipkfoemkfmojwpajwmdklaosjfiop";
36
+
37
+ // lidt brug af env så stats/scan virker
38
+ console.log(process.env.API_KEY, process.env.NEW_API_KEY);
39
+ `.trimStart());
40
+ const local = runCli(cwd, []);
41
+ expect(local.status).toBe(1);
42
+ expect(local.stdout).toContain('▸ Potential secrets detected');
43
+ expect(local.stdout).toMatch(/src[\/\\]index\.ts/);
44
+ const ci = runCli(cwd, ['--ci']);
45
+ expect(ci.status).toBe(1);
46
+ expect(ci.stdout).toContain('▸ Potential secrets detected');
47
+ });
48
+ it('does not warn when no secrets are present', () => {
49
+ const cwd = tmpDir();
50
+ fs.writeFileSync(path.join(cwd, '.env'), 'A=\n');
51
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
52
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
53
+ // helt harmløst
54
+ const a = "hello";
55
+ console.log(a);
56
+ `.trimStart());
57
+ const res = runCli(cwd, []);
58
+ expect(res.status).toBe(0);
59
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
60
+ });
61
+ it('does not warn on process.env and import.meta.env usage', () => {
62
+ const cwd = tmpDir();
63
+ fs.writeFileSync(path.join(cwd, '.env'), 'USER_API=\nVITE_KEYCLOAK_URL=\n');
64
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
65
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
66
+ // Skal ikke flagges som secrets
67
+ const apiUrl = '${'process.env.USER_API'}/users/${'userId'}/reset-password';
68
+ const tokenEndpoint = '${'import.meta.env.VITE_KEYCLOAK_URL'}/token';
69
+
70
+ console.log(apiUrl, tokenEndpoint);
71
+ `.trimStart());
72
+ const res = runCli(cwd, []);
73
+ expect(res.status).toBe(0);
74
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
75
+ });
76
+ it('does not warn on URL construction patterns with auth keywords', () => {
77
+ const cwd = tmpDir();
78
+ fs.writeFileSync(path.join(cwd, '.env'), 'KEYCLOAK_BASE=\nREALM=\n');
79
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
80
+ fs.writeFileSync(path.join(cwd, 'src', 'auth.ts'), `
81
+ // These should NOT be flagged as secrets - they're URL constructions
82
+ window.location.href = \`\${baseURL}auth/login\`;
83
+
84
+ const authUrl = \`\${keycloakBase}/realms/\${realm}/protocol/openid-connect/auth?client_id=test\`;
85
+ const tokenUrl = \`\${keycloakBase}/realms/\${realm}/protocol/openid-connect/token\`;
86
+ const authUrl = \`\${keycloakBase}/realms/\${realm}/protocol/openid-connect/auth?response_type=code&client_id=\${clientId}\`;
87
+ const logoutUrl = \`\${keycloakBase}/realms/\${realm}/protocol/openid-connect/logout\`;
88
+
89
+ const UUID = '123e4567-e89b-12d3-a456-426614174000'; // should not be flagged
90
+
91
+ const SHA256Hash = '3f79bb7b435b05321651daefd374cd21b4f2d3a0a4f1e5e6e7f8a9b0c1d2e3f4'; // should not be flagged
92
+
93
+ console.log(authUrl, redirectUrl, apiEndpoint);
94
+ `.trimStart());
95
+ const res = runCli(cwd, []);
96
+ expect(res.status).toBe(0);
97
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
98
+ });
99
+ it('still warns on actual secrets with auth keywords', () => {
100
+ const cwd = tmpDir();
101
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
102
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
103
+ fs.writeFileSync(path.join(cwd, 'src', 'secrets.ts'), `
104
+ // These SHOULD be flagged as potential secrets
105
+ const auth_token = "sk_live_abcxyz123456";
106
+ const api_key = "AKIA1234567890ABCDEF";
107
+ const client_secret = "very_secret_key_that_should_be_flagged_123";
108
+
109
+ // But this URL should NOT be flagged
110
+ const loginUrl = \`\${baseUrl}/auth/login\`;
111
+
112
+ console.log(process.env.DUMMY);
113
+ `.trimStart());
114
+ const res = runCli(cwd, []);
115
+ expect(res.status).toBe(1);
116
+ expect(res.stdout).toContain('▸ Potential secrets detected');
117
+ expect(res.stdout).toMatch(/src[\/\\]secrets\.ts/);
118
+ });
119
+ it('should not give warning on http://localhost*', () => {
120
+ const cwd = tmpDir();
121
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
122
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
123
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
124
+ const service = 'http://localhost:3000';
125
+ const service2 = "http://localhost/api";
126
+ const service3 = \`http://localhost:8080/path\`;
127
+
128
+ console.log(service, service2, service3);
129
+ `.trimStart());
130
+ const res = runCli(cwd, []);
131
+ expect(res.status).toBe(0);
132
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
133
+ });
134
+ it('should not give warning on localhost URLs in .env files', () => {
135
+ const cwd = tmpDir();
136
+ fs.writeFileSync(path.join(cwd, '.env'), `
137
+ DUMMY=
138
+ LOCAL_URL=http://localhost:3000
139
+ ANOTHER_URL=http://localhost/api
140
+ TEMPLATE_URL=http://localhost:8080/path
141
+ `.trimStart());
142
+ fs.writeFileSync(path.join(cwd, '.env.example'), `
143
+ DUMMY=
144
+ LOCAL_URL=http://localhost:3000
145
+ ANOTHER_URL=http://localhost/api
146
+ TEMPLATE_URL=http://localhost:8080/path
147
+ `.trimStart());
148
+ fs.writeFileSync(path.join(cwd, '.env.test'), `
149
+ DUMMY=
150
+ LOCAL_URL=http://localhost:3000
151
+ ANOTHER_URL=http://localhost/api
152
+ TEMPLATE_URL=http://localhost:8080/path
153
+ `.trimStart());
154
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
155
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
156
+ // lidt brug af env så stats/scan virker
157
+ console.log(process.env.DUMMY);
158
+ `.trimStart());
159
+ const res = runCli(cwd, []);
160
+ expect(res.status).toBe(0);
161
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
162
+ });
163
+ it('should not give warning on base64 ', () => {
164
+ const cwd = tmpDir();
165
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
166
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
167
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
168
+ // Base64 encoded string - should not be flagged
169
+ const encoded = "SGVsbG8gV29ybGQh"; // "Hello World!" in Base64
170
+
171
+ console.log(encoded);
172
+ `.trimStart());
173
+ const res = runCli(cwd, []);
174
+ expect(res.status).toBe(0);
175
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
176
+ });
177
+ it('should not give warning on SVG content', () => {
178
+ const cwd = tmpDir();
179
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
180
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
181
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
182
+ // SVG content - should not be flagged
183
+ const svgIcon = '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="40" stroke="black" stroke-width="3" fill="red" /></svg>';
184
+
185
+ console.log(svgIcon);
186
+ `.trimStart());
187
+ const res = runCli(cwd, []);
188
+ expect(res.status).toBe(0);
189
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
190
+ });
191
+ it('should ignore https://placerholder.com/ URLs', () => {
192
+ const cwd = tmpDir();
193
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
194
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
195
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
196
+ const placeholder1 = 'https://placeholder.com';
197
+ const placeholder2 = "https://placeholder.com/150";
198
+ const placeholder3 = \`http://placeholder.com/100x100\`;
199
+
200
+ console.log(placeholder1, placeholder2, placeholder3);
201
+ `.trimStart());
202
+ const res = runCli(cwd, []);
203
+ expect(res.status).toBe(0);
204
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
205
+ });
206
+ it('does not warn on UI tracking attributes containing auth keywords', () => {
207
+ const cwd = tmpDir();
208
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
209
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
210
+ fs.writeFileSync(path.join(cwd, 'src', 'page.svelte'), `
211
+ <script>
212
+ const trackingId = "users-reset-password-button";
213
+ const trackingContext = "users-reset-password-confirmation-modal";
214
+ </script>
215
+
216
+ <button
217
+ trackingId="users-reset-password-button"
218
+ trackingContext="users-reset-password-confirmation-modal"
219
+ >
220
+ Reset password
221
+ </button>
222
+ `.trimStart());
223
+ const res = runCli(cwd, []);
224
+ expect(res.status).toBe(0);
225
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
226
+ });
227
+ it('Will handle cross-platform / different path styles', () => {
228
+ const cwd = tmpDir();
229
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
230
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
231
+ const filePath = path.join(cwd, 'src', 'crossPlatform.ts');
232
+ fs.writeFileSync(filePath, `
233
+ // kendt mønster: GitHub PAT
234
+ const gh = "ghp_1234567890ABCDEFGHijklmnopqrstuvwxYZ";
235
+
236
+ console.log(process.env.DUMMY);
237
+ `.trimStart());
238
+ const res = runCli(cwd, []);
239
+ expect(res.status).toBe(1);
240
+ expect(res.stdout).toContain('▸ Potential secrets detected');
241
+ expect(res.stdout).toContain('src/crossPlatform.ts');
242
+ });
243
+ it('Will not give false positives on HTML text nodes', () => {
244
+ const cwd = tmpDir();
245
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
246
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
247
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
248
+ const htmlContent = \`
249
+ <div>
250
+ <p>This is a sample HTML content with no secrets.</p>
251
+ <h2 class="mb-3 text-xl">6. Private variables must only be used in server files</h2>
252
+ </div>
253
+ \`;
254
+
255
+ console.log(htmlContent);
256
+ `.trimStart());
257
+ const res = runCli(cwd, []);
258
+ expect(res.status).toBe(0);
259
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
260
+ });
261
+ it('should respect inline ignore comments', () => {
262
+ const cwd = tmpDir();
263
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
264
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
265
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
266
+ // This should be ignored
267
+ const secret = "AKIA1234567890ABCDEF"; // dotenv-diff-ignore
268
+
269
+ /* This should also be ignored */
270
+ const token = "ghp_1234567890ABCDEFGHijklmnopqrstuvwxYZ"; /* dotenv-diff-ignore */
271
+
272
+ // This should NOT be ignored
273
+ const realSecret = "AKIAXXXXXXXXXXX12345";
274
+
275
+ console.log(process.env.DUMMY);
276
+ `.trimStart());
277
+ const res = runCli(cwd, []);
278
+ expect(res.status).toBe(1);
279
+ expect(res.stdout).toContain('▸ Potential secrets detected');
280
+ });
281
+ it('should respect ignore block comments', () => {
282
+ const cwd = tmpDir();
283
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
284
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
285
+ fs.writeFileSync(path.join(cwd, 'src', 'config.ts'), `
286
+ const beforeBlock = "AKIA1234567890BEFORE";
287
+
288
+ <!-- dotenv-diff-ignore-start -->
289
+ const ignored1 = "AKIA1234567890ABCDEF";
290
+ const ignored2 = "ghp_1234567890ABCDEFGHijklmnopqrstuvwxYZ";
291
+ const ignored3 = "sk_live_1234567890abcdefghij";
292
+ <!-- dotenv-diff-ignore-end -->
293
+
294
+ const afterBlock = "AKIA1234567890AFTER1";
295
+
296
+ console.log(process.env.DUMMY);
297
+ `.trimStart());
298
+ const res = runCli(cwd, []);
299
+ expect(res.status).toBe(1);
300
+ expect(res.stdout).toContain('▸ Potential secrets detected');
301
+ expect(res.stdout).not.toContain('ignored1');
302
+ expect(res.stdout).not.toContain('ignored2');
303
+ expect(res.stdout).not.toContain('ignored3');
304
+ });
305
+ it('should not warn on pure interpolation templates', () => {
306
+ const cwd = tmpDir();
307
+ fs.writeFileSync(path.join(cwd, '.env'), 'DUMMY=\n');
308
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
309
+ fs.writeFileSync(path.join(cwd, 'src', 'index.ts'), `
310
+ // These are pure interpolations - should NOT be flagged
311
+ const token = \`\${apiKey}\`;
312
+ const authHeader = \`\${tokenType}:\${accessToken}\`;
313
+ const combined = \`\${part1}|\${part2}|\${part3}\`;
314
+ const password = \`\${user}_\${pass}\`;
315
+
316
+ console.log(token, authHeader);
317
+ `.trimStart());
318
+ const res = runCli(cwd, []);
319
+ expect(res.status).toBe(0);
320
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
321
+ });
322
+ it('should not warn on SvelteKit $env accessors', () => {
323
+ const cwd = tmpDir();
324
+ fs.writeFileSync(path.join(cwd, '.env'), 'API_KEY=\nPRIVATE_KEY=\nVITE_KEY=\nPUBLIC_URL=\n');
325
+ fs.mkdirSync(path.join(cwd, 'src'), { recursive: true });
326
+ fs.writeFileSync(path.join(cwd, 'src', '+page.server.ts'), `
327
+ import { API_KEY } from '$env/static/private';
328
+ import { PUBLIC_URL } from '$env/static/public';
329
+ import { env } from '$env/dynamic/private';
330
+
331
+ // These should NOT be flagged - they're using env accessors
332
+ const key1 = process.env.API_KEY;
333
+ const key2 = import.meta.env.VITE_KEY;
334
+ const key3 = env.PRIVATE_KEY;
335
+
336
+ console.log(API_KEY, PUBLIC_URL, key1, key2, key3);
337
+ `.trimStart());
338
+ const res = runCli(cwd, []);
339
+ console.log(res.stdout);
340
+ expect(res.status).toBe(0);
341
+ expect(res.stdout).not.toContain('▸ Potential secrets detected');
342
+ });
343
+ });
344
+ //# sourceMappingURL=cli.secrets.e2e.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.secrets.e2e.test.js","sourceRoot":"","sources":["../../../test/e2e/cli.secrets.e2e.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cli.strict.e2e.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.strict.e2e.test.d.ts","sourceRoot":"","sources":["../../../test/e2e/cli.strict.e2e.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,76 @@
1
+ import { describe, it, expect, beforeAll, afterAll, afterEach } from 'vitest';
2
+ import fs from 'fs';
3
+ import path from 'path';
4
+ import { makeTmpDir, rmrf } from '../utils/fs-helpers.js';
5
+ import { buildOnce, runCli, cleanupBuild } from '../utils/cli-helpers.js';
6
+ const tmpDirs = [];
7
+ beforeAll(() => {
8
+ buildOnce();
9
+ });
10
+ afterAll(() => {
11
+ cleanupBuild();
12
+ });
13
+ afterEach(() => {
14
+ while (tmpDirs.length) {
15
+ const dir = tmpDirs.pop();
16
+ if (dir)
17
+ rmrf(dir);
18
+ }
19
+ });
20
+ function tmpDir() {
21
+ const dir = makeTmpDir();
22
+ tmpDirs.push(dir);
23
+ return dir;
24
+ }
25
+ describe('--strict mode', () => {
26
+ it('fails on unused variables', () => {
27
+ const cwd = tmpDir();
28
+ fs.writeFileSync(path.join(cwd, '.env'), 'UNUSED=1\n');
29
+ fs.writeFileSync(path.join(cwd, '.env.example'), ''); // no usages
30
+ const res = runCli(cwd, ['--strict']);
31
+ expect(res.status).toBe(1);
32
+ expect(res.stdout).toContain('▸ Unused in .env');
33
+ });
34
+ it('fails on duplicate variables in .env', () => {
35
+ const cwd = tmpDir();
36
+ fs.writeFileSync(path.join(cwd, '.env'), 'FOO=1\nFOO=2\n');
37
+ fs.writeFileSync(path.join(cwd, '.env.example'), 'FOO=\n');
38
+ const res = runCli(cwd, ['--strict']);
39
+ expect(res.status).toBe(1);
40
+ expect(res.stdout).toContain('Duplicate keys');
41
+ });
42
+ it('fails on duplicate variables in .env.example', () => {
43
+ const cwd = tmpDir();
44
+ fs.writeFileSync(path.join(cwd, '.env'), 'FOO=1\n');
45
+ fs.writeFileSync(path.join(cwd, '.env.example'), 'FOO=\nFOO=\n');
46
+ const res = runCli(cwd, ['--strict', '--example', '.env.example']);
47
+ expect(res.status).toBe(1);
48
+ expect(res.stdout).toContain('Duplicate keys in .env.example');
49
+ });
50
+ it('succeeds when there are no warnings', () => {
51
+ const cwd = tmpDir();
52
+ fs.writeFileSync(path.join(cwd, '.env'), '');
53
+ fs.writeFileSync(path.join(cwd, '.gitignore'), '.env');
54
+ const res = runCli(cwd, ['--strict']);
55
+ expect(res.status).toBe(0);
56
+ });
57
+ });
58
+ describe('--strict mode with --compare', () => {
59
+ it('warns on duplicate variables in .env', () => {
60
+ const cwd = tmpDir();
61
+ fs.writeFileSync(path.join(cwd, '.env'), 'FOO=1\nFOO=2\n');
62
+ fs.writeFileSync(path.join(cwd, '.env.example'), 'FOO=\n');
63
+ const res = runCli(cwd, ['--strict', '--compare']);
64
+ expect(res.status).toBe(0);
65
+ expect(res.stdout).toContain('Duplicate keys');
66
+ });
67
+ it('warns on duplicate variables in .env.example', () => {
68
+ const cwd = tmpDir();
69
+ fs.writeFileSync(path.join(cwd, '.env'), 'FOO=1\n');
70
+ fs.writeFileSync(path.join(cwd, '.env.example'), 'FOO=\nFOO=\n');
71
+ const res = runCli(cwd, ['--strict', '--compare']);
72
+ expect(res.status).toBe(0);
73
+ expect(res.stdout).toContain('Duplicate keys in .env.example');
74
+ });
75
+ });
76
+ //# sourceMappingURL=cli.strict.e2e.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.strict.e2e.test.js","sourceRoot":"","sources":["../../../test/e2e/cli.strict.e2e.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cli.uppercaseWarnings.e2e.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.uppercaseWarnings.e2e.test.d.ts","sourceRoot":"","sources":["../../../test/e2e/cli.uppercaseWarnings.e2e.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,59 @@
1
+ import { describe, it, expect, beforeAll, afterAll, afterEach } from 'vitest';
2
+ import fs from 'fs';
3
+ import path from 'path';
4
+ import { makeTmpDir, rmrf } from '../utils/fs-helpers.js';
5
+ import { buildOnce, runCli, cleanupBuild } from '../utils/cli-helpers.js';
6
+ const tmpDirs = [];
7
+ beforeAll(() => {
8
+ buildOnce();
9
+ });
10
+ afterAll(() => {
11
+ cleanupBuild();
12
+ });
13
+ afterEach(() => {
14
+ while (tmpDirs.length) {
15
+ const dir = tmpDirs.pop();
16
+ if (dir)
17
+ rmrf(dir);
18
+ }
19
+ });
20
+ function tmpDir() {
21
+ const dir = makeTmpDir();
22
+ tmpDirs.push(dir);
23
+ return dir;
24
+ }
25
+ describe('Uppercase Warnings', () => {
26
+ it('warns when env variable names are not uppercase', () => {
27
+ const cwd = tmpDir();
28
+ fs.writeFileSync(path.join(cwd, '.env'), `api_key=123`);
29
+ const res = runCli(cwd, []);
30
+ expect(res.status).toBe(0);
31
+ expect(res.stdout).toContain('▸ Uppercase warnings (.env)');
32
+ expect(res.stdout).toContain('api_key');
33
+ expect(res.stdout).toContain('API_KEY');
34
+ });
35
+ it('does not warn when variable key is already uppercase', () => {
36
+ const cwd = tmpDir();
37
+ fs.writeFileSync(path.join(cwd, '.env'), `API_KEY=123`);
38
+ const res = runCli(cwd, []);
39
+ expect(res.status).toBe(0);
40
+ expect(res.stdout).not.toContain('▸ Uppercase warnings (.env)');
41
+ });
42
+ it('exits with error in strict mode when non-uppercase env vars are used', () => {
43
+ const cwd = tmpDir();
44
+ fs.writeFileSync(path.join(cwd, '.env'), `api_key=123`);
45
+ const res = runCli(cwd, ['--strict']);
46
+ expect(res.status).toBe(1);
47
+ expect(res.stdout).toContain('▸ Uppercase warnings (.env)');
48
+ expect(res.stdout).toContain('api_key');
49
+ expect(res.stdout).toContain('API_KEY');
50
+ });
51
+ it('does not warn about uppercase when --no-uppercase-keys is not enabled', () => {
52
+ const cwd = tmpDir();
53
+ fs.writeFileSync(path.join(cwd, '.env'), `api_key=123`);
54
+ const res = runCli(cwd, ['--no-uppercase-keys']);
55
+ expect(res.status).toBe(0);
56
+ expect(res.stdout).not.toContain('▸ Uppercase warnings (.env)');
57
+ });
58
+ });
59
+ //# sourceMappingURL=cli.uppercaseWarnings.e2e.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.uppercaseWarnings.e2e.test.js","sourceRoot":"","sources":["../../../test/e2e/cli.uppercaseWarnings.e2e.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cli.warningsCount.e2e.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.warningsCount.e2e.test.d.ts","sourceRoot":"","sources":["../../../test/e2e/cli.warningsCount.e2e.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,54 @@
1
+ import { describe, it, expect, beforeAll, afterAll, afterEach } from 'vitest';
2
+ import fs from 'fs';
3
+ import path from 'path';
4
+ import { makeTmpDir, rmrf } from '../utils/fs-helpers.js';
5
+ import { buildOnce, runCli, cleanupBuild } from '../utils/cli-helpers.js';
6
+ const tmpDirs = [];
7
+ beforeAll(() => {
8
+ buildOnce();
9
+ });
10
+ afterAll(() => {
11
+ cleanupBuild();
12
+ });
13
+ afterEach(() => {
14
+ while (tmpDirs.length) {
15
+ const dir = tmpDirs.pop();
16
+ if (dir)
17
+ rmrf(dir);
18
+ }
19
+ });
20
+ function tmpDir() {
21
+ const dir = makeTmpDir();
22
+ tmpDirs.push(dir);
23
+ return dir;
24
+ }
25
+ describe('cli warnings count', () => {
26
+ it('should show correct warnings count in scan statistics', () => {
27
+ const cwd = tmpDir();
28
+ // Code using two env vars
29
+ fs.writeFileSync(path.join(cwd, 'index.js'), `
30
+ const apiKey = process.env.API_KEY;
31
+ const apiUrl = process.env.API_URL;
32
+ `);
33
+ // .env.example contains:
34
+ // - lowercase key (uppercase warning)
35
+ // - unused key (unused warning)
36
+ fs.writeFileSync(path.join(cwd, '.env.example'), `
37
+ api_key=test
38
+ UNUSED_KEY=value
39
+ `);
40
+ const res = runCli(cwd, ['--scan-usage']);
41
+ /**
42
+ * Expected warnings:
43
+ * - 2x missing (API_KEY, API_URL)
44
+ * - 1x uppercase warning (api_key)
45
+ * - 1x unused warning (UNUSED_KEY)
46
+ *
47
+ * Total: 4
48
+ */
49
+ expect(res.status).toBe(1);
50
+ expect(res.stdout).toContain('Scan Statistics');
51
+ expect(res.stdout).toContain('5');
52
+ });
53
+ });
54
+ //# sourceMappingURL=cli.warningsCount.e2e.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.warningsCount.e2e.test.js","sourceRoot":"","sources":["../../../test/e2e/cli.warningsCount.e2e.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAC9E,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAE1E,MAAM,OAAO,GAAa,EAAE,CAAC;AAE7B,SAAS,CAAC,GAAG,EAAE;IACb,SAAS,EAAE,CAAC;AACd,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,GAAG,EAAE;IACZ,YAAY,EAAE,CAAC;AACjB,CAAC,CAAC,CAAC;AAEH,SAAS,CAAC,GAAG,EAAE;IACb,OAAO,OAAO,CAAC,MAAM,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,IAAI,GAAG;YAAE,IAAI,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;AACH,CAAC,CAAC,CAAC;AAEH,SAAS,MAAM;IACb,MAAM,GAAG,GAAG,UAAU,EAAE,CAAC;IACzB,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClB,OAAO,GAAG,CAAC;AACb,CAAC;AAED,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC;QAErB,0BAA0B;QAC1B,EAAE,CAAC,aAAa,CACd,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC,EAC1B;;;CAGL,CACI,CAAC;QAEF,yBAAyB;QACzB,sCAAsC;QACtC,gCAAgC;QAChC,EAAE,CAAC,aAAa,CACd,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAC9B;;;CAGL,CACI,CAAC;QAEF,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC;QAE1C;;;;;;;WAOG;QACH,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC3B,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;QAChD,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cli.nextJs.e2e.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.nextJs.e2e.test.d.ts","sourceRoot":"","sources":["../../../../test/e2e/frameworks/cli.nextJs.e2e.test.ts"],"names":[],"mappings":""}