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,693 +0,0 @@
1
- import * as fs from "node:fs";
2
- import { writeFileSync } from "node:fs";
3
- import * as TOML from "@iarna/toml";
4
- import { rest } from "msw";
5
- import { mockAccountId, mockApiToken } from "./helpers/mock-account-id";
6
- import { mockConsoleMethods } from "./helpers/mock-console";
7
- import { mockConfirm, mockPrompt, clearDialogs } from "./helpers/mock-dialogs";
8
- import { useMockIsTTY } from "./helpers/mock-istty";
9
- import { mockGetMembershipsFail } from "./helpers/mock-oauth-flow";
10
- import { useMockStdin } from "./helpers/mock-stdin";
11
- import { msw } from "./helpers/msw";
12
- import { runInTempDir } from "./helpers/run-in-tmp";
13
- import { runWrangler } from "./helpers/run-wrangler";
14
-
15
- function createFetchResult(result: unknown, success = true) {
16
- return {
17
- success,
18
- errors: [],
19
- messages: [],
20
- result,
21
- };
22
- }
23
-
24
- export function mockGetMemberships(
25
- accounts: { id: string; account: { id: string; name: string } }[]
26
- ) {
27
- msw.use(
28
- rest.get("*/memberships", (req, res, ctx) => {
29
- return res.once(ctx.json(createFetchResult(accounts)));
30
- })
31
- );
32
- }
33
-
34
- describe("wrangler secret", () => {
35
- const std = mockConsoleMethods();
36
- const { setIsTTY } = useMockIsTTY();
37
- runInTempDir();
38
- mockAccountId();
39
- mockApiToken();
40
- afterEach(() => {
41
- clearDialogs();
42
- });
43
-
44
- describe("put", () => {
45
- function mockPutRequest(
46
- input: { name: string; text: string },
47
- env?: string,
48
- legacyEnv = false
49
- ) {
50
- const servicesOrScripts = env && !legacyEnv ? "services" : "scripts";
51
- const environment = env && !legacyEnv ? "/environments/:envName" : "";
52
- msw.use(
53
- rest.put(
54
- `*/accounts/:accountId/workers/${servicesOrScripts}/:scriptName${environment}/secrets`,
55
- async (req, res, ctx) => {
56
- expect(req.params.accountId).toEqual("some-account-id");
57
- expect(req.params.scriptName).toEqual(
58
- legacyEnv && env ? `script-name-${env}` : "script-name"
59
- );
60
- if (!legacyEnv) {
61
- expect(req.params.envName).toEqual(env);
62
- }
63
- const { name, text, type } = await req.json();
64
- expect(type).toEqual("secret_text");
65
- expect(name).toEqual(input.name);
66
- expect(text).toEqual(input.text);
67
-
68
- return res.once(ctx.json(createFetchResult({ name, type })));
69
- }
70
- )
71
- );
72
- }
73
-
74
- describe("interactive", () => {
75
- beforeEach(() => {
76
- setIsTTY(true);
77
- });
78
-
79
- it("should trim stdin secret value", async () => {
80
- mockPrompt({
81
- text: "Enter a secret value:",
82
- options: { isSecret: true },
83
- result: `hunter2
84
- `,
85
- });
86
-
87
- mockPutRequest({ name: `secret-name`, text: `hunter2` });
88
- await runWrangler("secret put secret-name --name script-name");
89
- expect(std.out).toMatchInlineSnapshot(`
90
- "🌀 Creating the secret for the Worker \\"script-name\\"
91
- ✨ Success! Uploaded secret secret-name"
92
- `);
93
- });
94
-
95
- it("should create a secret", async () => {
96
- mockPrompt({
97
- text: "Enter a secret value:",
98
- options: { isSecret: true },
99
- result: "the-secret",
100
- });
101
-
102
- mockPutRequest({ name: "the-key", text: "the-secret" });
103
- await runWrangler("secret put the-key --name script-name");
104
-
105
- expect(std.out).toMatchInlineSnapshot(`
106
- "🌀 Creating the secret for the Worker \\"script-name\\"
107
- ✨ Success! Uploaded secret the-key"
108
- `);
109
- expect(std.err).toMatchInlineSnapshot(`""`);
110
- });
111
-
112
- it("should create secret:bulk", async () => {
113
- writeFileSync(
114
- "secret.json",
115
- JSON.stringify({
116
- "secret-name-1": "secret_text",
117
- "secret-name-2": "secret_text",
118
- })
119
- );
120
-
121
- // User counter to pass different secrets to the request mock
122
- let counter = 0;
123
- msw.use(
124
- rest.put(
125
- `*/accounts/:accountId/workers/scripts/:scriptName/secrets`,
126
- (req, res, ctx) => {
127
- expect(req.params.accountId).toEqual("some-account-id");
128
- counter++;
129
-
130
- return res(
131
- ctx.json(
132
- createFetchResult({
133
- name: `secret-name-${counter}`,
134
- type: "secret_text",
135
- })
136
- )
137
- );
138
- }
139
- )
140
- );
141
-
142
- await runWrangler("secret:bulk ./secret.json --name script-name");
143
-
144
- expect(std.out).toMatchInlineSnapshot(`
145
- "🌀 Creating the secrets for the Worker \\"script-name\\"
146
- ✨ Successfully created secret for key: secret-name-1
147
- ✨ Successfully created secret for key: secret-name-2
148
-
149
- Finished processing secrets JSON file:
150
- ✨ 2 secrets successfully uploaded"
151
- `);
152
- expect(std.err).toMatchInlineSnapshot(`""`);
153
- });
154
-
155
- it("should handle network failure on secret:bulk", async () => {
156
- writeFileSync(
157
- "secret.json",
158
- JSON.stringify({
159
- "secret-name-1": "secret_text",
160
- "secret-name-2": "secret_text",
161
- })
162
- );
163
-
164
- // User counter to pass different secrets to the request mock
165
- let counter = 0;
166
- msw.use(
167
- rest.put(
168
- `*/accounts/:accountId/workers/scripts/:scriptName/secrets`,
169
- (req, res) => {
170
- expect(req.params.accountId).toEqual("some-account-id");
171
- counter++;
172
-
173
- return res.networkError(`Failed to create secret ${counter}`);
174
- }
175
- )
176
- );
177
-
178
- await runWrangler("secret:bulk ./secret.json --name script-name");
179
-
180
- expect(std.out).toMatchInlineSnapshot(`
181
- "🌀 Creating the secrets for the Worker \\"script-name\\"
182
-
183
- Finished processing secrets JSON file:
184
- ✨ 0 secrets successfully uploaded
185
- 🚨 2 secrets failed to upload"
186
- `);
187
- expect(std.err).toMatchInlineSnapshot(`
188
- "X [ERROR] 🚨 Error uploading secret for key: secret-name-1:
189
-
190
- request to
191
- https://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets
192
- failed, reason: Failed to create secret 1
193
-
194
-
195
- X [ERROR] 🚨 Error uploading secret for key: secret-name-2:
196
-
197
- request to
198
- https://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets
199
- failed, reason: Failed to create secret 2
200
-
201
- "
202
- `);
203
- });
204
-
205
- it("should count success and network failure on secret:bulk", async () => {
206
- writeFileSync(
207
- "secret.json",
208
- JSON.stringify({
209
- "secret-name-1": "secret_text",
210
- "secret-name-2": "secret_text",
211
- "secret-name-3": "secret_text",
212
- "secret-name-4": "secret_text",
213
- "secret-name-5": "secret_text",
214
- "secret-name-6": "secret_text",
215
- "secret-name-7": "secret_text",
216
- })
217
- );
218
-
219
- // User counter to pass different secrets to the request mock
220
- let counter = 0;
221
- msw.use(
222
- rest.put(
223
- `*/accounts/:accountId/workers/scripts/:scriptName/secrets`,
224
- (req, res, ctx) => {
225
- expect(req.params.accountId).toEqual("some-account-id");
226
- counter++;
227
-
228
- if (counter % 2 === 0) {
229
- return res(
230
- ctx.json(
231
- createFetchResult({
232
- name: `secret-name-${counter}`,
233
- type: "secret_text",
234
- })
235
- )
236
- );
237
- } else {
238
- return res.networkError(`Failed to create secret ${counter}`);
239
- }
240
- }
241
- )
242
- );
243
-
244
- await runWrangler("secret:bulk ./secret.json --name script-name");
245
-
246
- expect(std.out).toMatchInlineSnapshot(`
247
- "🌀 Creating the secrets for the Worker \\"script-name\\"
248
- ✨ Successfully created secret for key: secret-name-2
249
- ✨ Successfully created secret for key: secret-name-4
250
- ✨ Successfully created secret for key: secret-name-6
251
-
252
- Finished processing secrets JSON file:
253
- ✨ 3 secrets successfully uploaded
254
- 🚨 4 secrets failed to upload"
255
- `);
256
- expect(std.err).toMatchInlineSnapshot(`
257
- "X [ERROR] 🚨 Error uploading secret for key: secret-name-1:
258
-
259
- request to
260
- https://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets
261
- failed, reason: Failed to create secret 1
262
-
263
-
264
- X [ERROR] 🚨 Error uploading secret for key: secret-name-3:
265
-
266
- request to
267
- https://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets
268
- failed, reason: Failed to create secret 3
269
-
270
-
271
- X [ERROR] 🚨 Error uploading secret for key: secret-name-5:
272
-
273
- request to
274
- https://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets
275
- failed, reason: Failed to create secret 5
276
-
277
-
278
- X [ERROR] 🚨 Error uploading secret for key: secret-name-7:
279
-
280
- request to
281
- https://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets
282
- failed, reason: Failed to create secret 7
283
-
284
- "
285
- `);
286
- });
287
-
288
- it("should create a secret: legacy envs", async () => {
289
- mockPrompt({
290
- text: "Enter a secret value:",
291
- options: { isSecret: true },
292
- result: "the-secret",
293
- });
294
-
295
- mockPutRequest(
296
- { name: "the-key", text: "the-secret" },
297
- "some-env",
298
- true
299
- );
300
- await runWrangler(
301
- "secret put the-key --name script-name --env some-env --legacy-env"
302
- );
303
-
304
- expect(std.out).toMatchInlineSnapshot(`
305
- "🌀 Creating the secret for the Worker \\"script-name-some-env\\"
306
- ✨ Success! Uploaded secret the-key"
307
- `);
308
- expect(std.err).toMatchInlineSnapshot(`""`);
309
- });
310
-
311
- it("should create a secret: service envs", async () => {
312
- mockPrompt({
313
- text: "Enter a secret value:",
314
- options: { isSecret: true },
315
- result: "the-secret",
316
- });
317
-
318
- mockPutRequest(
319
- { name: "the-key", text: "the-secret" },
320
- "some-env",
321
- false
322
- );
323
- await runWrangler(
324
- "secret put the-key --name script-name --env some-env --legacy-env false"
325
- );
326
-
327
- expect(std.out).toMatchInlineSnapshot(`
328
- "🌀 Creating the secret for the Worker \\"script-name\\" (some-env)
329
- ✨ Success! Uploaded secret the-key"
330
- `);
331
- expect(std.err).toMatchInlineSnapshot(`""`);
332
- });
333
-
334
- it("should error without a script name", async () => {
335
- let error: Error | undefined;
336
- try {
337
- await runWrangler("secret put the-key");
338
- } catch (e) {
339
- error = e as Error;
340
- }
341
- expect(std.out).toMatchInlineSnapshot(`
342
- "
343
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
344
- `);
345
- expect(std.err).toMatchInlineSnapshot(`
346
- "X [ERROR] Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`
347
-
348
- "
349
- `);
350
- expect(error).toMatchInlineSnapshot(
351
- `[Error: Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`]`
352
- );
353
- });
354
- });
355
-
356
- describe("non-interactive", () => {
357
- beforeEach(() => {
358
- setIsTTY(false);
359
- });
360
- const mockStdIn = useMockStdin({ isTTY: false });
361
-
362
- it("should trim stdin secret value, from piped input", async () => {
363
- mockPutRequest({ name: "the-key", text: "the-secret" });
364
- // Pipe the secret in as three chunks to test that we reconstitute it correctly.
365
- mockStdIn.send(
366
- `the`,
367
- `-`,
368
- `secret
369
- ` // whitespace & newline being removed
370
- );
371
- await runWrangler("secret put the-key --name script-name");
372
-
373
- expect(std.out).toMatchInlineSnapshot(`
374
- "🌀 Creating the secret for the Worker \\"script-name\\"
375
- ✨ Success! Uploaded secret the-key"
376
- `);
377
- expect(std.warn).toMatchInlineSnapshot(`""`);
378
- expect(std.err).toMatchInlineSnapshot(`""`);
379
- });
380
-
381
- it("should create a secret, from piped input", async () => {
382
- mockPutRequest({ name: "the-key", text: "the-secret" });
383
- // Pipe the secret in as three chunks to test that we reconstitute it correctly.
384
- mockStdIn.send("the", "-", "secret");
385
- await runWrangler("secret put the-key --name script-name");
386
-
387
- expect(std.out).toMatchInlineSnapshot(`
388
- "🌀 Creating the secret for the Worker \\"script-name\\"
389
- ✨ Success! Uploaded secret the-key"
390
- `);
391
- expect(std.warn).toMatchInlineSnapshot(`""`);
392
- expect(std.err).toMatchInlineSnapshot(`""`);
393
- });
394
-
395
- it("should error if the piped input fails", async () => {
396
- mockPutRequest({ name: "the-key", text: "the-secret" });
397
- mockStdIn.throwError(new Error("Error in stdin stream"));
398
- await expect(
399
- runWrangler("secret put the-key --name script-name")
400
- ).rejects.toThrowErrorMatchingInlineSnapshot(`"Error in stdin stream"`);
401
-
402
- expect(std.out).toMatchInlineSnapshot(`
403
- "
404
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
405
- `);
406
- expect(std.warn).toMatchInlineSnapshot(`""`);
407
- });
408
-
409
- describe("with accountId", () => {
410
- mockAccountId({ accountId: null });
411
-
412
- it("should error if request for memberships fails", async () => {
413
- mockGetMembershipsFail();
414
- await expect(
415
- runWrangler("secret put the-key --name script-name")
416
- ).rejects.toThrowErrorMatchingInlineSnapshot(
417
- `"A request to the Cloudflare API (/memberships) failed."`
418
- );
419
- });
420
-
421
- it("should error if a user has no account", async () => {
422
- mockGetMemberships([]);
423
- await expect(runWrangler("secret put the-key --name script-name"))
424
- .rejects.toThrowErrorMatchingInlineSnapshot(`
425
- "Failed to automatically retrieve account IDs for the logged in user.
426
- In a non-interactive environment, it is mandatory to specify an account ID, either by assigning its value to CLOUDFLARE_ACCOUNT_ID, or as \`account_id\` in your \`wrangler.toml\` file."
427
- `);
428
- });
429
-
430
- it("should use the account from wrangler.toml", async () => {
431
- fs.writeFileSync(
432
- "wrangler.toml",
433
- TOML.stringify({
434
- account_id: "some-account-id",
435
- }),
436
- "utf-8"
437
- );
438
- mockStdIn.send("the-secret");
439
- mockPutRequest({ name: "the-key", text: "the-secret" });
440
- await runWrangler("secret put the-key --name script-name");
441
- expect(std.out).toMatchInlineSnapshot(`
442
- "🌀 Creating the secret for the Worker \\"script-name\\"
443
- ✨ Success! Uploaded secret the-key"
444
- `);
445
- expect(std.warn).toMatchInlineSnapshot(`""`);
446
- expect(std.err).toMatchInlineSnapshot(`""`);
447
- });
448
-
449
- it("should error if a user has multiple accounts, and has not specified an account in wrangler.toml", async () => {
450
- mockGetMemberships([
451
- {
452
- id: "1",
453
- account: { id: "account-id-1", name: "account-name-1" },
454
- },
455
- {
456
- id: "2",
457
- account: { id: "account-id-2", name: "account-name-2" },
458
- },
459
- {
460
- id: "3",
461
- account: { id: "account-id-3", name: "account-name-3" },
462
- },
463
- ]);
464
-
465
- await expect(runWrangler("secret put the-key --name script-name"))
466
- .rejects.toThrowErrorMatchingInlineSnapshot(`
467
- "More than one account available but unable to select one in non-interactive mode.
468
- Please set the appropriate \`account_id\` in your \`wrangler.toml\` file.
469
- Available accounts are (\`<name>\`: \`<account_id>\`):
470
- \`account-name-1\`: \`account-id-1\`
471
- \`account-name-2\`: \`account-id-2\`
472
- \`account-name-3\`: \`account-id-3\`"
473
- `);
474
- });
475
- });
476
- });
477
- });
478
-
479
- describe("delete", () => {
480
- beforeEach(() => {
481
- setIsTTY(true);
482
- });
483
- function mockDeleteRequest(
484
- input: {
485
- scriptName: string;
486
- secretName: string;
487
- },
488
- env?: string,
489
- legacyEnv = false
490
- ) {
491
- const servicesOrScripts = env && !legacyEnv ? "services" : "scripts";
492
- const environment = env && !legacyEnv ? "/environments/:envName" : "";
493
- msw.use(
494
- rest.delete(
495
- `*/accounts/:accountId/workers/${servicesOrScripts}/:scriptName${environment}/secrets/:secretName`,
496
- (req, res, ctx) => {
497
- expect(req.params.accountId).toEqual("some-account-id");
498
- expect(req.params.scriptName).toEqual(
499
- legacyEnv && env ? `script-name-${env}` : "script-name"
500
- );
501
- if (!legacyEnv) {
502
- if (env) {
503
- expect(req.params.secretName).toEqual(input.secretName);
504
- }
505
- }
506
- return res.once(ctx.json(createFetchResult(null)));
507
- }
508
- )
509
- );
510
- }
511
-
512
- it("should delete a secret", async () => {
513
- mockDeleteRequest({ scriptName: "script-name", secretName: "the-key" });
514
- mockConfirm({
515
- text: "Are you sure you want to permanently delete the secret the-key on the Worker script-name?",
516
- result: true,
517
- });
518
- await runWrangler("secret delete the-key --name script-name");
519
- expect(std.out).toMatchInlineSnapshot(`
520
- "🌀 Deleting the secret the-key on the Worker script-name
521
- ✨ Success! Deleted secret the-key"
522
- `);
523
- expect(std.err).toMatchInlineSnapshot(`""`);
524
- });
525
-
526
- it("should delete a secret: legacy envs", async () => {
527
- mockDeleteRequest(
528
- { scriptName: "script-name", secretName: "the-key" },
529
- "some-env",
530
- true
531
- );
532
- mockConfirm({
533
- text: "Are you sure you want to permanently delete the secret the-key on the Worker script-name-some-env?",
534
- result: true,
535
- });
536
- await runWrangler(
537
- "secret delete the-key --name script-name --env some-env --legacy-env"
538
- );
539
- expect(std.out).toMatchInlineSnapshot(`
540
- "🌀 Deleting the secret the-key on the Worker script-name-some-env
541
- ✨ Success! Deleted secret the-key"
542
- `);
543
- expect(std.err).toMatchInlineSnapshot(`""`);
544
- });
545
-
546
- it("should delete a secret: service envs", async () => {
547
- mockDeleteRequest(
548
- { scriptName: "script-name", secretName: "the-key" },
549
- "some-env"
550
- );
551
- mockConfirm({
552
- text: "Are you sure you want to permanently delete the secret the-key on the Worker script-name (some-env)?",
553
- result: true,
554
- });
555
- await runWrangler(
556
- "secret delete the-key --name script-name --env some-env --legacy-env false"
557
- );
558
- expect(std.out).toMatchInlineSnapshot(`
559
- "🌀 Deleting the secret the-key on the Worker script-name (some-env)
560
- ✨ Success! Deleted secret the-key"
561
- `);
562
- expect(std.err).toMatchInlineSnapshot(`""`);
563
- });
564
-
565
- it("should error without a script name", async () => {
566
- let error: Error | undefined;
567
-
568
- try {
569
- await runWrangler("secret delete the-key");
570
- } catch (e) {
571
- error = e as Error;
572
- }
573
- expect(std.out).toMatchInlineSnapshot(`
574
- "
575
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
576
- `);
577
- expect(std.err).toMatchInlineSnapshot(`
578
- "X [ERROR] Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`
579
-
580
- "
581
- `);
582
- expect(error).toMatchInlineSnapshot(
583
- `[Error: Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`]`
584
- );
585
- });
586
- });
587
-
588
- describe("list", () => {
589
- beforeEach(() => {
590
- setIsTTY(true);
591
- });
592
- function mockListRequest(
593
- input: { scriptName: string },
594
- env?: string,
595
- legacyEnv = false
596
- ) {
597
- const servicesOrScripts = env && !legacyEnv ? "services" : "scripts";
598
- const environment = env && !legacyEnv ? "/environments/:envName" : "";
599
- msw.use(
600
- rest.get(
601
- `*/accounts/:accountId/workers/${servicesOrScripts}/:scriptName${environment}/secrets`,
602
- (req, res, ctx) => {
603
- expect(req.params.accountId).toEqual("some-account-id");
604
- expect(req.params.scriptName).toEqual(
605
- legacyEnv && env ? `script-name-${env}` : "script-name"
606
- );
607
- if (!legacyEnv) {
608
- expect(req.params.envName).toEqual(env);
609
- }
610
-
611
- return res.once(
612
- ctx.json(
613
- createFetchResult([
614
- {
615
- name: "the-secret-name",
616
- type: "secret_text",
617
- },
618
- ])
619
- )
620
- );
621
- }
622
- )
623
- );
624
- }
625
-
626
- it("should list secrets", async () => {
627
- mockListRequest({ scriptName: "script-name" });
628
- await runWrangler("secret list --name script-name");
629
- expect(std.out).toMatchInlineSnapshot(`
630
- "[
631
- {
632
- \\"name\\": \\"the-secret-name\\",
633
- \\"type\\": \\"secret_text\\"
634
- }
635
- ]"
636
- `);
637
- expect(std.err).toMatchInlineSnapshot(`""`);
638
- });
639
-
640
- it("should list secrets: legacy envs", async () => {
641
- mockListRequest({ scriptName: "script-name" }, "some-env", true);
642
- await runWrangler(
643
- "secret list --name script-name --env some-env --legacy-env"
644
- );
645
- expect(std.out).toMatchInlineSnapshot(`
646
- "[
647
- {
648
- \\"name\\": \\"the-secret-name\\",
649
- \\"type\\": \\"secret_text\\"
650
- }
651
- ]"
652
- `);
653
- expect(std.err).toMatchInlineSnapshot(`""`);
654
- });
655
-
656
- it("should list secrets: service envs", async () => {
657
- mockListRequest({ scriptName: "script-name" }, "some-env");
658
- await runWrangler(
659
- "secret list --name script-name --env some-env --legacy-env false"
660
- );
661
- expect(std.out).toMatchInlineSnapshot(`
662
- "[
663
- {
664
- \\"name\\": \\"the-secret-name\\",
665
- \\"type\\": \\"secret_text\\"
666
- }
667
- ]"
668
- `);
669
- expect(std.err).toMatchInlineSnapshot(`""`);
670
- });
671
-
672
- it("should error without a script name", async () => {
673
- let error: Error | undefined;
674
- try {
675
- await runWrangler("secret list");
676
- } catch (e) {
677
- error = e as Error;
678
- }
679
- expect(std.out).toMatchInlineSnapshot(`
680
- "
681
- If you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose"
682
- `);
683
- expect(std.err).toMatchInlineSnapshot(`
684
- "X [ERROR] Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`
685
-
686
- "
687
- `);
688
- expect(error).toMatchInlineSnapshot(
689
- `[Error: Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`]`
690
- );
691
- });
692
- });
693
- });