elm-pages 3.0.0-beta.20 → 3.0.0-beta.21

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 (433) hide show
  1. package/README.md +1 -1
  2. package/codegen/elm-pages-codegen.cjs +111 -99
  3. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/dependencies.75364bef27ac5a049b87c3325f846fc6dbda23b8ed7187ed06748b96bb6a50a7.json +1 -0
  4. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Console-Text.elmi +0 -0
  5. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Console-Text.elmo +0 -0
  6. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateData.elmi +0 -0
  7. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateData.elmo +0 -0
  8. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateDataTest.elmi +0 -0
  9. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateDataTest.elmo +0 -0
  10. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Generated-Main.elmi +0 -0
  11. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Generated-Main.elmo +0 -0
  12. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console-Format-Color.elmi +0 -0
  13. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console-Format-Color.elmo +0 -0
  14. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console-Format-Monochrome.elmi +0 -0
  15. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console-Format-Monochrome.elmo +0 -0
  16. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console-Format.elmi +0 -0
  17. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console-Format.elmo +0 -0
  18. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console.elmi +0 -0
  19. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Console.elmo +0 -0
  20. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Highlightable.elmi +0 -0
  21. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Highlightable.elmo +0 -0
  22. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-JUnit.elmi +0 -0
  23. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-JUnit.elmo +0 -0
  24. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Json.elmi +0 -0
  25. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Json.elmo +0 -0
  26. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Reporter.elmi +0 -0
  27. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-Reporter.elmo +0 -0
  28. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-TestResults.elmi +0 -0
  29. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Reporter-TestResults.elmo +0 -0
  30. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-JsMessage.elmi +0 -0
  31. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-JsMessage.elmo +0 -0
  32. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-Node-Vendor-Console.elmi +0 -0
  33. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-Node-Vendor-Console.elmo +0 -0
  34. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-Node-Vendor-Diff.elmi +0 -0
  35. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-Node-Vendor-Diff.elmo +0 -0
  36. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-Node.elmi +0 -0
  37. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/Test-Runner-Node.elmo +0 -0
  38. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/d.dat +0 -0
  39. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/i.dat +0 -0
  40. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/lock +0 -0
  41. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm-stuff/0.19.1/o.dat +0 -0
  42. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elm.json +38 -0
  43. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/elmTestOutput.js +29673 -0
  44. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/package.json +1 -0
  45. package/generator/dead-code-review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision9/src/Test/Generated/Main.elm +27 -0
  46. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateData.elmi +0 -0
  47. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateData.elmo +0 -0
  48. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/Pages-Review-DeadCodeEliminateDataTest.elmo +0 -0
  49. package/generator/dead-code-review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/d.dat +0 -0
  50. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/Reporter.elm.js +1 -1
  51. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/Runner.elm.js +37 -107
  52. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/node_runner.js +1 -1
  53. package/generator/dead-code-review/elm-stuff/tests-0.19.1/js/node_supervisor.js +4 -4
  54. package/generator/dead-code-review/node_modules/.package-lock.json +484 -0
  55. package/generator/dead-code-review/node_modules/ansi-styles/index.d.ts +345 -0
  56. package/generator/dead-code-review/node_modules/ansi-styles/index.js +163 -0
  57. package/generator/dead-code-review/node_modules/ansi-styles/license +9 -0
  58. package/generator/dead-code-review/node_modules/ansi-styles/package.json +56 -0
  59. package/generator/dead-code-review/node_modules/ansi-styles/readme.md +152 -0
  60. package/generator/dead-code-review/node_modules/anymatch/LICENSE +15 -0
  61. package/generator/dead-code-review/node_modules/anymatch/README.md +87 -0
  62. package/generator/dead-code-review/node_modules/anymatch/index.d.ts +20 -0
  63. package/generator/dead-code-review/node_modules/anymatch/index.js +104 -0
  64. package/generator/dead-code-review/node_modules/anymatch/package.json +48 -0
  65. package/generator/dead-code-review/node_modules/balanced-match/.github/FUNDING.yml +2 -0
  66. package/generator/dead-code-review/node_modules/balanced-match/LICENSE.md +21 -0
  67. package/generator/dead-code-review/node_modules/balanced-match/README.md +97 -0
  68. package/generator/dead-code-review/node_modules/balanced-match/index.js +62 -0
  69. package/generator/dead-code-review/node_modules/balanced-match/package.json +48 -0
  70. package/generator/dead-code-review/node_modules/binary-extensions/binary-extensions.json +260 -0
  71. package/generator/dead-code-review/node_modules/binary-extensions/binary-extensions.json.d.ts +3 -0
  72. package/generator/dead-code-review/node_modules/binary-extensions/index.d.ts +14 -0
  73. package/generator/dead-code-review/node_modules/binary-extensions/index.js +1 -0
  74. package/generator/dead-code-review/node_modules/binary-extensions/license +9 -0
  75. package/generator/dead-code-review/node_modules/binary-extensions/package.json +38 -0
  76. package/generator/dead-code-review/node_modules/binary-extensions/readme.md +41 -0
  77. package/generator/dead-code-review/node_modules/brace-expansion/.github/FUNDING.yml +2 -0
  78. package/generator/dead-code-review/node_modules/brace-expansion/LICENSE +21 -0
  79. package/generator/dead-code-review/node_modules/brace-expansion/README.md +135 -0
  80. package/generator/dead-code-review/node_modules/brace-expansion/index.js +203 -0
  81. package/generator/dead-code-review/node_modules/brace-expansion/package.json +46 -0
  82. package/generator/dead-code-review/node_modules/braces/CHANGELOG.md +184 -0
  83. package/generator/dead-code-review/node_modules/braces/LICENSE +21 -0
  84. package/generator/dead-code-review/node_modules/braces/README.md +593 -0
  85. package/generator/dead-code-review/node_modules/braces/index.js +170 -0
  86. package/generator/dead-code-review/node_modules/braces/lib/compile.js +57 -0
  87. package/generator/dead-code-review/node_modules/braces/lib/constants.js +57 -0
  88. package/generator/dead-code-review/node_modules/braces/lib/expand.js +113 -0
  89. package/generator/dead-code-review/node_modules/braces/lib/parse.js +333 -0
  90. package/generator/dead-code-review/node_modules/braces/lib/stringify.js +32 -0
  91. package/generator/dead-code-review/node_modules/braces/lib/utils.js +112 -0
  92. package/generator/dead-code-review/node_modules/braces/package.json +77 -0
  93. package/generator/dead-code-review/node_modules/chalk/index.d.ts +415 -0
  94. package/generator/dead-code-review/node_modules/chalk/license +9 -0
  95. package/generator/dead-code-review/node_modules/chalk/package.json +68 -0
  96. package/generator/dead-code-review/node_modules/chalk/readme.md +341 -0
  97. package/generator/dead-code-review/node_modules/chalk/source/index.js +229 -0
  98. package/generator/dead-code-review/node_modules/chalk/source/templates.js +134 -0
  99. package/generator/dead-code-review/node_modules/chalk/source/util.js +39 -0
  100. package/generator/dead-code-review/node_modules/chokidar/LICENSE +21 -0
  101. package/generator/dead-code-review/node_modules/chokidar/README.md +308 -0
  102. package/generator/dead-code-review/node_modules/chokidar/index.js +973 -0
  103. package/generator/dead-code-review/node_modules/chokidar/lib/constants.js +65 -0
  104. package/generator/dead-code-review/node_modules/chokidar/lib/fsevents-handler.js +524 -0
  105. package/generator/dead-code-review/node_modules/chokidar/lib/nodefs-handler.js +654 -0
  106. package/generator/dead-code-review/node_modules/chokidar/package.json +85 -0
  107. package/generator/dead-code-review/node_modules/chokidar/types/index.d.ts +188 -0
  108. package/generator/dead-code-review/node_modules/color-convert/CHANGELOG.md +54 -0
  109. package/generator/dead-code-review/node_modules/color-convert/LICENSE +21 -0
  110. package/generator/dead-code-review/node_modules/color-convert/README.md +68 -0
  111. package/generator/dead-code-review/node_modules/color-convert/conversions.js +839 -0
  112. package/generator/dead-code-review/node_modules/color-convert/index.js +81 -0
  113. package/generator/dead-code-review/node_modules/color-convert/package.json +48 -0
  114. package/generator/dead-code-review/node_modules/color-convert/route.js +97 -0
  115. package/generator/dead-code-review/node_modules/color-name/LICENSE +8 -0
  116. package/generator/dead-code-review/node_modules/color-name/README.md +11 -0
  117. package/generator/dead-code-review/node_modules/color-name/index.js +152 -0
  118. package/generator/dead-code-review/node_modules/color-name/package.json +28 -0
  119. package/generator/dead-code-review/node_modules/commander/LICENSE +22 -0
  120. package/generator/dead-code-review/node_modules/commander/Readme.md +1118 -0
  121. package/generator/dead-code-review/node_modules/commander/esm.mjs +16 -0
  122. package/generator/dead-code-review/node_modules/commander/index.js +27 -0
  123. package/generator/dead-code-review/node_modules/commander/lib/argument.js +147 -0
  124. package/generator/dead-code-review/node_modules/commander/lib/command.js +2160 -0
  125. package/generator/dead-code-review/node_modules/commander/lib/error.js +45 -0
  126. package/generator/dead-code-review/node_modules/commander/lib/help.js +406 -0
  127. package/generator/dead-code-review/node_modules/commander/lib/option.js +326 -0
  128. package/generator/dead-code-review/node_modules/commander/lib/suggestSimilar.js +100 -0
  129. package/generator/dead-code-review/node_modules/commander/package-support.json +16 -0
  130. package/generator/dead-code-review/node_modules/commander/package.json +80 -0
  131. package/generator/dead-code-review/node_modules/commander/typings/index.d.ts +881 -0
  132. package/generator/dead-code-review/node_modules/cross-spawn/CHANGELOG.md +130 -0
  133. package/generator/dead-code-review/node_modules/cross-spawn/LICENSE +21 -0
  134. package/generator/dead-code-review/node_modules/cross-spawn/README.md +96 -0
  135. package/generator/dead-code-review/node_modules/cross-spawn/index.js +39 -0
  136. package/generator/dead-code-review/node_modules/cross-spawn/lib/enoent.js +59 -0
  137. package/generator/dead-code-review/node_modules/cross-spawn/lib/parse.js +91 -0
  138. package/generator/dead-code-review/node_modules/cross-spawn/lib/util/escape.js +45 -0
  139. package/generator/dead-code-review/node_modules/cross-spawn/lib/util/readShebang.js +23 -0
  140. package/generator/dead-code-review/node_modules/cross-spawn/lib/util/resolveCommand.js +52 -0
  141. package/generator/dead-code-review/node_modules/cross-spawn/package.json +73 -0
  142. package/generator/dead-code-review/node_modules/elm-solve-deps-wasm/LICENSE +373 -0
  143. package/generator/dead-code-review/node_modules/elm-solve-deps-wasm/README.md +64 -0
  144. package/generator/dead-code-review/node_modules/elm-solve-deps-wasm/elm_solve_deps_wasm.d.ts +22 -0
  145. package/generator/dead-code-review/node_modules/elm-solve-deps-wasm/elm_solve_deps_wasm.js +419 -0
  146. package/generator/dead-code-review/node_modules/elm-solve-deps-wasm/elm_solve_deps_wasm_bg.wasm +0 -0
  147. package/generator/dead-code-review/node_modules/elm-solve-deps-wasm/package.json +27 -0
  148. package/generator/dead-code-review/node_modules/elm-test/LICENSE +27 -0
  149. package/generator/dead-code-review/node_modules/elm-test/README.md +192 -0
  150. package/generator/dead-code-review/node_modules/elm-test/bin/elm-test +3 -0
  151. package/generator/dead-code-review/node_modules/elm-test/elm/elm.json +25 -0
  152. package/generator/dead-code-review/node_modules/elm-test/elm/src/Console/Text.elm +217 -0
  153. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Console/Format/Color.elm +30 -0
  154. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Console/Format/Monochrome.elm +39 -0
  155. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Console/Format.elm +212 -0
  156. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Console.elm +207 -0
  157. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Highlightable.elm +48 -0
  158. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/JUnit.elm +161 -0
  159. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Json.elm +158 -0
  160. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/Reporter.elm +53 -0
  161. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Reporter/TestResults.elm +113 -0
  162. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Runner/JsMessage.elm +38 -0
  163. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Runner/Node/Vendor/Console.elm +230 -0
  164. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Runner/Node/Vendor/Diff.elm +326 -0
  165. package/generator/dead-code-review/node_modules/elm-test/elm/src/Test/Runner/Node.elm +440 -0
  166. package/generator/dead-code-review/node_modules/elm-test/lib/Compile.js +110 -0
  167. package/generator/dead-code-review/node_modules/elm-test/lib/DependencyProvider.js +343 -0
  168. package/generator/dead-code-review/node_modules/elm-test/lib/ElmCompiler.js +109 -0
  169. package/generator/dead-code-review/node_modules/elm-test/lib/ElmHome.js +47 -0
  170. package/generator/dead-code-review/node_modules/elm-test/lib/ElmJson.js +194 -0
  171. package/generator/dead-code-review/node_modules/elm-test/lib/FindTests.js +276 -0
  172. package/generator/dead-code-review/node_modules/elm-test/lib/Generate.js +294 -0
  173. package/generator/dead-code-review/node_modules/elm-test/lib/Install.js +290 -0
  174. package/generator/dead-code-review/node_modules/elm-test/lib/Parser.js +941 -0
  175. package/generator/dead-code-review/node_modules/elm-test/lib/Project.js +117 -0
  176. package/generator/dead-code-review/node_modules/elm-test/lib/Report.js +23 -0
  177. package/generator/dead-code-review/node_modules/elm-test/lib/RunTests.js +322 -0
  178. package/generator/dead-code-review/node_modules/elm-test/lib/Solve.js +76 -0
  179. package/generator/dead-code-review/node_modules/elm-test/lib/Supervisor.js +294 -0
  180. package/generator/dead-code-review/node_modules/elm-test/lib/SyncGet.js +45 -0
  181. package/generator/dead-code-review/node_modules/elm-test/lib/SyncGetWorker.js +36 -0
  182. package/generator/dead-code-review/node_modules/elm-test/lib/elm-test.js +318 -0
  183. package/generator/dead-code-review/node_modules/elm-test/package.json +69 -0
  184. package/generator/dead-code-review/node_modules/elm-test/templates/after.js +29 -0
  185. package/generator/dead-code-review/node_modules/elm-test/templates/before.js +58 -0
  186. package/generator/dead-code-review/node_modules/elm-test/templates/tests/Example.elm +10 -0
  187. package/generator/dead-code-review/node_modules/fill-range/LICENSE +21 -0
  188. package/generator/dead-code-review/node_modules/fill-range/README.md +237 -0
  189. package/generator/dead-code-review/node_modules/fill-range/index.js +249 -0
  190. package/generator/dead-code-review/node_modules/fill-range/package.json +69 -0
  191. package/generator/dead-code-review/node_modules/fs.realpath/LICENSE +43 -0
  192. package/generator/dead-code-review/node_modules/fs.realpath/README.md +33 -0
  193. package/generator/dead-code-review/node_modules/fs.realpath/index.js +66 -0
  194. package/generator/dead-code-review/node_modules/fs.realpath/old.js +303 -0
  195. package/generator/dead-code-review/node_modules/fs.realpath/package.json +26 -0
  196. package/generator/dead-code-review/node_modules/fsevents/LICENSE +22 -0
  197. package/generator/dead-code-review/node_modules/fsevents/README.md +83 -0
  198. package/generator/dead-code-review/node_modules/fsevents/fsevents.d.ts +46 -0
  199. package/generator/dead-code-review/node_modules/fsevents/fsevents.js +82 -0
  200. package/generator/dead-code-review/node_modules/fsevents/fsevents.node +0 -0
  201. package/generator/dead-code-review/node_modules/fsevents/package.json +62 -0
  202. package/generator/dead-code-review/node_modules/glob/LICENSE +15 -0
  203. package/generator/dead-code-review/node_modules/glob/README.md +378 -0
  204. package/generator/dead-code-review/node_modules/glob/common.js +240 -0
  205. package/generator/dead-code-review/node_modules/glob/glob.js +790 -0
  206. package/generator/dead-code-review/node_modules/glob/package.json +55 -0
  207. package/generator/dead-code-review/node_modules/glob/sync.js +486 -0
  208. package/generator/dead-code-review/node_modules/glob-parent/CHANGELOG.md +110 -0
  209. package/generator/dead-code-review/node_modules/glob-parent/LICENSE +15 -0
  210. package/generator/dead-code-review/node_modules/glob-parent/README.md +137 -0
  211. package/generator/dead-code-review/node_modules/glob-parent/index.js +42 -0
  212. package/generator/dead-code-review/node_modules/glob-parent/package.json +48 -0
  213. package/generator/dead-code-review/node_modules/graceful-fs/LICENSE +15 -0
  214. package/generator/dead-code-review/node_modules/graceful-fs/README.md +143 -0
  215. package/generator/dead-code-review/node_modules/graceful-fs/clone.js +23 -0
  216. package/generator/dead-code-review/node_modules/graceful-fs/graceful-fs.js +448 -0
  217. package/generator/dead-code-review/node_modules/graceful-fs/legacy-streams.js +118 -0
  218. package/generator/dead-code-review/node_modules/graceful-fs/package.json +50 -0
  219. package/generator/dead-code-review/node_modules/graceful-fs/polyfills.js +355 -0
  220. package/generator/dead-code-review/node_modules/has-flag/index.d.ts +39 -0
  221. package/generator/dead-code-review/node_modules/has-flag/index.js +8 -0
  222. package/generator/dead-code-review/node_modules/has-flag/license +9 -0
  223. package/generator/dead-code-review/node_modules/has-flag/package.json +46 -0
  224. package/generator/dead-code-review/node_modules/has-flag/readme.md +89 -0
  225. package/generator/dead-code-review/node_modules/inflight/LICENSE +15 -0
  226. package/generator/dead-code-review/node_modules/inflight/README.md +37 -0
  227. package/generator/dead-code-review/node_modules/inflight/inflight.js +54 -0
  228. package/generator/dead-code-review/node_modules/inflight/package.json +29 -0
  229. package/generator/dead-code-review/node_modules/inherits/LICENSE +16 -0
  230. package/generator/dead-code-review/node_modules/inherits/README.md +42 -0
  231. package/generator/dead-code-review/node_modules/inherits/inherits.js +9 -0
  232. package/generator/dead-code-review/node_modules/inherits/inherits_browser.js +27 -0
  233. package/generator/dead-code-review/node_modules/inherits/package.json +29 -0
  234. package/generator/dead-code-review/node_modules/is-binary-path/index.d.ts +17 -0
  235. package/generator/dead-code-review/node_modules/is-binary-path/index.js +7 -0
  236. package/generator/dead-code-review/node_modules/is-binary-path/license +9 -0
  237. package/generator/dead-code-review/node_modules/is-binary-path/package.json +40 -0
  238. package/generator/dead-code-review/node_modules/is-binary-path/readme.md +34 -0
  239. package/generator/dead-code-review/node_modules/is-extglob/LICENSE +21 -0
  240. package/generator/dead-code-review/node_modules/is-extglob/README.md +107 -0
  241. package/generator/dead-code-review/node_modules/is-extglob/index.js +20 -0
  242. package/generator/dead-code-review/node_modules/is-extglob/package.json +69 -0
  243. package/generator/dead-code-review/node_modules/is-glob/LICENSE +21 -0
  244. package/generator/dead-code-review/node_modules/is-glob/README.md +206 -0
  245. package/generator/dead-code-review/node_modules/is-glob/index.js +150 -0
  246. package/generator/dead-code-review/node_modules/is-glob/package.json +81 -0
  247. package/generator/dead-code-review/node_modules/is-number/LICENSE +21 -0
  248. package/generator/dead-code-review/node_modules/is-number/README.md +187 -0
  249. package/generator/dead-code-review/node_modules/is-number/index.js +18 -0
  250. package/generator/dead-code-review/node_modules/is-number/package.json +82 -0
  251. package/generator/dead-code-review/node_modules/isexe/LICENSE +15 -0
  252. package/generator/dead-code-review/node_modules/isexe/README.md +51 -0
  253. package/generator/dead-code-review/node_modules/isexe/index.js +57 -0
  254. package/generator/dead-code-review/node_modules/isexe/mode.js +41 -0
  255. package/generator/dead-code-review/node_modules/isexe/package.json +31 -0
  256. package/generator/dead-code-review/node_modules/isexe/test/basic.js +221 -0
  257. package/generator/dead-code-review/node_modules/isexe/windows.js +42 -0
  258. package/generator/dead-code-review/node_modules/minimatch/LICENSE +15 -0
  259. package/generator/dead-code-review/node_modules/minimatch/README.md +259 -0
  260. package/generator/dead-code-review/node_modules/minimatch/lib/path.js +4 -0
  261. package/generator/dead-code-review/node_modules/minimatch/minimatch.js +906 -0
  262. package/generator/dead-code-review/node_modules/minimatch/package.json +32 -0
  263. package/generator/dead-code-review/node_modules/normalize-path/LICENSE +21 -0
  264. package/generator/dead-code-review/node_modules/normalize-path/README.md +127 -0
  265. package/generator/dead-code-review/node_modules/normalize-path/index.js +35 -0
  266. package/generator/dead-code-review/node_modules/normalize-path/package.json +77 -0
  267. package/generator/dead-code-review/node_modules/once/LICENSE +15 -0
  268. package/generator/dead-code-review/node_modules/once/README.md +79 -0
  269. package/generator/dead-code-review/node_modules/once/once.js +42 -0
  270. package/generator/dead-code-review/node_modules/once/package.json +33 -0
  271. package/generator/dead-code-review/node_modules/path-key/index.d.ts +40 -0
  272. package/generator/dead-code-review/node_modules/path-key/index.js +16 -0
  273. package/generator/dead-code-review/node_modules/path-key/license +9 -0
  274. package/generator/dead-code-review/node_modules/path-key/package.json +39 -0
  275. package/generator/dead-code-review/node_modules/path-key/readme.md +61 -0
  276. package/generator/dead-code-review/node_modules/picomatch/CHANGELOG.md +136 -0
  277. package/generator/dead-code-review/node_modules/picomatch/LICENSE +21 -0
  278. package/generator/dead-code-review/node_modules/picomatch/README.md +708 -0
  279. package/generator/dead-code-review/node_modules/picomatch/index.js +3 -0
  280. package/generator/dead-code-review/node_modules/picomatch/lib/constants.js +179 -0
  281. package/generator/dead-code-review/node_modules/picomatch/lib/parse.js +1091 -0
  282. package/generator/dead-code-review/node_modules/picomatch/lib/picomatch.js +342 -0
  283. package/generator/dead-code-review/node_modules/picomatch/lib/scan.js +391 -0
  284. package/generator/dead-code-review/node_modules/picomatch/lib/utils.js +64 -0
  285. package/generator/dead-code-review/node_modules/picomatch/package.json +81 -0
  286. package/generator/dead-code-review/node_modules/readdirp/LICENSE +21 -0
  287. package/generator/dead-code-review/node_modules/readdirp/README.md +122 -0
  288. package/generator/dead-code-review/node_modules/readdirp/index.d.ts +43 -0
  289. package/generator/dead-code-review/node_modules/readdirp/index.js +287 -0
  290. package/generator/dead-code-review/node_modules/readdirp/package.json +122 -0
  291. package/generator/dead-code-review/node_modules/shebang-command/index.js +19 -0
  292. package/generator/dead-code-review/node_modules/shebang-command/license +9 -0
  293. package/generator/dead-code-review/node_modules/shebang-command/package.json +34 -0
  294. package/generator/dead-code-review/node_modules/shebang-command/readme.md +34 -0
  295. package/generator/dead-code-review/node_modules/shebang-regex/index.d.ts +22 -0
  296. package/generator/dead-code-review/node_modules/shebang-regex/index.js +2 -0
  297. package/generator/dead-code-review/node_modules/shebang-regex/license +9 -0
  298. package/generator/dead-code-review/node_modules/shebang-regex/package.json +35 -0
  299. package/generator/dead-code-review/node_modules/shebang-regex/readme.md +33 -0
  300. package/generator/dead-code-review/node_modules/split/.travis.yml +3 -0
  301. package/generator/dead-code-review/node_modules/split/LICENCE +22 -0
  302. package/generator/dead-code-review/node_modules/split/examples/pretty.js +26 -0
  303. package/generator/dead-code-review/node_modules/split/index.js +63 -0
  304. package/generator/dead-code-review/node_modules/split/package.json +30 -0
  305. package/generator/dead-code-review/node_modules/split/readme.markdown +72 -0
  306. package/generator/dead-code-review/node_modules/split/test/options.asynct.js +46 -0
  307. package/generator/dead-code-review/node_modules/split/test/partitioned_unicode.js +34 -0
  308. package/generator/dead-code-review/node_modules/split/test/split.asynct.js +137 -0
  309. package/generator/dead-code-review/node_modules/split/test/try_catch.asynct.js +51 -0
  310. package/generator/dead-code-review/node_modules/supports-color/browser.js +5 -0
  311. package/generator/dead-code-review/node_modules/supports-color/index.js +135 -0
  312. package/generator/dead-code-review/node_modules/supports-color/license +9 -0
  313. package/generator/dead-code-review/node_modules/supports-color/package.json +53 -0
  314. package/generator/dead-code-review/node_modules/supports-color/readme.md +76 -0
  315. package/generator/dead-code-review/node_modules/through/.travis.yml +5 -0
  316. package/generator/dead-code-review/node_modules/through/LICENSE.APACHE2 +15 -0
  317. package/generator/dead-code-review/node_modules/through/LICENSE.MIT +24 -0
  318. package/generator/dead-code-review/node_modules/through/index.js +108 -0
  319. package/generator/dead-code-review/node_modules/through/package.json +36 -0
  320. package/generator/dead-code-review/node_modules/through/readme.markdown +64 -0
  321. package/generator/dead-code-review/node_modules/through/test/async.js +28 -0
  322. package/generator/dead-code-review/node_modules/through/test/auto-destroy.js +30 -0
  323. package/generator/dead-code-review/node_modules/through/test/buffering.js +71 -0
  324. package/generator/dead-code-review/node_modules/through/test/end.js +45 -0
  325. package/generator/dead-code-review/node_modules/through/test/index.js +133 -0
  326. package/generator/dead-code-review/node_modules/to-regex-range/LICENSE +21 -0
  327. package/generator/dead-code-review/node_modules/to-regex-range/README.md +305 -0
  328. package/generator/dead-code-review/node_modules/to-regex-range/index.js +288 -0
  329. package/generator/dead-code-review/node_modules/to-regex-range/package.json +88 -0
  330. package/generator/dead-code-review/node_modules/which/CHANGELOG.md +166 -0
  331. package/generator/dead-code-review/node_modules/which/LICENSE +15 -0
  332. package/generator/dead-code-review/node_modules/which/README.md +54 -0
  333. package/generator/dead-code-review/node_modules/which/bin/node-which +52 -0
  334. package/generator/dead-code-review/node_modules/which/package.json +43 -0
  335. package/generator/dead-code-review/node_modules/which/which.js +125 -0
  336. package/generator/dead-code-review/node_modules/wrappy/LICENSE +15 -0
  337. package/generator/dead-code-review/node_modules/wrappy/README.md +36 -0
  338. package/generator/dead-code-review/node_modules/wrappy/package.json +29 -0
  339. package/generator/dead-code-review/node_modules/wrappy/wrappy.js +33 -0
  340. package/generator/dead-code-review/node_modules/xmlbuilder/.nycrc +6 -0
  341. package/generator/dead-code-review/node_modules/xmlbuilder/.vscode/launch.json +23 -0
  342. package/generator/dead-code-review/node_modules/xmlbuilder/CHANGELOG.md +593 -0
  343. package/generator/dead-code-review/node_modules/xmlbuilder/LICENSE +21 -0
  344. package/generator/dead-code-review/node_modules/xmlbuilder/README.md +103 -0
  345. package/generator/dead-code-review/node_modules/xmlbuilder/lib/Derivation.js +10 -0
  346. package/generator/dead-code-review/node_modules/xmlbuilder/lib/DocumentPosition.js +12 -0
  347. package/generator/dead-code-review/node_modules/xmlbuilder/lib/NodeType.js +25 -0
  348. package/generator/dead-code-review/node_modules/xmlbuilder/lib/OperationType.js +11 -0
  349. package/generator/dead-code-review/node_modules/xmlbuilder/lib/Utility.js +88 -0
  350. package/generator/dead-code-review/node_modules/xmlbuilder/lib/WriterState.js +10 -0
  351. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLAttribute.js +130 -0
  352. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLCData.js +41 -0
  353. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLCharacterData.js +86 -0
  354. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLComment.js +41 -0
  355. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDOMConfiguration.js +80 -0
  356. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDOMErrorHandler.js +20 -0
  357. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDOMImplementation.js +55 -0
  358. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDOMStringList.js +44 -0
  359. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDTDAttList.js +66 -0
  360. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDTDElement.js +44 -0
  361. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDTDEntity.js +115 -0
  362. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDTDNotation.js +66 -0
  363. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDeclaration.js +51 -0
  364. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDocType.js +235 -0
  365. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDocument.js +282 -0
  366. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDocumentCB.js +650 -0
  367. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDocumentFragment.js +21 -0
  368. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLDummy.js +39 -0
  369. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLElement.js +334 -0
  370. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLNamedNodeMap.js +77 -0
  371. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLNode.js +999 -0
  372. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLNodeFilter.js +51 -0
  373. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLNodeList.js +45 -0
  374. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLProcessingInstruction.js +56 -0
  375. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLRaw.js +40 -0
  376. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLStreamWriter.js +209 -0
  377. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLStringWriter.js +40 -0
  378. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLStringifier.js +291 -0
  379. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLText.js +82 -0
  380. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLTypeInfo.js +23 -0
  381. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLUserDataHandler.js +27 -0
  382. package/generator/dead-code-review/node_modules/xmlbuilder/lib/XMLWriterBase.js +485 -0
  383. package/generator/dead-code-review/node_modules/xmlbuilder/lib/index.js +120 -0
  384. package/generator/dead-code-review/node_modules/xmlbuilder/package.json +51 -0
  385. package/generator/dead-code-review/node_modules/xmlbuilder/perf/basic/escaping.coffee +244 -0
  386. package/generator/dead-code-review/node_modules/xmlbuilder/perf/basic/object.coffee +21 -0
  387. package/generator/dead-code-review/node_modules/xmlbuilder/perf/index.coffee +161 -0
  388. package/generator/dead-code-review/node_modules/xmlbuilder/perf/perf.list +11 -0
  389. package/generator/dead-code-review/node_modules/xmlbuilder/typings/index.d.ts +1771 -0
  390. package/generator/review/elm-stuff/0.19.1/d.dat +0 -0
  391. package/generator/review/elm-stuff/0.19.1/i.dat +0 -0
  392. package/generator/review/elm-stuff/0.19.1/o.dat +0 -0
  393. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision10/install/elm-stuff/0.19.1/d.dat +0 -0
  394. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision10/install/elm-stuff/0.19.1/i.dat +0 -0
  395. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision10/install/elm-stuff/0.19.1/o.dat +0 -0
  396. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision10/install/elm.json +25 -0
  397. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision7/install/elm-stuff/0.19.1/d.dat +0 -0
  398. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision7/install/elm-stuff/0.19.1/i.dat +0 -0
  399. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision7/install/elm-stuff/0.19.1/o.dat +0 -0
  400. package/generator/review/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revision7/install/elm.json +41 -0
  401. package/generator/review/elm-stuff/tests-0.19.1/elm-stuff/0.19.1/d.dat +0 -0
  402. package/generator/review/elm-stuff/tests-0.19.1/js/Reporter.elm.js +1 -1
  403. package/generator/review/elm-stuff/tests-0.19.1/js/Runner.elm.js +1 -1
  404. package/generator/review/elm-stuff/tests-0.19.1/js/node_runner.js +1 -1
  405. package/generator/review/elm-stuff/tests-0.19.1/js/node_supervisor.js +4 -4
  406. package/generator/src/cli.js +15 -7
  407. package/generator/src/compatibility-key.js +3 -1
  408. package/generator/src/dev-server.js +0 -13
  409. package/generator/src/pre-render-html.js +4 -6
  410. package/generator/src/render-worker.js +4 -1
  411. package/generator/src/request-cache.js +59 -8
  412. package/generator/template/app/Api.elm +4 -3
  413. package/generator/template/app/Effect.elm +123 -0
  414. package/generator/template/app/ErrorPage.elm +37 -6
  415. package/generator/template/app/Route/Index.elm +14 -7
  416. package/generator/template/app/Shared.elm +23 -46
  417. package/generator/template/app/Site.elm +11 -3
  418. package/generator/template/app/View.elm +1 -8
  419. package/generator/template/elm-tooling.json +0 -3
  420. package/generator/template/elm.json +34 -25
  421. package/generator/template/package.json +10 -4
  422. package/package.json +1 -1
  423. package/src/BackendTask/Custom.elm +110 -6
  424. package/src/Form/Field.elm +21 -9
  425. package/src/Form/FieldView.elm +14 -4
  426. package/src/Form.elm +61 -53
  427. package/src/Pages/Internal/Platform/Cli.elm +262 -235
  428. package/src/Pages/Internal/Platform/CompatibilityKey.elm +1 -1
  429. package/src/Pages/Internal/Platform.elm +56 -35
  430. package/src/Result/Extra.elm +6 -1
  431. package/src/Scaffold/Form.elm +474 -0
  432. package/src/{Pages/Generate.elm → Scaffold/Route.elm} +35 -5
  433. package/src/Test/Html/Internal/ElmHtml/ToString.elm +8 -9
