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,237 +0,0 @@
1
- import fs from "node:fs";
2
- import path from "node:path";
3
- import { mockConsoleMethods } from "./helpers/mock-console";
4
- import { mockConfirm } from "./helpers/mock-dialogs";
5
- import { useMockIsTTY } from "./helpers/mock-istty";
6
- import { runInTempDir } from "./helpers/run-in-tmp";
7
- import { runWrangler } from "./helpers/run-wrangler";
8
-
9
- describe("generate", () => {
10
- runInTempDir();
11
- const { setIsTTY } = useMockIsTTY();
12
- const std = mockConsoleMethods();
13
- beforeEach(() => {
14
- setIsTTY(true);
15
- });
16
-
17
- describe("cli functionality", () => {
18
- afterEach(() => {});
19
-
20
- it("defers to `wrangler init` when no template is given", async () => {
21
- mockConfirm(
22
- {
23
- text: "Would you like to use git to manage this Worker?",
24
- result: false,
25
- },
26
- {
27
- text: "No package.json found. Would you like to create one?",
28
- result: false,
29
- }
30
- );
31
- await runWrangler("generate no-template");
32
- expect(std.out).toMatchInlineSnapshot(
33
- `"✨ Created no-template/wrangler.toml"`
34
- );
35
- });
36
-
37
- it("complains when given the --type argument", async () => {
38
- await expect(
39
- runWrangler("generate worker-name worker-template --type rust")
40
- ).rejects.toThrowErrorMatchingInlineSnapshot(
41
- `"The --type option is no longer supported."`
42
- );
43
- });
44
-
45
- it("complains when given the --site argument", async () => {
46
- await expect(runWrangler("generate worker-name worker-template --site"))
47
- .rejects.toThrowErrorMatchingInlineSnapshot(`
48
- "The --site option is no longer supported.
49
- If you wish to create a brand new Worker Sites project then clone the \`worker-sites-template\` starter repository:
50
-
51
- \`\`\`
52
- git clone --depth=1 --branch=wrangler2 https://github.com/cloudflare/worker-sites-template worker-name
53
- cd worker-name
54
- \`\`\`
55
-
56
- Find out more about how to create and maintain Sites projects at https://developers.cloudflare.com/workers/platform/sites.
57
- Have you considered using Cloudflare Pages instead? See https://pages.cloudflare.com/."
58
- `);
59
- });
60
-
61
- it.skip("auto-increments the worker directory name", async () => {
62
- fs.mkdirSync("my-worker");
63
-
64
- expect(fs.existsSync("my-worker-1")).toBe(false);
65
-
66
- await expect(
67
- runWrangler("generate my-worker worker-typescript")
68
- ).resolves.toBeUndefined();
69
-
70
- expect(std.out).toStrictEqual(expect.stringContaining("my-worker-1"));
71
-
72
- expect(readDirectory("my-worker-1")).toMatchObject<Directory>({
73
- ".git": expect.any(Object),
74
- ".gitignore": expect.any(String),
75
- "README.md": expect.stringContaining("Template: worker-typescript"),
76
- "jest.config.json": expect.any(String),
77
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
78
- src: expect.objectContaining({ "index.ts": expect.any(String) }),
79
- test: expect.objectContaining({
80
- "index.test.ts": expect.any(String),
81
- }),
82
- "tsconfig.json": expect.any(String),
83
- "wrangler.toml": expect.any(String),
84
- });
85
- expect(fs.existsSync("my-worker-2")).toBe(false);
86
-
87
- await expect(
88
- runWrangler("generate my-worker worker-typescript")
89
- ).resolves.toBeUndefined();
90
-
91
- expect(std.out).toStrictEqual(expect.stringContaining("my-worker-2"));
92
-
93
- expect(readDirectory("my-worker-2")).toMatchObject<Directory>({
94
- ".git": expect.any(Object),
95
- ".gitignore": expect.any(String),
96
- "README.md": expect.stringContaining("Template: worker-typescript"),
97
- "jest.config.json": expect.any(String),
98
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
99
- src: expect.objectContaining({ "index.ts": expect.any(String) }),
100
- test: expect.objectContaining({
101
- "index.test.ts": expect.any(String),
102
- }),
103
- "tsconfig.json": expect.any(String),
104
- "wrangler.toml": expect.any(String),
105
- });
106
- });
107
- });
108
-
109
- describe("cloning", () => {
110
- it("clones a cloudflare template with sparse checkouts", async () => {
111
- await expect(
112
- runWrangler("generate my-worker worker-typescript")
113
- ).resolves.toBeUndefined();
114
-
115
- expect(readDirectory("my-worker")).toMatchObject<Directory>({
116
- ".git": expect.any(Object),
117
- ".gitignore": expect.any(String),
118
- "README.md": expect.stringContaining("Template: worker-typescript"),
119
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
120
- src: expect.objectContaining({
121
- "index.ts": expect.any(String),
122
- "index.test.ts": expect.any(String),
123
- }),
124
- "tsconfig.json": expect.any(String),
125
- "wrangler.toml": expect.any(String),
126
- });
127
- });
128
-
129
- // mocking out calls to either `isGitInstalled` or `execa("git", ["--version"])`
130
- // was harder than i thought, leaving this for now.
131
- it.todo("clones a cloudflare template with full checkouts");
132
-
133
- it.skip("clones a user/repo template", async () => {
134
- await expect(
135
- runWrangler("generate my-worker caass/wrangler-generate-test-template")
136
- ).resolves.toBeUndefined();
137
-
138
- expect(readDirectory("my-worker")).toMatchObject<Directory>({
139
- ".git": expect.any(Object),
140
- ".gitignore": expect.any(String),
141
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
142
- src: expect.objectContaining({ "index.ts": expect.any(String) }),
143
- "tsconfig.json": expect.any(String),
144
- "wrangler.toml": expect.any(String),
145
- });
146
- });
147
-
148
- it.skip("clones a user/repo/path/to/subdirectory template", async () => {
149
- await expect(
150
- runWrangler("generate my-worker cloudflare/templates/worker-typescript")
151
- ).resolves.toBeUndefined();
152
-
153
- expect(readDirectory("my-worker")).toMatchObject<Directory>({
154
- ".git": expect.any(Object),
155
- ".gitignore": expect.any(String),
156
- "README.md": expect.stringContaining("Template: worker-typescript"),
157
- "jest.config.json": expect.any(String),
158
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
159
- src: expect.objectContaining({ "index.ts": expect.any(String) }),
160
- test: expect.objectContaining({
161
- "index.test.ts": expect.any(String),
162
- }),
163
- "tsconfig.json": expect.any(String),
164
- "wrangler.toml": expect.any(String),
165
- });
166
- });
167
-
168
- it.skip("clones a git@github.com/user/repo template", async () => {
169
- await expect(
170
- runWrangler(
171
- "generate my-worker git@github.com:caass/wrangler-generate-test-template"
172
- )
173
- ).resolves.toBeUndefined();
174
-
175
- expect(readDirectory("my-worker")).toMatchObject<Directory>({
176
- ".git": expect.any(Object),
177
- ".gitignore": expect.any(String),
178
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
179
- src: expect.objectContaining({ "index.ts": expect.any(String) }),
180
- "tsconfig.json": expect.any(String),
181
- "wrangler.toml": expect.any(String),
182
- });
183
- });
184
-
185
- it.skip("clones a git@github.com/user/repo/path/to/subdirectory template", async () => {
186
- await expect(
187
- runWrangler(
188
- "generate my-worker git@github.com:cloudflare/templates/worker-typescript"
189
- )
190
- ).resolves.toBeUndefined();
191
-
192
- expect(readDirectory("my-worker")).toMatchObject<Directory>({
193
- ".git": expect.any(Object),
194
- ".gitignore": expect.any(String),
195
- "README.md": expect.stringContaining("Template: worker-typescript"),
196
- "jest.config.json": expect.any(String),
197
- "package.json": expect.stringContaining("@cloudflare/workers-types"),
198
- src: expect.objectContaining({ "index.ts": expect.any(String) }),
199
- test: expect.objectContaining({
200
- "index.test.ts": expect.any(String),
201
- }),
202
- "tsconfig.json": expect.any(String),
203
- "wrangler.toml": expect.any(String),
204
- });
205
- });
206
- });
207
- });
208
-
209
- type FileName = string;
210
- type FileContents = string;
211
- type Directory = { [key: FileName]: FileContents | Directory };
212
-
213
- function readDirectory(directoryPath: string): Directory {
214
- if (!fs.existsSync(directoryPath)) {
215
- throw new Error(`${directoryPath} does not exist!`);
216
- }
217
-
218
- if (!fs.lstatSync(directoryPath).isDirectory()) {
219
- throw new Error(`${directoryPath} is not a directory!`);
220
- }
221
-
222
- return fs
223
- .readdirSync(directoryPath, { withFileTypes: true })
224
- .reduce((output, child) => {
225
- const childPath = path.join(directoryPath, child.name);
226
-
227
- if (child.isDirectory()) {
228
- output[child.name] = readDirectory(childPath);
229
- } else if (child.isFile()) {
230
- output[child.name] = fs.readFileSync(childPath, { encoding: "utf-8" });
231
- } else {
232
- throw new Error(`${childPath} was not a file or directory!`);
233
- }
234
-
235
- return output;
236
- }, {} as Directory);
237
- }
@@ -1,16 +0,0 @@
1
- import { getHostFromUrl } from "../zones";
2
-
3
- //return the host given a url-like string
4
- describe("getHostFromUrl", () => {
5
- it("should return the host from a url", () => {
6
- expect(getHostFromUrl("https://www.example.com")).toBe("www.example.com");
7
- });
8
-
9
- it("should return the host from a url using wildcard *.", () => {
10
- expect(getHostFromUrl("*.example.com")).toBe("example.com");
11
- });
12
-
13
- it("should return the host from a url using wildcard *", () => {
14
- expect(getHostFromUrl("*example.com")).toBe("example.com");
15
- });
16
- });
@@ -1,120 +0,0 @@
1
- import { writeFile } from "fs/promises";
2
- import path from "path";
3
- import guessWorkerFormat from "../entry";
4
- import { mockConsoleMethods } from "./helpers/mock-console";
5
- import { runInTempDir } from "./helpers/run-in-tmp";
6
-
7
- describe("guess worker format", () => {
8
- runInTempDir();
9
- const std = mockConsoleMethods();
10
- it('should detect a "modules" worker', async () => {
11
- await writeFile("./index.ts", "export default {};");
12
- // Note that this isn't actually a valid worker, because it's missing
13
- // a fetch handler. Regardless, our heuristic is simply to check for exports.
14
- const guess = await guessWorkerFormat(
15
- path.join(process.cwd(), "./index.ts"),
16
- process.cwd(),
17
- undefined
18
- );
19
- expect(guess).toBe("modules");
20
- });
21
-
22
- it('should detect a "service-worker" worker', async () => {
23
- await writeFile("./index.ts", "");
24
- // Note that this isn't actually a valid worker, because it's missing
25
- // a fetch listener. Regardless, our heuristic is simply to check for
26
- // the lack of exports.
27
- const guess = await guessWorkerFormat(
28
- path.join(process.cwd(), "./index.ts"),
29
- process.cwd(),
30
- undefined
31
- );
32
- expect(guess).toBe("service-worker");
33
- });
34
-
35
- it('should detect a "service-worker" worker using `typeof module`', async () => {
36
- await writeFile("./index.ts", "typeof module");
37
- const guess = await guessWorkerFormat(
38
- path.join(process.cwd(), "./index.ts"),
39
- process.cwd(),
40
- undefined
41
- );
42
- expect(guess).toBe("service-worker");
43
- });
44
-
45
- it('should detect a "service-worker" worker using imports', async () => {
46
- await writeFile(
47
- "./dep.ts",
48
- `
49
- const value = 'thing';
50
- export default value;
51
- `
52
- );
53
- await writeFile(
54
- "./index.ts",
55
- `
56
- import value from './dep.ts';
57
- addEventListener('fetch', (event) => {
58
- event.respondWith(new Response(value));
59
- });
60
- `
61
- );
62
- const guess = await guessWorkerFormat(
63
- path.join(process.cwd(), "./index.ts"),
64
- process.cwd(),
65
- undefined
66
- );
67
- expect(guess).toBe("service-worker");
68
- });
69
-
70
- it("should throw an error when the hint doesn't match the guess (modules - service-worker)", async () => {
71
- await writeFile("./index.ts", "export default {};");
72
- await expect(
73
- guessWorkerFormat(
74
- path.join(process.cwd(), "./index.ts"),
75
- process.cwd(),
76
- "service-worker"
77
- )
78
- ).rejects.toThrow(
79
- "You configured this worker to be a 'service-worker', but the file you are trying to build appears to have a `default` export like a module worker. Please pass `--format modules`, or simply remove the configuration."
80
- );
81
- });
82
-
83
- it("should throw an error when the hint doesn't match the guess (service-worker - modules)", async () => {
84
- await writeFile("./index.ts", "");
85
- await expect(
86
- guessWorkerFormat(
87
- path.join(process.cwd(), "./index.ts"),
88
- process.cwd(),
89
- "modules"
90
- )
91
- ).rejects.toThrow(
92
- "You configured this worker to be 'modules', but the file you are trying to build doesn't export a handler. Please pass `--format service-worker`, or simply remove the configuration."
93
- );
94
- });
95
-
96
- it("should not error if a .js entry point has jsx", async () => {
97
- await writeFile("./index.js", "console.log(<div/>)");
98
- const guess = await guessWorkerFormat(
99
- path.join(process.cwd(), "./index.js"),
100
- process.cwd(),
101
- undefined
102
- );
103
- expect(guess).toBe("service-worker");
104
- });
105
-
106
- it("logs a warning when a worker has exports, but not a default one", async () => {
107
- await writeFile("./index.ts", "export const foo = 1;");
108
- const guess = await guessWorkerFormat(
109
- path.join(process.cwd(), "./index.ts"),
110
- process.cwd(),
111
- undefined
112
- );
113
- expect(guess).toBe("service-worker");
114
- expect(std.warn).toMatchInlineSnapshot(`
115
- "▲ [WARNING] The entrypoint index.ts has exports like an ES Module, but hasn't defined a default export like a module worker normally would. Building the worker using \\"service-worker\\" format...
116
-
117
- "
118
- `);
119
- });
120
- });
@@ -1,4 +0,0 @@
1
- // We use this mock during tests because we're having trouble
2
- // properly compiling clipboardy for jest
3
- // We can revisit this if and when we write tests that test
4
- // the copying part of `dev`
@@ -1,11 +0,0 @@
1
- /**
2
- * The typings file available at `@types/cmd-shim` are out of date.
3
- */
4
- module "cmd-shim" {
5
- /**
6
- *
7
- * Create a cmd shim at `to` for the command line program at `from`.
8
- *
9
- */
10
- export default function cmdShim(from: string, to: string): Promise<void>;
11
- }
@@ -1,6 +0,0 @@
1
- /**
2
- * Forces a tick and ensures that all pending promises resolve
3
- */
4
- export function endEventLoop() {
5
- return new Promise((resolve) => setImmediate(resolve));
6
- }
@@ -1,48 +0,0 @@
1
- import { reinitialiseAuthTokens } from "../../user";
2
-
3
- const ORIGINAL_CLOUDFLARE_API_TOKEN = process.env.CLOUDFLARE_API_TOKEN;
4
- const ORIGINAL_CLOUDFLARE_ACCOUNT_ID = process.env.CLOUDFLARE_ACCOUNT_ID;
5
-
6
- /**
7
- * Mock the API token so that we don't need to read it from user configuration files.
8
- *
9
- * Note that you can remove any API token from the environment by setting the value to `null`.
10
- * This is useful if a higher `describe()` block has already called `mockApiToken()`.
11
- */
12
- export function mockApiToken({
13
- apiToken = "some-api-token",
14
- }: { apiToken?: string | null } = {}) {
15
- beforeEach(() => {
16
- if (apiToken === null) {
17
- delete process.env.CLOUDFLARE_API_TOKEN;
18
- } else {
19
- process.env.CLOUDFLARE_API_TOKEN = apiToken;
20
- }
21
- // Now we have updated the environment, we must reinitialize the user auth state.
22
- reinitialiseAuthTokens();
23
- });
24
- afterEach(() => {
25
- process.env.CLOUDFLARE_API_TOKEN = ORIGINAL_CLOUDFLARE_API_TOKEN;
26
- });
27
- }
28
-
29
- /**
30
- * Mock the current account ID so that we don't need to read it from configuration files.
31
- *
32
- * Note that you can remove any account ID from the environment by setting the value to `null`.
33
- * This is useful if a higher `describe()` block has already called `mockAccountId()`.
34
- */
35
- export function mockAccountId({
36
- accountId = "some-account-id",
37
- }: { accountId?: string | null } = {}) {
38
- beforeEach(() => {
39
- if (accountId === null) {
40
- delete process.env.CLOUDFLARE_ACCOUNT_ID;
41
- } else {
42
- process.env.CLOUDFLARE_ACCOUNT_ID = accountId;
43
- }
44
- });
45
- afterEach(() => {
46
- process.env.CLOUDFLARE_ACCOUNT_ID = ORIGINAL_CLOUDFLARE_ACCOUNT_ID;
47
- });
48
- }
@@ -1,20 +0,0 @@
1
- const ORIGINAL_WRANGLER_AUTH_DOMAIN = process.env.WRANGLER_AUTH_DOMAIN;
2
-
3
- /**
4
- * Mock the Auth URL domain so that we can control where we attempt to login.
5
- *
6
- * Note that you can remove any API token from the environment by setting the value to `null`.
7
- * This is useful if a higher `describe()` block has already called `mockAuthDomain()`.
8
- */
9
- export function mockAuthDomain({ domain }: { domain: string | null }) {
10
- beforeEach(() => {
11
- if (domain === null) {
12
- delete process.env.WRANGLER_AUTH_DOMAIN;
13
- } else {
14
- process.env.WRANGLER_AUTH_DOMAIN = domain;
15
- }
16
- });
17
- afterEach(() => {
18
- process.env.WRANGLER_AUTH_DOMAIN = ORIGINAL_WRANGLER_AUTH_DOMAIN;
19
- });
20
- }
@@ -1,36 +0,0 @@
1
- import { chmodSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
2
- import { basename, resolve } from "node:path";
3
- import cmdShim from "cmd-shim";
4
-
5
- const nodeShebang = "#!/usr/bin/env node";
6
-
7
- /**
8
- * Create a binary file in a temp directory and make it available on the PATH.
9
- */
10
- export async function mockBinary(
11
- binaryName: string,
12
- code: string
13
- ): Promise<() => void> {
14
- // Ensure there is a directory to put the mock binary in.
15
- const tmpDir = resolve(mkdtempSync(".mock-binary-"));
16
-
17
- // Use a fake extension on Windows because we will create a cmd-shim to run the binary.
18
- const extension = process.platform === "win32" ? ".x-mock-bin" : "";
19
- const filePath = resolve(tmpDir, `${binaryName}${extension}`);
20
- writeFileSync(filePath, nodeShebang + "\n" + code);
21
- chmodSync(filePath, 0o777);
22
-
23
- if (process.platform === "win32") {
24
- await cmdShim(filePath, basename(filePath, ".x-mock-bin"));
25
- }
26
-
27
- // Update PATH using the appropriate separator for the platform.
28
- const oldPath = process.env.PATH;
29
- const sep = process.platform === "win32" ? ";" : ":";
30
- process.env.PATH = tmpDir + sep + oldPath;
31
-
32
- return function unMock() {
33
- rmSync(tmpDir, { recursive: true });
34
- process.env.PATH = process.env.PATH?.replace(tmpDir + sep, "");
35
- };
36
- }
@@ -1,112 +0,0 @@
1
- import * as util from "node:util";
2
- import { logger } from "../../logger";
3
-
4
- /**
5
- * We use this module to mock console methods, and optionally
6
- * assert on the values they're called with in our tests.
7
- */
8
-
9
- let debugSpy: jest.SpyInstance,
10
- logSpy: jest.SpyInstance,
11
- infoSpy: jest.SpyInstance,
12
- errorSpy: jest.SpyInstance,
13
- warnSpy: jest.SpyInstance;
14
-
15
- const std = {
16
- get debug() {
17
- return normalizeOutput(debugSpy);
18
- },
19
- get out() {
20
- return normalizeOutput(logSpy);
21
- },
22
- get info() {
23
- return normalizeOutput(infoSpy);
24
- },
25
- get err() {
26
- return normalizeOutput(errorSpy);
27
- },
28
- get warn() {
29
- return normalizeOutput(warnSpy);
30
- },
31
- };
32
-
33
- function normalizeOutput(spy: jest.SpyInstance): string {
34
- return normalizeErrorMarkers(
35
- replaceByte(
36
- stripTrailingWhitespace(
37
- normalizeSlashes(normalizeTempDirs(stripTimings(captureCalls(spy))))
38
- )
39
- )
40
- );
41
- }
42
-
43
- function captureCalls(spy: jest.SpyInstance): string {
44
- return spy.mock.calls
45
- .map((args: unknown[]) => util.format("%s", ...args))
46
- .join("\n");
47
- }
48
-
49
- export function mockConsoleMethods() {
50
- beforeEach(() => {
51
- logger.columns = 100;
52
- debugSpy = jest.spyOn(console, "debug").mockImplementation();
53
- logSpy = jest.spyOn(console, "log").mockImplementation();
54
- infoSpy = jest.spyOn(console, "info").mockImplementation();
55
- errorSpy = jest.spyOn(console, "error").mockImplementation();
56
- warnSpy = jest.spyOn(console, "warn").mockImplementation();
57
- });
58
- afterEach(() => {
59
- debugSpy.mockRestore();
60
- logSpy.mockRestore();
61
- infoSpy.mockRestore();
62
- errorSpy.mockRestore();
63
- warnSpy.mockRestore();
64
- });
65
- return std;
66
- }
67
-
68
- /**
69
- * Normalize error `X` markers.
70
- *
71
- * Windows gets a different character.
72
- */
73
- function normalizeErrorMarkers(str: string): string {
74
- return str.replaceAll("✘", "X");
75
- }
76
-
77
- /**
78
- * Ensure slashes in the `str` are OS file-system agnostic.
79
- *
80
- * Use this in snapshot tests to be resilient to file-system differences.
81
- */
82
- export function normalizeSlashes(str: string): string {
83
- return str.replace(/\\/g, "/");
84
- }
85
-
86
- /**
87
- * Strip "timing data" out of the `stdout` string, since this is not always deterministic.
88
- *
89
- * Use this in snapshot tests to be resilient to slight changes in timing of processing.
90
- */
91
- export function stripTimings(stdout: string): string {
92
- return stdout.replace(/\(\d+\.\d+ sec\)/g, "(TIMINGS)");
93
- }
94
-
95
- export function stripTrailingWhitespace(str: string): string {
96
- return str.replace(/[^\S\n]+\n/g, "\n");
97
- }
98
-
99
- /**
100
- * Removing leading kilobit (tenth of a byte) from test output due to
101
- * variation causing every few tests the value to change by ± .01
102
- */
103
- function replaceByte(stdout: string): string {
104
- return stdout.replaceAll(/\d+\.\d+ KiB/g, "xx KiB");
105
- }
106
-
107
- /**
108
- * Temp directories are created with random names, so we replace all comments temp dirs in them
109
- */
110
- export function normalizeTempDirs(stdout: string): string {
111
- return stdout.replaceAll(/\/\/.+\/tmp.+/g, "//tmpdir");
112
- }