wrangler 2.20.0 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (297) hide show
  1. package/README.md +4 -4
  2. package/bin/wrangler.js +9 -75
  3. package/package.json +5 -13
  4. package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
  5. package/templates/checked-fetch.js +1 -1
  6. package/templates/first-party-worker-module-facade.ts +2 -2
  7. package/templates/middleware/common.ts +9 -4
  8. package/templates/middleware/loader-sw.ts +2 -7
  9. package/templates/new-worker-scheduled.ts +1 -1
  10. package/templates/new-worker.ts +1 -1
  11. package/templates/pages-dev-util.ts +4 -1
  12. package/templates/pages-shim.ts +0 -3
  13. package/templates/tsconfig.tsbuildinfo +1 -1
  14. package/wrangler-dist/cli.d.ts +149 -75
  15. package/wrangler-dist/cli.js +60062 -64338
  16. package/import_meta_url.js +0 -3
  17. package/miniflare-config-stubs/.env.empty +0 -0
  18. package/miniflare-config-stubs/package.empty.json +0 -1
  19. package/miniflare-config-stubs/wrangler.empty.toml +0 -0
  20. package/miniflare-dist/index.mjs +0 -6442
  21. package/src/__tests__/access.test.ts +0 -25
  22. package/src/__tests__/api-dev.test.ts +0 -238
  23. package/src/__tests__/api-devregistry.test.ts +0 -121
  24. package/src/__tests__/api.test.ts +0 -102
  25. package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
  26. package/src/__tests__/config-cache.test.ts +0 -42
  27. package/src/__tests__/configuration.test.ts +0 -4517
  28. package/src/__tests__/constellation.test.ts +0 -371
  29. package/src/__tests__/d1/d1.test.ts +0 -82
  30. package/src/__tests__/d1/execute.test.ts +0 -66
  31. package/src/__tests__/d1/migrate.test.ts +0 -257
  32. package/src/__tests__/d1/splitter.test.ts +0 -255
  33. package/src/__tests__/delete.test.ts +0 -272
  34. package/src/__tests__/deployments.test.ts +0 -369
  35. package/src/__tests__/dev.test.tsx +0 -1617
  36. package/src/__tests__/generate.test.ts +0 -237
  37. package/src/__tests__/get-host-from-url.test.ts +0 -16
  38. package/src/__tests__/guess-worker-format.test.ts +0 -120
  39. package/src/__tests__/helpers/clipboardy-mock.js +0 -4
  40. package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
  41. package/src/__tests__/helpers/end-event-loop.ts +0 -6
  42. package/src/__tests__/helpers/mock-account-id.ts +0 -48
  43. package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
  44. package/src/__tests__/helpers/mock-bin.ts +0 -36
  45. package/src/__tests__/helpers/mock-console.ts +0 -112
  46. package/src/__tests__/helpers/mock-dialogs.ts +0 -139
  47. package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
  48. package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
  49. package/src/__tests__/helpers/mock-http-server.ts +0 -46
  50. package/src/__tests__/helpers/mock-istty.ts +0 -74
  51. package/src/__tests__/helpers/mock-known-routes.ts +0 -12
  52. package/src/__tests__/helpers/mock-kv.ts +0 -46
  53. package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
  54. package/src/__tests__/helpers/mock-process.ts +0 -34
  55. package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
  56. package/src/__tests__/helpers/mock-stdin.ts +0 -108
  57. package/src/__tests__/helpers/mock-web-socket.ts +0 -29
  58. package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
  59. package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
  60. package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
  61. package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
  62. package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
  63. package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
  64. package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
  65. package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
  66. package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
  67. package/src/__tests__/helpers/msw/index.ts +0 -52
  68. package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
  69. package/src/__tests__/helpers/run-in-tmp.ts +0 -38
  70. package/src/__tests__/helpers/run-wrangler.ts +0 -16
  71. package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
  72. package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
  73. package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
  74. package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
  75. package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
  76. package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
  77. package/src/__tests__/helpers/write-worker-source.ts +0 -31
  78. package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
  79. package/src/__tests__/https-options.test.ts +0 -163
  80. package/src/__tests__/index.test.ts +0 -282
  81. package/src/__tests__/init.test.ts +0 -3196
  82. package/src/__tests__/jest.setup.ts +0 -179
  83. package/src/__tests__/kv.test.ts +0 -1799
  84. package/src/__tests__/logger.test.ts +0 -207
  85. package/src/__tests__/logout.test.ts +0 -47
  86. package/src/__tests__/metrics.test.ts +0 -493
  87. package/src/__tests__/middleware.scheduled.test.ts +0 -145
  88. package/src/__tests__/middleware.test.ts +0 -816
  89. package/src/__tests__/mtls-certificates.test.ts +0 -589
  90. package/src/__tests__/package-manager.test.ts +0 -353
  91. package/src/__tests__/pages/deployment-list.test.ts +0 -80
  92. package/src/__tests__/pages/functions-build.test.ts +0 -528
  93. package/src/__tests__/pages/pages.test.ts +0 -81
  94. package/src/__tests__/pages/project-create.test.ts +0 -63
  95. package/src/__tests__/pages/project-list.test.ts +0 -110
  96. package/src/__tests__/pages/project-upload.test.ts +0 -500
  97. package/src/__tests__/pages/publish.test.ts +0 -2864
  98. package/src/__tests__/pages-deployment-tail.test.ts +0 -957
  99. package/src/__tests__/parse.test.ts +0 -436
  100. package/src/__tests__/paths.test.ts +0 -39
  101. package/src/__tests__/publish.test.ts +0 -8849
  102. package/src/__tests__/pubsub.test.ts +0 -496
  103. package/src/__tests__/queues.test.ts +0 -532
  104. package/src/__tests__/r2.test.ts +0 -374
  105. package/src/__tests__/route.test.ts +0 -45
  106. package/src/__tests__/secret.test.ts +0 -693
  107. package/src/__tests__/tail.test.ts +0 -989
  108. package/src/__tests__/test-old-node-version.js +0 -31
  109. package/src/__tests__/traverse-module-graph.test.ts +0 -220
  110. package/src/__tests__/tsconfig-sanity.ts +0 -12
  111. package/src/__tests__/tsconfig.json +0 -8
  112. package/src/__tests__/tsconfig.tsbuildinfo +0 -1
  113. package/src/__tests__/type-generation.test.ts +0 -234
  114. package/src/__tests__/user.test.ts +0 -118
  115. package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
  116. package/src/__tests__/validate-dev-props.test.ts +0 -56
  117. package/src/__tests__/version.test.ts +0 -35
  118. package/src/__tests__/whoami.test.tsx +0 -172
  119. package/src/__tests__/worker-namespace.test.ts +0 -340
  120. package/src/abort.d.ts +0 -3
  121. package/src/api/dev.ts +0 -321
  122. package/src/api/index.ts +0 -11
  123. package/src/api/mtls-certificate.ts +0 -148
  124. package/src/api/pages/create-worker-bundle-contents.ts +0 -77
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -371
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -929
  129. package/src/cfetch/index.ts +0 -158
  130. package/src/cfetch/internal.ts +0 -258
  131. package/src/cli.ts +0 -28
  132. package/src/config/README.md +0 -107
  133. package/src/config/config.ts +0 -282
  134. package/src/config/diagnostics.ts +0 -80
  135. package/src/config/environment.ts +0 -625
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2369
  139. package/src/config-cache.ts +0 -85
  140. package/src/constellation/createProject.tsx +0 -51
  141. package/src/constellation/deleteProject.ts +0 -51
  142. package/src/constellation/deleteProjectModel.ts +0 -68
  143. package/src/constellation/index.ts +0 -75
  144. package/src/constellation/listCatalog.tsx +0 -35
  145. package/src/constellation/listModel.tsx +0 -41
  146. package/src/constellation/listProject.tsx +0 -28
  147. package/src/constellation/listRuntime.tsx +0 -28
  148. package/src/constellation/options.ts +0 -17
  149. package/src/constellation/types.ts +0 -17
  150. package/src/constellation/uploadModel.tsx +0 -64
  151. package/src/constellation/utils.ts +0 -90
  152. package/src/create-worker-preview.ts +0 -293
  153. package/src/create-worker-upload-form.ts +0 -363
  154. package/src/d1/backups.tsx +0 -219
  155. package/src/d1/constants.ts +0 -2
  156. package/src/d1/create.tsx +0 -70
  157. package/src/d1/delete.ts +0 -53
  158. package/src/d1/execute.tsx +0 -357
  159. package/src/d1/formatTimeAgo.ts +0 -14
  160. package/src/d1/index.ts +0 -100
  161. package/src/d1/list.tsx +0 -62
  162. package/src/d1/migrations/apply.tsx +0 -212
  163. package/src/d1/migrations/create.tsx +0 -79
  164. package/src/d1/migrations/helpers.ts +0 -169
  165. package/src/d1/migrations/index.ts +0 -3
  166. package/src/d1/migrations/list.tsx +0 -95
  167. package/src/d1/migrations/options.ts +0 -23
  168. package/src/d1/options.ts +0 -22
  169. package/src/d1/splitter.ts +0 -161
  170. package/src/d1/types.ts +0 -25
  171. package/src/d1/utils.ts +0 -49
  172. package/src/delete.ts +0 -100
  173. package/src/deployments.ts +0 -368
  174. package/src/deprecated/index.ts +0 -144
  175. package/src/dev/dev-vars.ts +0 -39
  176. package/src/dev/dev.tsx +0 -605
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -952
  179. package/src/dev/remote.tsx +0 -635
  180. package/src/dev/start-server.ts +0 -545
  181. package/src/dev/use-esbuild.ts +0 -215
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -934
  185. package/src/dialogs.ts +0 -136
  186. package/src/dispatch-namespace.ts +0 -211
  187. package/src/docs/helpers.ts +0 -50
  188. package/src/docs/index.ts +0 -54
  189. package/src/durable.ts +0 -102
  190. package/src/entry.ts +0 -344
  191. package/src/environment-variables/factory.ts +0 -89
  192. package/src/environment-variables/misc-variables.ts +0 -30
  193. package/src/errors.ts +0 -11
  194. package/src/generate/index.ts +0 -298
  195. package/src/git-client.ts +0 -135
  196. package/src/global-wrangler-config-path.ts +0 -26
  197. package/src/https-options.ts +0 -127
  198. package/src/index.ts +0 -768
  199. package/src/init.ts +0 -1037
  200. package/src/inspect.ts +0 -883
  201. package/src/intl-polyfill.d.ts +0 -139
  202. package/src/is-ci.ts +0 -14
  203. package/src/is-interactive.ts +0 -16
  204. package/src/jest.d.ts +0 -4
  205. package/src/kv/helpers.ts +0 -433
  206. package/src/kv/index.ts +0 -594
  207. package/src/logger.ts +0 -123
  208. package/src/metrics/index.ts +0 -5
  209. package/src/metrics/metrics-config.ts +0 -239
  210. package/src/metrics/metrics-dispatcher.ts +0 -96
  211. package/src/metrics/metrics-usage-headers.ts +0 -24
  212. package/src/metrics/send-event.ts +0 -99
  213. package/src/miniflare-cli/README.md +0 -30
  214. package/src/miniflare-cli/assets.ts +0 -251
  215. package/src/miniflare-cli/index.ts +0 -210
  216. package/src/miniflare-cli/request-context.ts +0 -40
  217. package/src/miniflare-cli/tsconfig.json +0 -9
  218. package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
  219. package/src/miniflare-cli/types.ts +0 -11
  220. package/src/module-collection.ts +0 -333
  221. package/src/mtls-certificate/cli.ts +0 -155
  222. package/src/open-in-browser.ts +0 -17
  223. package/src/package-manager.ts +0 -219
  224. package/src/pages/build.ts +0 -423
  225. package/src/pages/buildFunctions.ts +0 -140
  226. package/src/pages/constants.ts +0 -18
  227. package/src/pages/deployment-tails.ts +0 -281
  228. package/src/pages/deployments.tsx +0 -84
  229. package/src/pages/dev.ts +0 -734
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -114
  232. package/src/pages/functions/buildWorker.ts +0 -350
  233. package/src/pages/functions/filepath-routing.test.ts +0 -234
  234. package/src/pages/functions/filepath-routing.ts +0 -189
  235. package/src/pages/functions/identifiers.ts +0 -78
  236. package/src/pages/functions/routes-consolidation.test.ts +0 -250
  237. package/src/pages/functions/routes-consolidation.ts +0 -73
  238. package/src/pages/functions/routes-transformation.test.ts +0 -282
  239. package/src/pages/functions/routes-transformation.ts +0 -115
  240. package/src/pages/functions/routes-validation.test.ts +0 -403
  241. package/src/pages/functions/routes-validation.ts +0 -202
  242. package/src/pages/functions/routes.ts +0 -151
  243. package/src/pages/functions/tsconfig.json +0 -8
  244. package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
  245. package/src/pages/functions.ts +0 -86
  246. package/src/pages/hash.ts +0 -13
  247. package/src/pages/index.ts +0 -102
  248. package/src/pages/projects.tsx +0 -159
  249. package/src/pages/prompt-select-project.tsx +0 -31
  250. package/src/pages/publish.tsx +0 -267
  251. package/src/pages/types.ts +0 -46
  252. package/src/pages/upload.tsx +0 -469
  253. package/src/pages/utils.ts +0 -23
  254. package/src/parse.ts +0 -308
  255. package/src/paths.ts +0 -71
  256. package/src/proxy.ts +0 -694
  257. package/src/publish/index.ts +0 -274
  258. package/src/publish/publish.ts +0 -1065
  259. package/src/pubsub/index.ts +0 -286
  260. package/src/pubsub/pubsub-commands.ts +0 -623
  261. package/src/queues/cli/commands/consumer/add.ts +0 -71
  262. package/src/queues/cli/commands/consumer/index.ts +0 -19
  263. package/src/queues/cli/commands/consumer/remove.ts +0 -31
  264. package/src/queues/cli/commands/create.ts +0 -25
  265. package/src/queues/cli/commands/delete.ts +0 -26
  266. package/src/queues/cli/commands/index.ts +0 -35
  267. package/src/queues/cli/commands/list.ts +0 -25
  268. package/src/queues/client.ts +0 -136
  269. package/src/queues/utils.ts +0 -18
  270. package/src/r2/constants.ts +0 -4
  271. package/src/r2/helpers.ts +0 -132
  272. package/src/r2/index.ts +0 -289
  273. package/src/routes.ts +0 -140
  274. package/src/secret/index.ts +0 -377
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -415
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -132
  281. package/src/traverse-module-graph.ts +0 -54
  282. package/src/tsconfig-sanity.ts +0 -16
  283. package/src/type-generation.ts +0 -181
  284. package/src/update-check.ts +0 -19
  285. package/src/user/access.ts +0 -68
  286. package/src/user/auth-variables.ts +0 -113
  287. package/src/user/choose-account.tsx +0 -39
  288. package/src/user/generate-auth-url.ts +0 -33
  289. package/src/user/generate-random-state.ts +0 -16
  290. package/src/user/index.ts +0 -2
  291. package/src/user/user.ts +0 -1234
  292. package/src/utils/collectKeyValues.ts +0 -14
  293. package/src/utils/render.ts +0 -93
  294. package/src/whoami.ts +0 -135
  295. package/src/worker.ts +0 -279
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
@@ -1,528 +0,0 @@
1
- import { execSync } from "node:child_process";
2
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
3
- import { endEventLoop } from "../helpers/end-event-loop";
4
- import { mockConsoleMethods } from "../helpers/mock-console";
5
- import { runInTempDir } from "../helpers/run-in-tmp";
6
- import { runWrangler } from "../helpers/run-wrangler";
7
- import { replaceRandomWithConstantData } from "../helpers/string-dynamic-values-matcher";
8
-
9
- describe("functions build", () => {
10
- const std = mockConsoleMethods();
11
-
12
- runInTempDir();
13
-
14
- afterEach(async () => {
15
- // Force a tick to ensure that all promises resolve
16
- await endEventLoop();
17
- });
18
-
19
- it("should throw an error if no worker script and no Functions directory was found", async () => {
20
- await expect(runWrangler("pages functions build")).rejects.toThrowError();
21
- expect(std.err).toContain("Could not find anything to build.");
22
- });
23
-
24
- it("should build functions", async () => {
25
- /* ---------------------------- */
26
- /* Set up Functions */
27
- /* ---------------------------- */
28
- mkdirSync("functions");
29
- writeFileSync(
30
- "functions/hello.js",
31
- `
32
- export async function onRequest() {
33
- return new Response("Hello from Pages Functions");
34
- }
35
- `
36
- );
37
-
38
- /* --------------------------------- */
39
- /* Run cmd & make assertions */
40
- /* --------------------------------- */
41
- await runWrangler(`pages functions build`);
42
-
43
- expect(existsSync("_worker.bundle")).toBe(true);
44
- expect(std.out).toMatchInlineSnapshot(`
45
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
46
- ✨ Compiled Worker successfully"
47
- `);
48
- expect(std.err).toMatchInlineSnapshot(`""`);
49
- });
50
-
51
- it("should include any external modules imported by functions in the output bundle", async () => {
52
- /* ---------------------------- */
53
- /* Set up wasm files */
54
- /* ---------------------------- */
55
- mkdirSync("wasm");
56
- writeFileSync("wasm/greeting.wasm", "Hello");
57
- writeFileSync("wasm/name.wasm", "wasm Functions");
58
-
59
- /* ---------------------------- */
60
- /* Set up Functions */
61
- /* ---------------------------- */
62
- mkdirSync("functions");
63
- writeFileSync(
64
- "functions/hello.js",
65
- `
66
- import hello from "./../wasm/greeting.wasm";
67
- import name from "./../wasm/name.wasm";
68
-
69
- export async function onRequest() {
70
- const greetingModule = await WebAssembly.instantiate(greeting);
71
- const nameModule = await WebAssembly.instantiate(name);
72
- return new Response(greetingModule.exports.hello + " " + nameModule.exports.name);
73
- }
74
- `
75
- );
76
-
77
- /* --------------------------------- */
78
- /* Run cmd & make assertions */
79
- /* --------------------------------- */
80
- await runWrangler(`pages functions build --outfile=_worker.bundle`);
81
-
82
- expect(existsSync("_worker.bundle")).toBe(true);
83
- expect(std.out).toMatchInlineSnapshot(`
84
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
85
- ✨ Compiled Worker successfully"
86
- `);
87
-
88
- // some values in workerBundleContents, such as the undici form boundary
89
- // or the file hashes, are randomly generated. Let's replace them
90
- // with static values so we can test the file contents
91
- const workerBundleContents = readFileSync("_worker.bundle", "utf-8");
92
- const workerBundleWithConstantData = replaceRandomWithConstantData(
93
- workerBundleContents,
94
- [
95
- [/------formdata-undici-0.[0-9]*/g, "------formdata-undici-0.test"],
96
- [/functionsWorker-0.[0-9]*.js/g, "functionsWorker-0.test.js"],
97
- [/[0-9a-z]*-greeting.wasm/g, "test-greeting.wasm"],
98
- [/[0-9a-z]*-name.wasm/g, "test-name.wasm"],
99
- ]
100
- );
101
-
102
- // check we appended the metadata
103
- expect(workerBundleWithConstantData).toContain(
104
- `Content-Disposition: form-data; name="metadata"`
105
- );
106
- expect(workerBundleWithConstantData).toContain(
107
- `{"main_module":"functionsWorker-0.test.js"}`
108
- );
109
-
110
- // check we appended the compiled Worker
111
- expect(workerBundleWithConstantData).toContain(
112
- `Content-Disposition: form-data; name="functionsWorker-0.test.js"; filename="functionsWorker-0.test.js"`
113
- );
114
-
115
- // check we appended the wasm modules
116
- expect(workerBundleWithConstantData).toContain(
117
- `Content-Disposition: form-data; name="./test-greeting.wasm"; filename="./test-greeting.wasm"`
118
- );
119
- expect(workerBundleWithConstantData).toContain(
120
- `Content-Disposition: form-data; name="./test-name.wasm"; filename="./test-name.wasm"`
121
- );
122
- expect(workerBundleWithConstantData).toContain(`Hello`);
123
- expect(workerBundleWithConstantData).toContain(`wasm Functions`);
124
-
125
- expect(std.err).toMatchInlineSnapshot(`""`);
126
- });
127
-
128
- it("should output a directory with --outdir", async () => {
129
- /* ---------------------------- */
130
- /* Set up wasm files */
131
- /* ---------------------------- */
132
- mkdirSync("wasm");
133
- writeFileSync("wasm/greeting.wasm", "Hello");
134
- writeFileSync("wasm/name.wasm", "wasm Functions");
135
-
136
- /* ---------------------------- */
137
- /* Set up Functions */
138
- /* ---------------------------- */
139
- mkdirSync("functions");
140
- writeFileSync(
141
- "functions/hello.js",
142
- `
143
- import hello from "./../wasm/greeting.wasm";
144
- import name from "./../wasm/name.wasm";
145
-
146
- export async function onRequest() {
147
- const greetingModule = await WebAssembly.instantiate(greeting);
148
- const nameModule = await WebAssembly.instantiate(name);
149
- return new Response(greetingModule.exports.hello + " " + nameModule.exports.name);
150
- }
151
- `
152
- );
153
-
154
- /* --------------------------------- */
155
- /* Run cmd & make assertions */
156
- /* --------------------------------- */
157
- await runWrangler(`pages functions build --outdir=dist`);
158
-
159
- expect(existsSync("dist")).toBe(true);
160
- expect(std.out).toMatchInlineSnapshot(`
161
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
162
- ✨ Compiled Worker successfully"
163
- `);
164
-
165
- expect(execSync("ls dist", { encoding: "utf-8" })).toMatchInlineSnapshot(`
166
- "e8f0f80fe25d71a0fc2b9a08c877020211192308-name.wasm
167
- f7ff9e8b7bb2e09b70935a5d785e0cc5d9d0abf0-greeting.wasm
168
- index.js
169
- "
170
- `);
171
- });
172
-
173
- it("should build _worker.js", async () => {
174
- /* ---------------------------- */
175
- /* Set up js files */
176
- /* ---------------------------- */
177
- mkdirSync("utils");
178
- writeFileSync(
179
- "utils/meaning-of-life.js",
180
- `
181
- export const MEANING_OF_LIFE = 21;
182
- `
183
- );
184
-
185
- /* ---------------------------- */
186
- /* Set up _worker.js */
187
- /* ---------------------------- */
188
- mkdirSync("public");
189
- writeFileSync(
190
- "public/_worker.js",
191
- `
192
- import { MEANING_OF_LIFE } from "./../utils/meaning-of-life.js";
193
-
194
- export default {
195
- async fetch(request, env) {
196
- return new Response("Hello from _worker.js. The meaning of life is " + MEANING_OF_LIFE);
197
- },
198
- };`
199
- );
200
-
201
- /* --------------------------------- */
202
- /* Run cmd & make assertions */
203
- /* --------------------------------- */
204
- await runWrangler(
205
- `pages functions build --build-output-directory=public --outfile=_worker.bundle`
206
- );
207
- expect(existsSync("_worker.bundle")).toBe(true);
208
- expect(std.out).toMatchInlineSnapshot(`
209
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
210
- ✨ Compiled Worker successfully"
211
- `);
212
-
213
- // some values in workerBundleContents, such as the undici form boundary
214
- // or the file hashes, are randomly generated. Let's replace them
215
- // with static values so we can test the file contents
216
- const workerBundleContents = readFileSync("_worker.bundle", "utf-8");
217
- const workerBundleWithConstantData = replaceRandomWithConstantData(
218
- workerBundleContents,
219
- [
220
- [/------formdata-undici-0.[0-9]*/g, "------formdata-undici-0.test"],
221
- [/functionsWorker-0.[0-9]*.js/g, "functionsWorker-0.test.js"],
222
- ]
223
- );
224
-
225
- expect(workerBundleWithConstantData).toMatchInlineSnapshot(`
226
- "------formdata-undici-0.test
227
- Content-Disposition: form-data; name=\\"metadata\\"
228
-
229
- {\\"main_module\\":\\"functionsWorker-0.test.js\\"}
230
- ------formdata-undici-0.test
231
- Content-Disposition: form-data; name=\\"functionsWorker-0.test.js\\"; filename=\\"functionsWorker-0.test.js\\"
232
- Content-Type: application/javascript+module
233
-
234
- // ../utils/meaning-of-life.js
235
- var MEANING_OF_LIFE = 21;
236
-
237
- // _worker.js
238
- var worker_default = {
239
- async fetch(request, env) {
240
- return new Response(\\"Hello from _worker.js. The meaning of life is \\" + MEANING_OF_LIFE);
241
- }
242
- };
243
- export {
244
- worker_default as default
245
- };
246
-
247
- ------formdata-undici-0.test--"
248
- `);
249
- expect(std.err).toMatchInlineSnapshot(`""`);
250
- });
251
-
252
- it("should include all external modules imported by _worker.js in the output bundle, when bundling _worker.js", async () => {
253
- /* ---------------------------- */
254
- /* Set up wasm files */
255
- /* ---------------------------- */
256
- mkdirSync("wasm");
257
- writeFileSync("wasm/greeting.wasm", "Hello");
258
- writeFileSync("wasm/name.wasm", "wasm _worker.js");
259
-
260
- /* ---------------------------- */
261
- /* Set up _worker.js */
262
- /* ---------------------------- */
263
- mkdirSync("public");
264
- writeFileSync(
265
- "public/_worker.js",
266
- `
267
- import greeting from "./../wasm/greeting.wasm";
268
- import name from "./../wasm/name.wasm";
269
-
270
- export default {
271
- async fetch(request, env) {
272
- const greetingModule = await WebAssembly.instantiate(greeting);
273
- const nameModule = await WebAssembly.instantiate(name);
274
- return new Response(greetingModule.exports.hello + " " + nameModule.exports.name + "!");
275
- },
276
- };`
277
- );
278
-
279
- /* --------------------------------- */
280
- /* Run cmd & make assertions */
281
- /* --------------------------------- */
282
- await runWrangler(`pages functions build --build-output-directory=public`);
283
-
284
- // built to _worker.js by default
285
- expect(existsSync("_worker.bundle")).toBe(true);
286
- expect(std.out).toMatchInlineSnapshot(`
287
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
288
- ✨ Compiled Worker successfully"
289
- `);
290
-
291
- // some values in workerBundleContents, such as the undici form boundary
292
- // or the file hashes, are randomly generated. Let's replace them
293
- // with static values so we can test the file contents
294
- const workerBundleContents = readFileSync("_worker.bundle", "utf-8");
295
- const workerBundleWithConstantData = replaceRandomWithConstantData(
296
- workerBundleContents,
297
- [
298
- [/------formdata-undici-0.[0-9]*/g, "------formdata-undici-0.test"],
299
- [/functionsWorker-0.[0-9]*.js/g, "functionsWorker-0.test.js"],
300
- [/[0-9a-z]*-greeting.wasm/g, "test-greeting.wasm"],
301
- [/[0-9a-z]*-name.wasm/g, "test-name.wasm"],
302
- ]
303
- );
304
-
305
- // check we appended the metadata
306
- expect(workerBundleWithConstantData).toContain(
307
- `Content-Disposition: form-data; name="metadata"`
308
- );
309
- expect(workerBundleWithConstantData).toContain(
310
- `{"main_module":"functionsWorker-0.test.js"}`
311
- );
312
-
313
- // check we appended the wasm modules
314
- expect(workerBundleWithConstantData).toContain(
315
- `Content-Disposition: form-data; name="./test-greeting.wasm"; filename="./test-greeting.wasm"`
316
- );
317
- expect(workerBundleWithConstantData).toContain(
318
- `Content-Disposition: form-data; name="./test-name.wasm"; filename="./test-name.wasm"`
319
- );
320
- expect(workerBundleWithConstantData).toContain(`Hello`);
321
- expect(workerBundleWithConstantData).toContain(`wasm _worker.js`);
322
-
323
- expect(std.err).toMatchInlineSnapshot(`""`);
324
- });
325
-
326
- it("should build _worker.js over /functions, if both are present", async () => {
327
- /* ---------------------------- */
328
- /* Set up _worker.js */
329
- /* ---------------------------- */
330
- mkdirSync("public");
331
- writeFileSync(
332
- "public/_worker.js",
333
- `
334
- export default {
335
- async fetch(request, env) {
336
- return new Response("Hello from _worker.js");
337
- },
338
- };`
339
- );
340
-
341
- /* ---------------------------- */
342
- /* Set up Functions */
343
- /* ---------------------------- */
344
- mkdirSync("functions");
345
- writeFileSync(
346
- "functions/hello.js",
347
- `
348
- export async function onRequest() {
349
- return new Response("Hello from Pages Functions");
350
- }
351
- `
352
- );
353
-
354
- /* --------------------------------- */
355
- /* Run cmd & make assertions */
356
- /* --------------------------------- */
357
- await runWrangler(`pages functions build --outfile=public/_worker.bundle`);
358
-
359
- expect(existsSync("public/_worker.bundle")).toBe(true);
360
- expect(std.out).toMatchInlineSnapshot(`
361
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
362
- ✨ Compiled Worker successfully"
363
- `);
364
-
365
- // some values in workerBundleContents, such as the undici form boundary
366
- // or the file hashes, are randomly generated. Let's replace them
367
- // with static values so we can test the file contents
368
- const workerBundleContents = readFileSync("public/_worker.bundle", "utf-8");
369
- const workerBundleWithConstantData = replaceRandomWithConstantData(
370
- workerBundleContents,
371
- [
372
- [/------formdata-undici-0.[0-9]*/g, "------formdata-undici-0.test"],
373
- [/functionsWorker-0.[0-9]*.js/g, "functionsWorker-0.test.js"],
374
- ]
375
- );
376
-
377
- expect(workerBundleWithConstantData).toMatchInlineSnapshot(`
378
- "------formdata-undici-0.test
379
- Content-Disposition: form-data; name=\\"metadata\\"
380
-
381
- {\\"main_module\\":\\"functionsWorker-0.test.js\\"}
382
- ------formdata-undici-0.test
383
- Content-Disposition: form-data; name=\\"functionsWorker-0.test.js\\"; filename=\\"functionsWorker-0.test.js\\"
384
- Content-Type: application/javascript+module
385
-
386
- // _worker.js
387
- var worker_default = {
388
- async fetch(request, env) {
389
- return new Response(\\"Hello from _worker.js\\");
390
- }
391
- };
392
- export {
393
- worker_default as default
394
- };
395
-
396
- ------formdata-undici-0.test--"
397
- `);
398
-
399
- expect(std.err).toMatchInlineSnapshot(`""`);
400
- });
401
-
402
- it("should leave Node.js imports when the `nodejs_compat` compatibility flag is set", async () => {
403
- mkdirSync("functions");
404
- writeFileSync(
405
- "functions/hello.js",
406
- `
407
- import { AsyncLocalStorage } from 'node:async_hooks';
408
-
409
- export async function onRequest() {
410
- console.log(AsyncLocalStorage);
411
- return new Response("Hello from Pages Functions");
412
- }
413
- `
414
- );
415
-
416
- await runWrangler(
417
- `pages functions build --outfile=public/_worker.bundle --compatibility-flag=nodejs_compat`
418
- );
419
-
420
- expect(existsSync("public/_worker.bundle")).toBe(true);
421
- expect(std.out).toMatchInlineSnapshot(`
422
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
423
- ✨ Compiled Worker successfully"
424
- `);
425
-
426
- expect(readFileSync("public/_worker.bundle", "utf-8")).toContain(
427
- `import { AsyncLocalStorage } from "node:async_hooks";`
428
- );
429
- });
430
-
431
- it("should error at Node.js imports when the `nodejs_compat` compatibility flag is not set", async () => {
432
- mkdirSync("functions");
433
- writeFileSync(
434
- "functions/hello.js",
435
- `
436
- import { AsyncLocalStorage } from 'node:async_hooks';
437
-
438
- export async function onRequest() {
439
- console.log(AsyncLocalStorage);
440
- return new Response("Hello from Pages Functions");
441
- }
442
- `
443
- );
444
-
445
- await expect(
446
- runWrangler(`pages functions build --outfile=public/_worker.bundle`)
447
- ).rejects.toThrowErrorMatchingInlineSnapshot(`
448
- "Build failed with 1 error:
449
- hello.js:2:36: ERROR: Could not resolve \\"node:async_hooks\\""
450
- `);
451
- expect(std.err).toContain(
452
- 'The package "node:async_hooks" wasn\'t found on the file system but is built into node.'
453
- );
454
- expect(std.err).toContain(
455
- 'Add the "nodejs_compat" compatibility flag to your Pages project to enable Node.js compatibility.'
456
- );
457
- });
458
-
459
- it("should compile a _worker.js/ directory", async () => {
460
- mkdirSync("public");
461
- mkdirSync("public/_worker.js");
462
- writeFileSync(
463
- "public/_worker.js/index.js",
464
- `
465
- import { cat } from "./cat.js";
466
-
467
- export default {
468
- async fetch(request, env) {
469
- return new Response("Hello from _worker.js/index.js" + cat);
470
- },
471
- };`
472
- );
473
- writeFileSync(
474
- "public/_worker.js/cat.js",
475
- `
476
- export const cat = "cat";`
477
- );
478
-
479
- await runWrangler(`pages functions build --outfile=public/_worker.bundle`);
480
-
481
- expect(existsSync("public/_worker.bundle")).toBe(true);
482
- expect(std.out).toMatchInlineSnapshot(`
483
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
484
- ✨ Compiled Worker successfully"
485
- `);
486
-
487
- const workerBundleContents = readFileSync("public/_worker.bundle", "utf-8");
488
- const workerBundleWithConstantData = replaceRandomWithConstantData(
489
- workerBundleContents,
490
- [
491
- [/------formdata-undici-0.[0-9]*/g, "------formdata-undici-0.test"],
492
- [/bundledWorker-0.[0-9]*.mjs/g, "bundledWorker-0.test.mjs"],
493
- [/bundledWorker-0.[0-9]*.map/g, "bundledWorker-0.test.map"],
494
- ]
495
- );
496
-
497
- expect(workerBundleWithConstantData).toMatchInlineSnapshot(`
498
- "------formdata-undici-0.test
499
- Content-Disposition: form-data; name=\\"metadata\\"
500
-
501
- {\\"main_module\\":\\"bundledWorker-0.test.mjs\\"}
502
- ------formdata-undici-0.test
503
- Content-Disposition: form-data; name=\\"bundledWorker-0.test.mjs\\"; filename=\\"bundledWorker-0.test.mjs\\"
504
- Content-Type: application/javascript+module
505
-
506
- import { cat } from \\"./cat.js\\";
507
- var worker_default = {
508
- async fetch(request, env) {
509
- return new Response(\\"Hello from _worker.js/index.js\\" + cat);
510
- }
511
- };
512
- export {
513
- worker_default as default
514
- };
515
- //# sourceMappingURL=bundledWorker-0.test.mjs.map
516
-
517
- ------formdata-undici-0.test
518
- Content-Disposition: form-data; name=\\"cat.js\\"; filename=\\"cat.js\\"
519
- Content-Type: application/javascript+module
520
-
521
-
522
- export const cat = \\"cat\\";
523
- ------formdata-undici-0.test--"
524
- `);
525
-
526
- expect(std.err).toMatchInlineSnapshot(`""`);
527
- });
528
- });
@@ -1,81 +0,0 @@
1
- import { endEventLoop } from "../helpers/end-event-loop";
2
- import { mockConsoleMethods } from "../helpers/mock-console";
3
- import { runInTempDir } from "../helpers/run-in-tmp";
4
- import { runWrangler } from "../helpers/run-wrangler";
5
-
6
- describe("pages", () => {
7
- const std = mockConsoleMethods();
8
-
9
- runInTempDir();
10
-
11
- afterEach(async () => {
12
- // Force a tick to ensure that all promises resolve
13
- await endEventLoop();
14
- });
15
-
16
- it("should display a list of available subcommands, for pages with no subcommand", async () => {
17
- await runWrangler("pages");
18
- await endEventLoop();
19
-
20
- expect(std.out).toMatchInlineSnapshot(`
21
- "wrangler pages
22
-
23
- ⚡️ Configure Cloudflare Pages
24
-
25
- Commands:
26
- wrangler pages dev [directory] [-- command..] 🧑‍💻 Develop your full-stack Pages application locally
27
- wrangler pages project ⚡️ Interact with your Pages projects
28
- wrangler pages deployment 🚀 Interact with the deployments of a project
29
- wrangler pages publish [directory] 🆙 Publish a directory of static assets as a Pages deployment
30
-
31
- Flags:
32
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
33
- -c, --config Path to .toml configuration file [string]
34
- -e, --env Environment to use for operations and .env files [string]
35
- -h, --help Show help [boolean]
36
- -v, --version Show version number [boolean]
37
-
38
- 🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose"
39
- `);
40
- });
41
-
42
- describe("beta message for subcommands", () => {
43
- it("should display for pages:dev", async () => {
44
- await expect(
45
- runWrangler("pages dev")
46
- ).rejects.toThrowErrorMatchingInlineSnapshot(
47
- `"Must specify a directory of static assets to serve or a command to run or a proxy port."`
48
- );
49
-
50
- expect(std.out).toMatchInlineSnapshot(`
51
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
52
-
53
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
54
- `);
55
- });
56
-
57
- it("should display for pages:functions:build", async () => {
58
- await expect(runWrangler("pages functions build")).rejects.toThrowError();
59
-
60
- expect(std.out).toMatchInlineSnapshot(`
61
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
62
-
63
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
64
- `);
65
- });
66
-
67
- it("should display for pages:functions:optimize-routes", async () => {
68
- await expect(
69
- runWrangler(
70
- 'pages functions optimize-routes --routes-path="/build/_routes.json" --output-routes-path="/build/_optimized-routes.json"'
71
- )
72
- ).rejects.toThrowError();
73
-
74
- expect(std.out).toMatchInlineSnapshot(`
75
- "🚧 'wrangler pages <command>' is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose
76
-
77
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
78
- `);
79
- });
80
- });
81
- });
@@ -1,63 +0,0 @@
1
- import { rest } from "msw";
2
- import { endEventLoop } from "../helpers/end-event-loop";
3
- import { mockAccountId, mockApiToken } from "./../helpers/mock-account-id";
4
- import { mockConsoleMethods } from "./../helpers/mock-console";
5
- import { msw } from "./../helpers/msw";
6
- import { runInTempDir } from "./../helpers/run-in-tmp";
7
- import { runWrangler } from "./../helpers/run-wrangler";
8
-
9
- describe("project create", () => {
10
- const std = mockConsoleMethods();
11
-
12
- runInTempDir();
13
- mockAccountId();
14
- mockApiToken();
15
-
16
- afterEach(async () => {
17
- // Force a tick to ensure that all promises resolve
18
- await endEventLoop();
19
- // Reset MSW after tick to ensure that all requests have been handled
20
- msw.resetHandlers();
21
- msw.restoreHandlers();
22
- });
23
-
24
- it("should create a project with a production branch", async () => {
25
- msw.use(
26
- rest.post(
27
- "*/accounts/:accountId/pages/projects",
28
- async (req, res, ctx) => {
29
- const body = await req.json();
30
-
31
- expect(req.params.accountId).toEqual("some-account-id");
32
- expect(body).toEqual({
33
- name: "a-new-project",
34
- production_branch: "main",
35
- });
36
-
37
- return res.once(
38
- ctx.status(200),
39
- ctx.json({
40
- success: true,
41
- errors: [],
42
- messages: [],
43
- result: {
44
- name: "a-new-project",
45
- subdomain: "a-new-project.pages.dev",
46
- production_branch: "main",
47
- },
48
- })
49
- );
50
- }
51
- )
52
- );
53
-
54
- await runWrangler(
55
- "pages project create a-new-project --production-branch=main"
56
- );
57
-
58
- expect(std.out).toMatchInlineSnapshot(`
59
- "✨ Successfully created the 'a-new-project' project. It will be available at https://a-new-project.pages.dev/ once you create your first deployment.
60
- To deploy a folder of assets, run 'wrangler pages publish [directory]'."
61
- `);
62
- });
63
- });