@@ -0,0 +1,276 @@
1
+ // @flow
2
+
3
+ const gracefulFs = require('graceful-fs');
4
+ const fs = require('fs');
5
+ const glob = require('glob');
6
+ const path = require('path');
7
+ const Parser = require('./Parser');
8
+ const Project = require('./Project');
9
+
10
+ void Project;
11
+
12
+ // Double stars at the start and end is the correct way to ignore directories in
13
+ // the `glob` package.
14
+ // https://github.com/isaacs/node-glob/issues/270#issuecomment-273949982
15
+ // https://github.com/isaacs/node-glob/blob/f5a57d3d6e19b324522a3fa5bdd5075fd1aa79d1/common.js#L222-L231
16
+ const ignoredDirsGlobs = ['**/elm-stuff/**', '**/node_modules/**'];
17
+
18
+ function resolveGlobs(
19
+ fileGlobs /*: Array<string> */,
20
+ projectRootDir /*: string */
21
+ ) /*: Array<string> */ {
22
+ return Array.from(
23
+ new Set(
24
+ fileGlobs.flatMap((fileGlob) => {
25
+ const absolutePath = path.resolve(fileGlob);
26
+ try {
27
+ const stat = fs.statSync(absolutePath);
28
+ // If the CLI arg exists…
29
+ return stat.isDirectory()
30
+ ? // …and it’s a directory, find all .elm files in there…
31
+ findAllElmFilesInDir(absolutePath)
32
+ : // …otherwise use it as-is.
33
+ [absolutePath];
34
+ } catch (error) {
35
+ // If the CLI arg does not exist…
36
+ return error.code === 'ENOENT'
37
+ ? // …resolve it as a glob for shells that don’t support globs.
38
+ resolveCliArgGlob(absolutePath, projectRootDir)
39
+ : // The glob package ignores other types of stat errors.
40
+ [];
41
+ }
42
+ })
43
+ ),
44
+ // The `glob` package returns absolute paths with slashes always, even on
45
+ // Windows. All other paths in elm-test use the native directory separator
46
+ // so normalize here.
47
+ (filePath) => path.normalize(filePath)
48
+ );
49
+ }
50
+
51
+ function resolveCliArgGlob(
52
+ fileGlob /*: string */,
53
+ projectRootDir /*: string */
54
+ ) /*: Array<string> */ {
55
+ // Globs passed as CLI arguments are relative to CWD, while elm-test
56
+ // operates from the project root dir.
57
+ const globRelativeToProjectRoot = path.relative(
58
+ projectRootDir,
59
+ path.resolve(fileGlob)
60
+ );
61
+
62
+ // glob@8 (via minimatch@5) had a breaking change where you _have_ to use
63
+ // forwards slash as path separator, regardless of platform, making it
64
+ // unambiguous which characters are separators and which are escapes. This
65
+ // restores the previous behavior, avoiding a breaking change in elm-test.
66
+ // Note: As far I can tell, escaping glob syntax has _never_ worked on
67
+ // Windows. In Elm, needing to escape glob syntax should be very rare, since
68
+ // Elm file paths must match the module name (letters only). So it’s probably
69
+ // more worth supporting `some\folder\*Test.elm` rather than escaping.
70
+ // https://github.com/isaacs/node-glob/issues/468
71
+ // https://github.com/isaacs/minimatch/commit/9104d8d175bdd8843338103be1401f80774d2a10#diff-f41746899d033115e03bebe4fbde76acf2de4bf261bfb221744808f4c8a286cf
72
+ const pattern =
73
+ process.platform === 'win32'
74
+ ? globRelativeToProjectRoot.replace(/\\/g, '/')
75
+ : globRelativeToProjectRoot;
76
+
77
+ return glob
78
+ .sync(pattern, {
79
+ cwd: projectRootDir,
80
+ nocase: true,
81
+ absolute: true,
82
+ ignore: ignoredDirsGlobs,
83
+ // Match directories as well and mark them with a trailing slash.
84
+ nodir: false,
85
+ mark: true,
86
+ })
87
+ .flatMap((filePath) =>
88
+ filePath.endsWith('/') ? findAllElmFilesInDir(filePath) : filePath
89
+ );
90
+ }
91
+
92
+ // Recursively search for *.elm files.
93
+ function findAllElmFilesInDir(dir /*: string */) /*: Array<string> */ {
94
+ return glob.sync('**/*.elm', {
95
+ cwd: dir,
96
+ nocase: true,
97
+ absolute: true,
98
+ ignore: ignoredDirsGlobs,
99
+ nodir: true,
100
+ });
101
+ }
102
+
103
+ function findTests(
104
+ testFilePaths /*: Array<string> */,
105
+ project /*: typeof Project.Project */
106
+ ) /*: Promise<Array<{ moduleName: string, possiblyTests: Array<string> }>> */ {
107
+ return Promise.all(
108
+ testFilePaths.map((filePath) => {
109
+ const matchingSourceDirs = project.testsSourceDirs.filter((dir) =>
110
+ filePath.startsWith(`${dir}${path.sep}`)
111
+ );
112
+
113
+ // Tests must be in tests/ or in source-directories – otherwise they won’t
114
+ // compile. Elm won’t be able to find imports.
115
+ switch (matchingSourceDirs.length) {
116
+ case 0:
117
+ return Promise.reject(
118
+ Error(
119
+ missingSourceDirectoryError(
120
+ filePath,
121
+ project.elmJson.type === 'package'
122
+ )
123
+ )
124
+ );
125
+
126
+ case 1:
127
+ // Keep going.
128
+ break;
129
+
130
+ default:
131
+ // This shouldn’t be possible for package projects.
132
+ return Promise.reject(
133
+ new Error(
134
+ multipleSourceDirectoriesError(
135
+ filePath,
136
+ matchingSourceDirs,
137
+ project.testsDir
138
+ )
139
+ )
140
+ );
141
+ }
142
+
143
+ // By finding the module name from the file path we can import it even if
144
+ // the file is full of errors. Elm will then report what’s wrong.
145
+ const moduleNameParts = path
146
+ .relative(matchingSourceDirs[0], filePath)
147
+ .replace(/\.elm$/, '')
148
+ .split(path.sep);
149
+ const moduleName = moduleNameParts.join('.');
150
+
151
+ if (!moduleNameParts.every(Parser.isUpperName)) {
152
+ return Promise.reject(
153
+ new Error(
154
+ badModuleNameError(filePath, matchingSourceDirs[0], moduleName)
155
+ )
156
+ );
157
+ }
158
+
159
+ return Parser.extractExposedPossiblyTests(
160
+ filePath,
161
+ // We’re reading files asynchronously in a loop here, so it makes sense
162
+ // to use graceful-fs to avoid “too many open files” errors.
163
+ gracefulFs.createReadStream
164
+ ).then((possiblyTests) => ({
165
+ moduleName,
166
+ possiblyTests,
167
+ }));
168
+ })
169
+ );
170
+ }
171
+
172
+ function missingSourceDirectoryError(filePath, isPackageProject) {
173
+ return `
174
+ This file:
175
+
176
+ ${filePath}
177
+
178
+ …matches no source directory! Imports won't work then.
179
+
180
+ ${
181
+ isPackageProject
182
+ ? 'Move it to tests/ or src/ in your project root.'
183
+ : 'Move it to tests/ in your project root, or make sure it is covered by "source-directories" in your elm.json.'
184
+ }
185
+ `.trim();
186
+ }
187
+
188
+ function multipleSourceDirectoriesError(
189
+ filePath,
190
+ matchingSourceDirs,
191
+ testsDir
192
+ ) {
193
+ const note = matchingSourceDirs.includes(testsDir)
194
+ ? "Note: The tests/ folder counts as a source directory too (even if it isn't listed in your elm.json)!"
195
+ : '';
196
+
197
+ return `
198
+ This file:
199
+
200
+ ${filePath}
201
+
202
+ …matches more than one source directory:
203
+
204
+ ${matchingSourceDirs.join('\n')}
205
+
206
+ Edit "source-directories" in your elm.json and try to make it so no source directory contains another source directory!
207
+
208
+ ${note}
209
+ `.trim();
210
+ }
211
+
212
+ function badModuleNameError(filePath, sourceDir, moduleName) {
213
+ return `
214
+ This file:
215
+
216
+ ${filePath}
217
+
218
+ …located in this directory:
219
+
220
+ ${sourceDir}
221
+
222
+ …is problematic. Trying to construct a module name from the parts after the directory gives:
223
+
224
+ ${moduleName}
225
+
226
+ …but module names need to look like for example:
227
+
228
+ Main
229
+ Http.Helpers
230
+
231
+ Make sure that all parts start with an uppercase letter and don't contain any spaces or anything like that.
232
+ `.trim();
233
+ }
234
+
235
+ function noFilesFoundError(
236
+ projectRootDir /*: string */,
237
+ testFileGlobs /*: Array<string> */
238
+ ) /*: string */ {
239
+ return testFileGlobs.length === 0
240
+ ? `
241
+ ${noFilesFoundInTestsDir(projectRootDir)}
242
+
243
+ To generate some initial tests to get things going: elm-test init
244
+
245
+ Alternatively, if your project has tests in a different directory,
246
+ try calling elm-test with a glob such as: elm-test "src/**/*Tests.elm"
247
+ `.trim()
248
+ : `
249
+ No files found matching:
250
+
251
+ ${testFileGlobs.join('\n')}
252
+
253
+ Are the above patterns correct? Maybe try running elm-test with no arguments?
254
+ `.trim();
255
+ }
256
+
257
+ function noFilesFoundInTestsDir(projectRootDir) {
258
+ const testsDir = path.join(projectRootDir, 'tests');
259
+ try {
260
+ const stats = fs.statSync(testsDir);
261
+ return stats.isDirectory()
262
+ ? 'No .elm files found in the tests/ directory.'
263
+ : `Expected a directory but found something else at: ${testsDir}\nCheck it out! Could you remove it?`;
264
+ } catch (error) {
265
+ return error.code === 'ENOENT'
266
+ ? 'The tests/ directory does not exist.'
267
+ : `Failed to read the tests/ directory: ${error.message}`;
268
+ }
269
+ }
270
+
271
+ module.exports = {
272
+ findTests,
273
+ ignoredDirsGlobs,
274
+ noFilesFoundError,
275
+ resolveGlobs,
276
+ };
@@ -0,0 +1,294 @@
1
+ // @flow
2
+
3
+ const { supportsColor } = require('chalk');
4
+ const fs = require('fs');
5
+ const path = require('path');
6
+ const DependencyProvider = require('./DependencyProvider.js');
7
+ const ElmJson = require('./ElmJson');
8
+ const Project = require('./Project');
9
+ const Report = require('./Report');
10
+ const Solve = require('./Solve');
11
+
12
+ // These values are used _only_ in flow types. 'use' them with the javascript
13
+ // void operator to keep eslint happy.
14
+ void DependencyProvider;
15
+ void Project;
16
+ void Report;
17
+
18
+ const before = fs.readFileSync(
19
+ path.join(__dirname, '..', 'templates', 'before.js'),
20
+ 'utf8'
21
+ );
22
+
23
+ const after = fs.readFileSync(
24
+ path.join(__dirname, '..', 'templates', 'after.js'),
25
+ 'utf8'
26
+ );
27
+
28
+ function prepareCompiledJsFile(
29
+ pipeFilename /*: string */,
30
+ dest /*: string */
31
+ ) /*: void */ {
32
+ const content = fs.readFileSync(dest, 'utf8');
33
+ const finalContent = `
34
+ ${before}
35
+ var Elm = (function(module) {
36
+ ${addKernelTestChecking(content)}
37
+ return this.Elm;
38
+ })({});
39
+ var pipeFilename = ${JSON.stringify(pipeFilename)};
40
+ ${after}
41
+ `.trim();
42
+ fs.writeFileSync(dest, finalContent);
43
+
44
+ // Needed when the user has `"type": "module"` in their package.json.
45
+ // Our output is CommonJS.
46
+ fs.writeFileSync(
47
+ path.join(path.dirname(dest), 'package.json'),
48
+ JSON.stringify({ type: 'commonjs' })
49
+ );
50
+ }
51
+
52
+ // For older versions of elm-explorations/test we need to list every single
53
+ // variant of the `Test` type. To avoid having to update this regex if a new
54
+ // variant is added, newer versions of elm-explorations/test have prefixed all
55
+ // variants with `ElmTestVariant__` so we can match just on that.
56
+ const testVariantDefinition =
57
+ /^var\s+\$elm_explorations\$test\$Test\$Internal\$(?:ElmTestVariant__\w+|UnitTest|FuzzTest|Labeled|Skipped|Only|Batch)\s*=\s*(?:\w+\(\s*)?function\s*\([\w, ]*\)\s*\{\s*return *\{/gm;
58
+
59
+ const checkDefinition =
60
+ /^(var\s+\$author\$project\$Test\$Runner\$Node\$check)\s*=\s*\$author\$project\$Test\$Runner\$Node\$checkHelperReplaceMe___;?$/m;
61
+
62
+ // Create a symbol, tag all `Test` constructors with it and make the `check`
63
+ // function look for it.
64
+ function addKernelTestChecking(content) {
65
+ return (
66
+ 'var __elmTestSymbol = Symbol("elmTestSymbol");\n' +
67
+ content
68
+ .replace(testVariantDefinition, '$&__elmTestSymbol: __elmTestSymbol, ')
69
+ .replace(
70
+ checkDefinition,
71
+ '$1 = value => value && value.__elmTestSymbol === __elmTestSymbol ? $elm$core$Maybe$Just(value) : $elm$core$Maybe$Nothing;'
72
+ )
73
+ );
74
+ }
75
+
76
+ function getGeneratedSrcDir(generatedCodeDir /*: string */) /*: string */ {
77
+ return path.join(generatedCodeDir, 'src');
78
+ }
79
+
80
+ function generateElmJson(
81
+ dependencyProvider /*: DependencyProvider */,
82
+ project /*: typeof Project.Project */
83
+ ) /*: void */ {
84
+ const generatedSrc = getGeneratedSrcDir(project.generatedCodeDir);
85
+
86
+ fs.mkdirSync(generatedSrc, { recursive: true });
87
+
88
+ const sourceDirs = [
89
+ // Include the generated test application.
90
+ generatedSrc,
91
+
92
+ // NOTE: we must include node-test-runner's Elm source as a source-directory
93
+ // instead of adding it as a dependency so that it can include port modules
94
+ path.join(__dirname, '..', 'elm', 'src'),
95
+ ]
96
+ .concat(project.testsSourceDirs)
97
+ .filter(
98
+ // When running node-test-runner's own test suite, the node-test-runner/src folder
99
+ // will get added twice: once because it's the source-directory of the packge being tested,
100
+ // and once because elm-test will always add it.
101
+ // To prevent elm from being confused, we need to remove the duplicate when this happens.
102
+ (value, index, self) => self.indexOf(value) === index
103
+ )
104
+ .map((absolutePath) =>
105
+ // Relative paths have the nice benefit that if the user moves their
106
+ // directory, this doesn't break.
107
+ path.relative(project.generatedCodeDir, absolutePath)
108
+ );
109
+
110
+ const testElmJson = {
111
+ type: 'application',
112
+ 'source-directories': sourceDirs,
113
+ 'elm-version': '0.19.1',
114
+ dependencies: Solve.getDependenciesCached(dependencyProvider, project),
115
+ 'test-dependencies': {
116
+ direct: {},
117
+ indirect: {},
118
+ },
119
+ };
120
+
121
+ // Generate the new elm.json, if necessary.
122
+ const generatedContents = JSON.stringify(testElmJson, null, 4);
123
+ const generatedPath = ElmJson.getPath(project.generatedCodeDir);
124
+
125
+ // Don't write a fresh elm.json if it's going to be the same. If we do,
126
+ // it will update the timestamp on the file, which will cause `elm make`
127
+ // to do a bunch of unnecessary work.
128
+ if (
129
+ !fs.existsSync(generatedPath) ||
130
+ generatedContents !== fs.readFileSync(generatedPath, 'utf8')
131
+ ) {
132
+ // package projects don't explicitly list their transitive dependencies,
133
+ // to we have to figure out what they are. We write the elm.json that
134
+ // we have so far, and run elm to see what it thinks is missing.
135
+ fs.writeFileSync(generatedPath, generatedContents);
136
+ }
137
+ }
138
+
139
+ function getMainModule(generatedCodeDir /*: string */) /*: {
140
+ moduleName: string,
141
+ path: string,
142
+ } */ {
143
+ const moduleName = ['Test', 'Generated', 'Main'];
144
+ return {
145
+ moduleName: moduleName.join('.'),
146
+ path:
147
+ // We'll be putting the generated Main in something like this:
148
+ //
149
+ // my-project-name/elm-stuff/generated-code/elm-community/elm-test/0.19.1-revisionX/src/Test/Generated/Main.elm
150
+ path.join(getGeneratedSrcDir(generatedCodeDir), ...moduleName) + '.elm',
151
+ };
152
+ }
153
+
154
+ function generateMainModule(
155
+ fuzz /*: number */,
156
+ seed /*: number */,
157
+ report /*: typeof Report.Report */,
158
+ testFileGlobs /*: Array<string> */,
159
+ testFilePaths /*: Array<string> */,
160
+ testModules /*: Array<{
161
+ moduleName: string,
162
+ possiblyTests: Array<string>,
163
+ }> */,
164
+ mainModule /*: { moduleName: string, path: string } */,
165
+ processes /*: number */
166
+ ) /*: void */ {
167
+ const testFileBody = makeTestFileBody(
168
+ testModules,
169
+ makeOptsCode(fuzz, seed, report, testFileGlobs, testFilePaths, processes)
170
+ );
171
+
172
+ const testFileContents = `module ${mainModule.moduleName} exposing (main)\n\n${testFileBody}`;
173
+
174
+ fs.mkdirSync(path.dirname(mainModule.path), { recursive: true });
175
+
176
+ fs.writeFileSync(mainModule.path, testFileContents);
177
+ }
178
+
179
+ function makeTestFileBody(
180
+ testModules /*: Array<{
181
+ moduleName: string,
182
+ possiblyTests: Array<string>,
183
+ }> */,
184
+ optsCode /*: string */
185
+ ) /*: string */ {
186
+ const imports = testModules.map((mod) => `import ${mod.moduleName}`);
187
+
188
+ const possiblyTestsList = makeList(testModules.map(makeModuleTuple));
189
+
190
+ return `
191
+ ${imports.join('\n')}
192
+
193
+ import Test.Reporter.Reporter exposing (Report(..))
194
+ import Console.Text exposing (UseColor(..))
195
+ import Test.Runner.Node
196
+ import Test
197
+
198
+ main : Test.Runner.Node.TestProgram
199
+ main =
200
+ Test.Runner.Node.run
201
+ ${indentAllButFirstLine(' ', optsCode)}
202
+ ${indentAllButFirstLine(' ', possiblyTestsList)}
203
+ `.trim();
204
+ }
205
+
206
+ function makeModuleTuple(mod /*: {
207
+ moduleName: string,
208
+ possiblyTests: Array<string>,
209
+ } */) /*: string */ {
210
+ const list = mod.possiblyTests.map(
211
+ (test) => `Test.Runner.Node.check ${mod.moduleName}.${test}`
212
+ );
213
+
214
+ return `
215
+ ( "${mod.moduleName}"
216
+ , ${indentAllButFirstLine(' ', makeList(list))}
217
+ )
218
+ `.trim();
219
+ }
220
+
221
+ function makeList(parts /*: Array<string> */) /*: string */ {
222
+ if (parts.length === 0) {
223
+ return '[]';
224
+ }
225
+
226
+ const list = parts.map(
227
+ (part, index) =>
228
+ `${index === 0 ? '' : ', '}${indentAllButFirstLine(' ', part)}`
229
+ );
230
+
231
+ return `
232
+ [ ${list.join('\n')}
233
+ ]
234
+ `.trim();
235
+ }
236
+
237
+ function indentAllButFirstLine(indent, string) {
238
+ return string
239
+ .split('\n')
240
+ .map((line, index) => (index === 0 ? line : indent + line))
241
+ .join('\n');
242
+ }
243
+
244
+ function makeOptsCode(
245
+ fuzz /*: number */,
246
+ seed /*: number */,
247
+ report /*: typeof Report.Report */,
248
+ testFileGlobs /*: Array<string> */,
249
+ testFilePaths /*: Array<string> */,
250
+ processes /*: number */
251
+ ) /*: string */ {
252
+ return `
253
+ { runs = ${fuzz}
254
+ , report = ${generateElmReportVariant(report)}
255
+ , seed = ${seed}
256
+ , processes = ${processes}
257
+ , globs =
258
+ ${indentAllButFirstLine(' ', makeList(testFileGlobs.map(makeElmString)))}
259
+ , paths =
260
+ ${indentAllButFirstLine(' ', makeList(testFilePaths.map(makeElmString)))}
261
+ }
262
+ `.trim();
263
+ }
264
+
265
+ function generateElmReportVariant(
266
+ report /*: typeof Report.Report */
267
+ ) /*: string */ {
268
+ switch (report) {
269
+ case 'json':
270
+ return 'JsonReport';
271
+ case 'junit':
272
+ return 'JUnitReport';
273
+ case 'console':
274
+ if (supportsColor) {
275
+ return 'ConsoleReport UseColor';
276
+ } else {
277
+ return 'ConsoleReport Monochrome';
278
+ }
279
+ }
280
+ }
281
+
282
+ function makeElmString(string) {
283
+ return `"${string
284
+ .replace(/[\\"]/g, '\\$&')
285
+ .replace(/\n/g, '\\n')
286
+ .replace(/\r/g, '\\r')}"`;
287
+ }
288
+
289
+ module.exports = {
290
+ generateElmJson,
291
+ generateMainModule,
292
+ getMainModule,
293
+ prepareCompiledJsFile,
294
+ };