wrangler 2.19.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 +160 -75
  15. package/wrangler-dist/cli.js +61843 -65907
  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 -4509
  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 -452
  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 -955
  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 -958
  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 -316
  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 -76
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -355
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -908
  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 -618
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2342
  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 -359
  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 -600
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -948
  179. package/src/dev/remote.tsx +0 -632
  180. package/src/dev/start-server.ts +0 -534
  181. package/src/dev/use-esbuild.ts +0 -203
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -929
  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 -337
  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 -1032
  200. package/src/inspect.ts +0 -782
  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 -410
  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 -716
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -113
  232. package/src/pages/functions/buildWorker.ts +0 -291
  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 -1060
  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 -376
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -406
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -122
  281. package/src/traverse-module-graph.ts +0 -53
  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 -274
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
@@ -1,61 +0,0 @@
1
- /*! Read blob sync in NodeJS. MIT License. Jimmy Wärting <https://jimmy.warting.se/opensource>
2
- * Special Thanks to Jimmy Wärting helping in https://github.com/nodejs/undici/issues/1830
3
- */
4
- const { join } = require("path");
5
- const {
6
- Worker,
7
- receiveMessageOnPort,
8
- MessageChannel,
9
- } = require("worker_threads");
10
-
11
- /**
12
- * blob-worker & read-file-sync are part of a polyfill to synchronously read a blob in NodeJS
13
- * this is needed for MSW FormData patching to work and support Blobs, serializing them to a string before recreating the FormData.
14
- */
15
- function read(blob) {
16
- const subChannel = new MessageChannel();
17
- const signal = new Int32Array(new SharedArrayBuffer(4));
18
- signal[0] = 0;
19
-
20
- const path = join(__dirname, "blob-worker.cjs");
21
-
22
- const worker = new Worker(path, {
23
- transferList: [subChannel.port1],
24
- workerData: {
25
- signal,
26
- port: subChannel.port1,
27
- blob,
28
- },
29
- });
30
-
31
- // Sleep until the other thread sets signal[0] to 1
32
- Atomics.wait(signal, 0, 0);
33
-
34
- // Close the worker thread
35
- worker.terminate();
36
-
37
- return receiveMessageOnPort(subChannel.port2)?.message;
38
- }
39
-
40
- class FileReaderSync {
41
- readAsArrayBuffer(blob) {
42
- this.result = read(blob);
43
- }
44
-
45
- readAsDataURL(blob) {
46
- const ab = read(blob);
47
- this.result = `data:${blob.type};base64,${Buffer.from(ab).toString(
48
- "base64"
49
- )}`;
50
- }
51
-
52
- readAsText(blob) {
53
- const ab = read(blob);
54
- this.result = new TextDecoder().decode(ab);
55
- }
56
-
57
- // Should not be used, use readAsArrayBuffer instead
58
- // readAsBinaryString(blob) { ... }
59
- }
60
-
61
- exports.FileReaderSync = FileReaderSync;
@@ -1,38 +0,0 @@
1
- import * as fs from "node:fs";
2
- import os from "node:os";
3
- import * as path from "node:path";
4
- import { reinitialiseAuthTokens } from "../../user";
5
-
6
- const originalCwd = process.cwd();
7
-
8
- export function runInTempDir({ homedir } = { homedir: "./home" }) {
9
- let tmpDir: string;
10
-
11
- beforeEach(() => {
12
- // Use realpath because the temporary path can point to a symlink rather than the actual path.
13
- tmpDir = fs.realpathSync(
14
- fs.mkdtempSync(path.join(os.tmpdir(), "wrangler-tests"))
15
- );
16
-
17
- process.chdir(tmpDir);
18
- // The path that is returned from `homedir()` should be absolute.
19
- const absHomedir = path.resolve(tmpDir, homedir);
20
- // Override where the home directory is so that we can write our own user config,
21
- // without destroying the real thing.
22
- fs.mkdirSync(absHomedir, { recursive: true });
23
- // Note it is very important that we use the "default" value from "node:os" (e.g. `import os from "node:os";`)
24
- // rather than an alias to the module (e.g. `import * as os from "node:os";`).
25
- // This is because the module gets transpiled so that the "method" `homedir()` gets converted to a
26
- // getter that is not configurable (and so cannot be spied upon).
27
- jest.spyOn(os, "homedir")?.mockReturnValue(absHomedir);
28
- // Now that we have changed the home directory location, we must reinitialize the user auth state
29
- reinitialiseAuthTokens();
30
- });
31
-
32
- afterEach(() => {
33
- if (fs.existsSync(tmpDir)) {
34
- process.chdir(originalCwd);
35
- fs.rmSync(tmpDir, { recursive: true });
36
- }
37
- });
38
- }
@@ -1,16 +0,0 @@
1
- import { main } from "../../index";
2
- import { normalizeSlashes, stripTimings } from "./mock-console";
3
-
4
- /**
5
- * A helper to 'run' wrangler commands for tests.
6
- */
7
- export async function runWrangler(cmd?: string) {
8
- try {
9
- await main(cmd?.split(" ") ?? []);
10
- } catch (err) {
11
- if (err instanceof Error) {
12
- err.message = normalizeSlashes(stripTimings(err.message));
13
- }
14
- throw err;
15
- }
16
- }
@@ -1,28 +0,0 @@
1
- export type PatternReplacementPair = [string | RegExp, string];
2
-
3
- /**
4
- * Sometimes, we might need to test strings that contain dynamic |
5
- * random | generated data (such as file hashes, IDs, etc.).
6
- *
7
- * This helper function replaces the dynamic parts of such strings with
8
- * static values, thus enabling us to properly test the contents of the
9
- * string.
10
- *
11
- * see https://jestjs.io/docs/snapshot-testing#property-matchers
12
- */
13
- export function replaceRandomWithConstantData(
14
- stringWithRandomData: string,
15
- patternReplacementPairs: Array<PatternReplacementPair>
16
- ) {
17
- let stringWithConstantData = stringWithRandomData;
18
-
19
- patternReplacementPairs.forEach(
20
- (pair) =>
21
- (stringWithConstantData = stringWithConstantData.replace(
22
- pair[0], // pattern
23
- pair[1] // replacement
24
- ))
25
- );
26
-
27
- return stringWithConstantData;
28
- }
@@ -1 +0,0 @@
1
- name = 'child'
@@ -1,5 +0,0 @@
1
- export default {
2
- async fetch() {
3
- return new Response("Hello World!");
4
- },
5
- };
@@ -1 +0,0 @@
1
- name = 'hello-world'
@@ -1,11 +0,0 @@
1
- export default {
2
- async fetch(req, env) {
3
- const resp = await env.CHILD.fetch(req);
4
- const text = await resp.text();
5
- // TODO: we should capture console logs when running `dev` programmatically
6
- // (and locally) and expose it on the DevWorker object instead of allowing
7
- // the log to appear in the output of the test runner.
8
- // console.log("text: ", text);
9
- return new Response(`Parent worker sees: ${text}`);
10
- },
11
- };
@@ -1,5 +0,0 @@
1
- name = 'parent'
2
-
3
- [[services]]
4
- binding = "CHILD"
5
- service = 'child'
@@ -1,31 +0,0 @@
1
- import fs from "node:fs";
2
-
3
- /** Write a mock Worker script to disk. */
4
- export function writeWorkerSource({
5
- basePath = ".",
6
- format = "js",
7
- type = "esm",
8
- }: {
9
- basePath?: string;
10
- format?: "js" | "ts" | "jsx" | "tsx" | "mjs";
11
- type?: "esm" | "sw";
12
- } = {}) {
13
- if (basePath !== ".") {
14
- fs.mkdirSync(basePath, { recursive: true });
15
- }
16
- fs.writeFileSync(
17
- `${basePath}/index.${format}`,
18
- type === "esm"
19
- ? `import { foo } from "./another";
20
- export default {
21
- async fetch(request) {
22
- return new Response('Hello' + foo);
23
- },
24
- };`
25
- : `import { foo } from "./another";
26
- addEventListener('fetch', event => {
27
- event.respondWith(new Response('Hello' + foo));
28
- })`
29
- );
30
- fs.writeFileSync(`${basePath}/another.${format}`, `export const foo = 100;`);
31
- }
@@ -1,17 +0,0 @@
1
- import * as fs from "fs";
2
- import TOML from "@iarna/toml";
3
- import type { RawConfig } from "../../config";
4
-
5
- /** Write a mock wrangler.toml file to disk. */
6
- export default function writeWranglerToml(config: RawConfig = {}) {
7
- fs.writeFileSync(
8
- "./wrangler.toml",
9
- TOML.stringify({
10
- compatibility_date: "2022-01-12",
11
- name: "test-name",
12
- ...(config as TOML.JsonMap),
13
- }),
14
-
15
- "utf-8"
16
- );
17
- }
@@ -1,163 +0,0 @@
1
- import fs from "node:fs";
2
- import os from "node:os";
3
- import path from "node:path";
4
- import { getGlobalWranglerConfigPath } from "../global-wrangler-config-path";
5
- import { getHttpsOptions } from "../https-options";
6
- import { mockConsoleMethods } from "./helpers/mock-console";
7
- import { runInTempDir } from "./helpers/run-in-tmp";
8
-
9
- describe("getHttpsOptions()", () => {
10
- runInTempDir();
11
- const std = mockConsoleMethods();
12
-
13
- it("should use cached values if they have not expired", async () => {
14
- fs.mkdirSync(path.resolve(getGlobalWranglerConfigPath(), "local-cert"), {
15
- recursive: true,
16
- });
17
- fs.writeFileSync(
18
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/key.pem"),
19
- "PRIVATE KEY"
20
- );
21
- fs.writeFileSync(
22
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/cert.pem"),
23
- "PUBLIC KEY"
24
- );
25
- const result = await getHttpsOptions();
26
- expect(result.key).toEqual("PRIVATE KEY");
27
- expect(result.cert).toEqual("PUBLIC KEY");
28
- expect(std.out).toMatchInlineSnapshot(`""`);
29
- expect(std.warn).toMatchInlineSnapshot(`""`);
30
- expect(std.err).toMatchInlineSnapshot(`""`);
31
- });
32
-
33
- it("should generate and cache new keys if none are cached", async () => {
34
- const result = await getHttpsOptions();
35
- const key = fs.readFileSync(
36
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/key.pem"),
37
- "utf8"
38
- );
39
- const cert = fs.readFileSync(
40
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/cert.pem"),
41
- "utf8"
42
- );
43
- expect(result.key).toEqual(key);
44
- expect(result.cert).toEqual(cert);
45
- expect(std.out).toMatchInlineSnapshot(
46
- `"Generating new self-signed certificate..."`
47
- );
48
- expect(std.warn).toMatchInlineSnapshot(`""`);
49
- expect(std.err).toMatchInlineSnapshot(`""`);
50
- });
51
-
52
- it("should generate and cache new keys if cached files have expired", async () => {
53
- fs.mkdirSync(path.resolve(getGlobalWranglerConfigPath(), "local-cert"), {
54
- recursive: true,
55
- });
56
- const ORIGINAL_KEY = "EXPIRED PRIVATE KEY";
57
- const ORIGINAL_CERT = "EXPIRED PUBLIC KEY";
58
- fs.writeFileSync(
59
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/key.pem"),
60
- ORIGINAL_KEY
61
- );
62
- fs.writeFileSync(
63
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/cert.pem"),
64
- ORIGINAL_CERT
65
- );
66
- mockStatSync(/\.pem$/, { mtimeMs: new Date(2000).valueOf() });
67
-
68
- const result = await getHttpsOptions();
69
- const key = fs.readFileSync(
70
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/key.pem"),
71
- "utf8"
72
- );
73
- const cert = fs.readFileSync(
74
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/cert.pem"),
75
- "utf8"
76
- );
77
- expect(key).not.toEqual(ORIGINAL_KEY);
78
- expect(cert).not.toEqual(ORIGINAL_CERT);
79
- expect(result.key).toEqual(key);
80
- expect(result.cert).toEqual(cert);
81
- expect(std.out).toMatchInlineSnapshot(
82
- `"Generating new self-signed certificate..."`
83
- );
84
- expect(std.warn).toMatchInlineSnapshot(`""`);
85
- expect(std.err).toMatchInlineSnapshot(`""`);
86
- });
87
-
88
- it("should warn if not able to write to the cache (legacy config path)", async () => {
89
- fs.mkdirSync(path.join(os.homedir(), ".wrangler"));
90
- mockWriteFileSyncThrow(/\.pem$/);
91
- await getHttpsOptions();
92
- expect(
93
- fs.existsSync(
94
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/key.pem")
95
- )
96
- ).toBe(false);
97
- expect(
98
- fs.existsSync(
99
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/cert.pem")
100
- )
101
- ).toBe(false);
102
- expect(std.out).toMatchInlineSnapshot(
103
- `"Generating new self-signed certificate..."`
104
- );
105
- expect(std.warn).toMatchInlineSnapshot(`
106
- "▲ [WARNING] Unable to cache generated self-signed certificate in home/.wrangler/local-cert.
107
-
108
- ERROR: Cannot write file
109
-
110
- "
111
- `);
112
- expect(std.err).toMatchInlineSnapshot(`""`);
113
- fs.rmSync(path.join(os.homedir(), ".wrangler"), { recursive: true });
114
- });
115
-
116
- it("should warn if not able to write to the cache", async () => {
117
- mockWriteFileSyncThrow(/\.pem$/);
118
- await getHttpsOptions();
119
- expect(
120
- fs.existsSync(
121
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/key.pem")
122
- )
123
- ).toBe(false);
124
- expect(
125
- fs.existsSync(
126
- path.resolve(getGlobalWranglerConfigPath(), "local-cert/cert.pem")
127
- )
128
- ).toBe(false);
129
- expect(std.out).toMatchInlineSnapshot(
130
- `"Generating new self-signed certificate..."`
131
- );
132
- expect(std.warn).toMatchInlineSnapshot(`
133
- "▲ [WARNING] Unable to cache generated self-signed certificate in test-xdg-config/local-cert.
134
-
135
- ERROR: Cannot write file
136
-
137
- "
138
- `);
139
- expect(std.err).toMatchInlineSnapshot(`""`);
140
- });
141
- });
142
-
143
- function mockStatSync(matcher: RegExp, stats: Partial<fs.Stats>) {
144
- const originalStatSync = jest.requireActual("node:fs").statSync;
145
- jest.spyOn(fs, "statSync").mockImplementation((statPath, options) => {
146
- return matcher.test(statPath.toString())
147
- ? (stats as fs.Stats)
148
- : originalStatSync(statPath, options);
149
- });
150
- }
151
-
152
- function mockWriteFileSyncThrow(matcher: RegExp) {
153
- const originalWriteFileSync = jest.requireActual("node:fs").writeFileSync;
154
- jest
155
- .spyOn(fs, "writeFileSync")
156
- .mockImplementation((filePath, data, options) => {
157
- if (matcher.test(filePath.toString())) {
158
- throw new Error("ERROR: Cannot write file");
159
- } else {
160
- return originalWriteFileSync(filePath, data, options);
161
- }
162
- });
163
- }
@@ -1,282 +0,0 @@
1
- import { getPackageManager } from "../package-manager";
2
- import { endEventLoop } from "./helpers/end-event-loop";
3
- import { mockConsoleMethods } from "./helpers/mock-console";
4
- import { runInTempDir } from "./helpers/run-in-tmp";
5
- import { runWrangler } from "./helpers/run-wrangler";
6
- import { writeWorkerSource } from "./helpers/write-worker-source";
7
- import writeWranglerToml from "./helpers/write-wrangler-toml";
8
- import type { PackageManager } from "../package-manager";
9
-
10
- describe("wrangler", () => {
11
- let mockPackageManager: PackageManager;
12
- runInTempDir();
13
-
14
- beforeEach(() => {
15
- mockPackageManager = {
16
- cwd: process.cwd(),
17
- // @ts-expect-error we're making a fake package manager here
18
- type: "mockpm",
19
- addDevDeps: jest.fn(),
20
- install: jest.fn(),
21
- };
22
- (getPackageManager as jest.Mock).mockResolvedValue(mockPackageManager);
23
- });
24
-
25
- const std = mockConsoleMethods();
26
-
27
- describe("no command", () => {
28
- it("should display a list of available commands", async () => {
29
- await runWrangler();
30
-
31
- expect(std.out).toMatchInlineSnapshot(`
32
- "wrangler
33
-
34
- Commands:
35
- wrangler docs [command..] 📚 Open wrangler's docs in your browser
36
- wrangler init [name] 📥 Initialize a basic Worker project, including a wrangler.toml file
37
- wrangler generate [name] [template] ✨ Generate a new Worker project from an existing Worker template. See https://github.com/cloudflare/templates
38
- wrangler dev [script] 👂 Start a local server for developing your worker
39
- wrangler publish [script] 🆙 Publish your Worker to Cloudflare.
40
- wrangler delete [script] 🗑 Delete your Worker from Cloudflare.
41
- wrangler tail [worker] 🦚 Starts a log tailing session for a published Worker.
42
- wrangler secret 🤫 Generate a secret that can be referenced in a Worker
43
- wrangler secret:bulk <json> 🗄️ Bulk upload secrets for a Worker
44
- wrangler kv:namespace 🗂️ Interact with your Workers KV Namespaces
45
- wrangler kv:key 🔑 Individually manage Workers KV key-value pairs
46
- wrangler kv:bulk 💪 Interact with multiple Workers KV key-value pairs at once
47
- wrangler pages ⚡️ Configure Cloudflare Pages
48
- wrangler queues 🇶 Configure Workers Queues
49
- wrangler r2 📦 Interact with an R2 store
50
- wrangler dispatch-namespace 📦 Interact with a dispatch namespace
51
- wrangler d1 🗄 Interact with a D1 database
52
- wrangler constellation 🤖 Interact with Constellation AI models
53
- wrangler pubsub 📮 Interact and manage Pub/Sub Brokers
54
- wrangler mtls-certificate 🪪 Manage certificates used for mTLS connections
55
- wrangler login 🔓 Login to Cloudflare
56
- wrangler logout 🚪 Logout from Cloudflare
57
- wrangler whoami 🕵️ Retrieve your user info and test your auth config
58
- wrangler types 📝 Generate types from bindings & module rules in config
59
- wrangler deployments 🚢 List and view details for deployments
60
- wrangler rollback [deployment-id] 🔙 Rollback a deployment
61
-
62
- Flags:
63
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
64
- -c, --config Path to .toml configuration file [string]
65
- -e, --env Environment to use for operations and .env files [string]
66
- -h, --help Show help [boolean]
67
- -v, --version Show version number [boolean]
68
-
69
- 🚧\`wrangler rollback\` is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose"
70
- `);
71
-
72
- expect(std.err).toMatchInlineSnapshot(`""`);
73
- });
74
- });
75
-
76
- describe("invalid command", () => {
77
- it("should display an error", async () => {
78
- await expect(
79
- runWrangler("invalid-command")
80
- ).rejects.toThrowErrorMatchingInlineSnapshot(
81
- `"Unknown argument: invalid-command"`
82
- );
83
-
84
- expect(std.out).toMatchInlineSnapshot(`
85
- "
86
- wrangler
87
-
88
- Commands:
89
- wrangler docs [command..] 📚 Open wrangler's docs in your browser
90
- wrangler init [name] 📥 Initialize a basic Worker project, including a wrangler.toml file
91
- wrangler generate [name] [template] ✨ Generate a new Worker project from an existing Worker template. See https://github.com/cloudflare/templates
92
- wrangler dev [script] 👂 Start a local server for developing your worker
93
- wrangler publish [script] 🆙 Publish your Worker to Cloudflare.
94
- wrangler delete [script] 🗑 Delete your Worker from Cloudflare.
95
- wrangler tail [worker] 🦚 Starts a log tailing session for a published Worker.
96
- wrangler secret 🤫 Generate a secret that can be referenced in a Worker
97
- wrangler secret:bulk <json> 🗄️ Bulk upload secrets for a Worker
98
- wrangler kv:namespace 🗂️ Interact with your Workers KV Namespaces
99
- wrangler kv:key 🔑 Individually manage Workers KV key-value pairs
100
- wrangler kv:bulk 💪 Interact with multiple Workers KV key-value pairs at once
101
- wrangler pages ⚡️ Configure Cloudflare Pages
102
- wrangler queues 🇶 Configure Workers Queues
103
- wrangler r2 📦 Interact with an R2 store
104
- wrangler dispatch-namespace 📦 Interact with a dispatch namespace
105
- wrangler d1 🗄 Interact with a D1 database
106
- wrangler constellation 🤖 Interact with Constellation AI models
107
- wrangler pubsub 📮 Interact and manage Pub/Sub Brokers
108
- wrangler mtls-certificate 🪪 Manage certificates used for mTLS connections
109
- wrangler login 🔓 Login to Cloudflare
110
- wrangler logout 🚪 Logout from Cloudflare
111
- wrangler whoami 🕵️ Retrieve your user info and test your auth config
112
- wrangler types 📝 Generate types from bindings & module rules in config
113
- wrangler deployments 🚢 List and view details for deployments
114
- wrangler rollback [deployment-id] 🔙 Rollback a deployment
115
-
116
- Flags:
117
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
118
- -c, --config Path to .toml configuration file [string]
119
- -e, --env Environment to use for operations and .env files [string]
120
- -h, --help Show help [boolean]
121
- -v, --version Show version number [boolean]
122
-
123
- 🚧\`wrangler rollback\` is a beta command. Please report any issues to https://github.com/cloudflare/workers-sdk/issues/new/choose"
124
- `);
125
- expect(std.err).toMatchInlineSnapshot(`
126
- "X [ERROR] Unknown argument: invalid-command
127
-
128
- "
129
- `);
130
- });
131
- });
132
-
133
- describe("preview", () => {
134
- it("should throw an error if the deprecated command is used with positional arguments", async () => {
135
- await expect(runWrangler("preview GET")).rejects
136
- .toThrowErrorMatchingInlineSnapshot(`
137
- "Deprecation:
138
- The \`wrangler preview\` command has been deprecated.
139
- Try using \`wrangler dev\` to to try out a worker during development.
140
- "
141
- `);
142
- await expect(runWrangler(`preview GET "SomeBody"`)).rejects
143
- .toThrowErrorMatchingInlineSnapshot(`
144
- "Deprecation:
145
- The \`wrangler preview\` command has been deprecated.
146
- Try using \`wrangler dev\` to to try out a worker during development.
147
- "
148
- `);
149
- });
150
- });
151
-
152
- describe("subcommand implicit help ran on incomplete command execution", () => {
153
- it("no subcommand for 'secret' should display a list of available subcommands", async () => {
154
- await runWrangler("secret");
155
- await endEventLoop();
156
- expect(std.out).toMatchInlineSnapshot(`
157
- "wrangler secret
158
-
159
- 🤫 Generate a secret that can be referenced in a Worker
160
-
161
- Commands:
162
- wrangler secret put <key> Create or update a secret variable for a Worker
163
- wrangler secret delete <key> Delete a secret variable from a Worker
164
- wrangler secret list List all secrets for a Worker
165
-
166
- Flags:
167
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
168
- -c, --config Path to .toml configuration file [string]
169
- -e, --env Environment to use for operations and .env files [string]
170
- -h, --help Show help [boolean]
171
- -v, --version Show version number [boolean]"
172
- `);
173
- });
174
-
175
- it("no subcommand 'kv:namespace' should display a list of available subcommands", async () => {
176
- await runWrangler("kv:namespace");
177
- await endEventLoop();
178
- expect(std.out).toMatchInlineSnapshot(`
179
- "wrangler kv:namespace
180
-
181
- 🗂️ Interact with your Workers KV Namespaces
182
-
183
- Commands:
184
- wrangler kv:namespace create <namespace> Create a new namespace
185
- wrangler kv:namespace list Outputs a list of all KV namespaces associated with your account id.
186
- wrangler kv:namespace delete Deletes a given namespace.
187
-
188
- Flags:
189
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
190
- -c, --config Path to .toml configuration file [string]
191
- -e, --env Environment to use for operations and .env files [string]
192
- -h, --help Show help [boolean]
193
- -v, --version Show version number [boolean]"
194
- `);
195
- });
196
-
197
- it("no subcommand 'kv:key' should display a list of available subcommands", async () => {
198
- await runWrangler("kv:key");
199
- await endEventLoop();
200
- expect(std.out).toMatchInlineSnapshot(`
201
- "wrangler kv:key
202
-
203
- 🔑 Individually manage Workers KV key-value pairs
204
-
205
- Commands:
206
- wrangler kv:key put <key> [value] Writes a single key/value pair to the given namespace.
207
- wrangler kv:key list Outputs a list of all keys in a given namespace.
208
- wrangler kv:key get <key> Reads a single value by key from the given namespace.
209
- wrangler kv:key delete <key> Removes a single key value pair from the given namespace.
210
-
211
- Flags:
212
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
213
- -c, --config Path to .toml configuration file [string]
214
- -e, --env Environment to use for operations and .env files [string]
215
- -h, --help Show help [boolean]
216
- -v, --version Show version number [boolean]"
217
- `);
218
- });
219
-
220
- it("no subcommand 'kv:bulk' should display a list of available subcommands", async () => {
221
- await runWrangler("kv:bulk");
222
- await endEventLoop();
223
- expect(std.out).toMatchInlineSnapshot(`
224
- "wrangler kv:bulk
225
-
226
- 💪 Interact with multiple Workers KV key-value pairs at once
227
-
228
- Commands:
229
- wrangler kv:bulk put <filename> Upload multiple key-value pairs to a namespace
230
- wrangler kv:bulk delete <filename> Delete multiple key-value pairs from a namespace
231
-
232
- Flags:
233
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
234
- -c, --config Path to .toml configuration file [string]
235
- -e, --env Environment to use for operations and .env files [string]
236
- -h, --help Show help [boolean]
237
- -v, --version Show version number [boolean]"
238
- `);
239
- });
240
-
241
- it("no subcommand 'r2' should display a list of available subcommands", async () => {
242
- await runWrangler("r2");
243
- await endEventLoop();
244
- expect(std.out).toMatchInlineSnapshot(`
245
- "wrangler r2
246
-
247
- 📦 Interact with an R2 store
248
-
249
- Commands:
250
- wrangler r2 object Manage R2 objects
251
- wrangler r2 bucket Manage R2 buckets
252
-
253
- Flags:
254
- -j, --experimental-json-config Experimental: Support wrangler.json [boolean]
255
- -c, --config Path to .toml configuration file [string]
256
- -e, --env Environment to use for operations and .env files [string]
257
- -h, --help Show help [boolean]
258
- -v, --version Show version number [boolean]"
259
- `);
260
- });
261
- });
262
-
263
- it("should print a deprecation message for 'build' and then try to run `publish --dry-run --outdir`", async () => {
264
- writeWranglerToml({
265
- main: "index.js",
266
- });
267
- writeWorkerSource();
268
- await runWrangler("build");
269
- await endEventLoop();
270
- expect(std.out).toMatchInlineSnapshot(`
271
- "▲ [WARNING] Deprecation: \`wrangler build\` has been deprecated.
272
-
273
- Please refer to https://developers.cloudflare.com/workers/wrangler/migration/deprecations/#build
274
- for more information.
275
- Attempting to run \`wrangler publish --dry-run --outdir=dist\` for you instead:
276
-
277
-
278
- Total Upload: xx KiB / gzip: xx KiB
279
- --dry-run: exiting now."
280
- `);
281
- });
282
- });