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.
- package/README.md +4 -4
- package/bin/wrangler.js +9 -75
- package/package.json +5 -13
- package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
- package/templates/checked-fetch.js +1 -1
- package/templates/first-party-worker-module-facade.ts +2 -2
- package/templates/middleware/common.ts +9 -4
- package/templates/middleware/loader-sw.ts +2 -7
- package/templates/new-worker-scheduled.ts +1 -1
- package/templates/new-worker.ts +1 -1
- package/templates/pages-dev-util.ts +4 -1
- package/templates/pages-shim.ts +0 -3
- package/templates/tsconfig.tsbuildinfo +1 -1
- package/wrangler-dist/cli.d.ts +149 -75
- package/wrangler-dist/cli.js +60062 -64338
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/miniflare-dist/index.mjs +0 -6442
- package/src/__tests__/access.test.ts +0 -25
- package/src/__tests__/api-dev.test.ts +0 -238
- package/src/__tests__/api-devregistry.test.ts +0 -121
- package/src/__tests__/api.test.ts +0 -102
- package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
- package/src/__tests__/config-cache.test.ts +0 -42
- package/src/__tests__/configuration.test.ts +0 -4517
- package/src/__tests__/constellation.test.ts +0 -371
- package/src/__tests__/d1/d1.test.ts +0 -82
- package/src/__tests__/d1/execute.test.ts +0 -66
- package/src/__tests__/d1/migrate.test.ts +0 -257
- package/src/__tests__/d1/splitter.test.ts +0 -255
- package/src/__tests__/delete.test.ts +0 -272
- package/src/__tests__/deployments.test.ts +0 -369
- package/src/__tests__/dev.test.tsx +0 -1617
- package/src/__tests__/generate.test.ts +0 -237
- package/src/__tests__/get-host-from-url.test.ts +0 -16
- package/src/__tests__/guess-worker-format.test.ts +0 -120
- package/src/__tests__/helpers/clipboardy-mock.js +0 -4
- package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
- package/src/__tests__/helpers/end-event-loop.ts +0 -6
- package/src/__tests__/helpers/mock-account-id.ts +0 -48
- package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
- package/src/__tests__/helpers/mock-bin.ts +0 -36
- package/src/__tests__/helpers/mock-console.ts +0 -112
- package/src/__tests__/helpers/mock-dialogs.ts +0 -139
- package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
- package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
- package/src/__tests__/helpers/mock-http-server.ts +0 -46
- package/src/__tests__/helpers/mock-istty.ts +0 -74
- package/src/__tests__/helpers/mock-known-routes.ts +0 -12
- package/src/__tests__/helpers/mock-kv.ts +0 -46
- package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
- package/src/__tests__/helpers/mock-process.ts +0 -34
- package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
- package/src/__tests__/helpers/mock-stdin.ts +0 -108
- package/src/__tests__/helpers/mock-web-socket.ts +0 -29
- package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
- package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
- package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
- package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
- package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
- package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
- package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
- package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
- package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
- package/src/__tests__/helpers/msw/index.ts +0 -52
- package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
- package/src/__tests__/helpers/run-in-tmp.ts +0 -38
- package/src/__tests__/helpers/run-wrangler.ts +0 -16
- package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
- package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
- package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
- package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
- package/src/__tests__/helpers/write-worker-source.ts +0 -31
- package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
- package/src/__tests__/https-options.test.ts +0 -163
- package/src/__tests__/index.test.ts +0 -282
- package/src/__tests__/init.test.ts +0 -3196
- package/src/__tests__/jest.setup.ts +0 -179
- package/src/__tests__/kv.test.ts +0 -1799
- package/src/__tests__/logger.test.ts +0 -207
- package/src/__tests__/logout.test.ts +0 -47
- package/src/__tests__/metrics.test.ts +0 -493
- package/src/__tests__/middleware.scheduled.test.ts +0 -145
- package/src/__tests__/middleware.test.ts +0 -816
- package/src/__tests__/mtls-certificates.test.ts +0 -589
- package/src/__tests__/package-manager.test.ts +0 -353
- package/src/__tests__/pages/deployment-list.test.ts +0 -80
- package/src/__tests__/pages/functions-build.test.ts +0 -528
- package/src/__tests__/pages/pages.test.ts +0 -81
- package/src/__tests__/pages/project-create.test.ts +0 -63
- package/src/__tests__/pages/project-list.test.ts +0 -110
- package/src/__tests__/pages/project-upload.test.ts +0 -500
- package/src/__tests__/pages/publish.test.ts +0 -2864
- package/src/__tests__/pages-deployment-tail.test.ts +0 -957
- package/src/__tests__/parse.test.ts +0 -436
- package/src/__tests__/paths.test.ts +0 -39
- package/src/__tests__/publish.test.ts +0 -8849
- package/src/__tests__/pubsub.test.ts +0 -496
- package/src/__tests__/queues.test.ts +0 -532
- package/src/__tests__/r2.test.ts +0 -374
- package/src/__tests__/route.test.ts +0 -45
- package/src/__tests__/secret.test.ts +0 -693
- package/src/__tests__/tail.test.ts +0 -989
- package/src/__tests__/test-old-node-version.js +0 -31
- package/src/__tests__/traverse-module-graph.test.ts +0 -220
- package/src/__tests__/tsconfig-sanity.ts +0 -12
- package/src/__tests__/tsconfig.json +0 -8
- package/src/__tests__/tsconfig.tsbuildinfo +0 -1
- package/src/__tests__/type-generation.test.ts +0 -234
- package/src/__tests__/user.test.ts +0 -118
- package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
- package/src/__tests__/validate-dev-props.test.ts +0 -56
- package/src/__tests__/version.test.ts +0 -35
- package/src/__tests__/whoami.test.tsx +0 -172
- package/src/__tests__/worker-namespace.test.ts +0 -340
- package/src/abort.d.ts +0 -3
- package/src/api/dev.ts +0 -321
- package/src/api/index.ts +0 -11
- package/src/api/mtls-certificate.ts +0 -148
- package/src/api/pages/create-worker-bundle-contents.ts +0 -77
- package/src/api/pages/index.ts +0 -5
- package/src/api/pages/publish.tsx +0 -371
- package/src/bundle-reporter.ts +0 -68
- package/src/bundle.ts +0 -929
- package/src/cfetch/index.ts +0 -158
- package/src/cfetch/internal.ts +0 -258
- package/src/cli.ts +0 -28
- package/src/config/README.md +0 -107
- package/src/config/config.ts +0 -282
- package/src/config/diagnostics.ts +0 -80
- package/src/config/environment.ts +0 -625
- package/src/config/index.ts +0 -403
- package/src/config/validation-helpers.ts +0 -597
- package/src/config/validation.ts +0 -2369
- package/src/config-cache.ts +0 -85
- package/src/constellation/createProject.tsx +0 -51
- package/src/constellation/deleteProject.ts +0 -51
- package/src/constellation/deleteProjectModel.ts +0 -68
- package/src/constellation/index.ts +0 -75
- package/src/constellation/listCatalog.tsx +0 -35
- package/src/constellation/listModel.tsx +0 -41
- package/src/constellation/listProject.tsx +0 -28
- package/src/constellation/listRuntime.tsx +0 -28
- package/src/constellation/options.ts +0 -17
- package/src/constellation/types.ts +0 -17
- package/src/constellation/uploadModel.tsx +0 -64
- package/src/constellation/utils.ts +0 -90
- package/src/create-worker-preview.ts +0 -293
- package/src/create-worker-upload-form.ts +0 -363
- package/src/d1/backups.tsx +0 -219
- package/src/d1/constants.ts +0 -2
- package/src/d1/create.tsx +0 -70
- package/src/d1/delete.ts +0 -53
- package/src/d1/execute.tsx +0 -357
- package/src/d1/formatTimeAgo.ts +0 -14
- package/src/d1/index.ts +0 -100
- package/src/d1/list.tsx +0 -62
- package/src/d1/migrations/apply.tsx +0 -212
- package/src/d1/migrations/create.tsx +0 -79
- package/src/d1/migrations/helpers.ts +0 -169
- package/src/d1/migrations/index.ts +0 -3
- package/src/d1/migrations/list.tsx +0 -95
- package/src/d1/migrations/options.ts +0 -23
- package/src/d1/options.ts +0 -22
- package/src/d1/splitter.ts +0 -161
- package/src/d1/types.ts +0 -25
- package/src/d1/utils.ts +0 -49
- package/src/delete.ts +0 -100
- package/src/deployments.ts +0 -368
- package/src/deprecated/index.ts +0 -144
- package/src/dev/dev-vars.ts +0 -39
- package/src/dev/dev.tsx +0 -605
- package/src/dev/get-local-persistence-path.ts +0 -31
- package/src/dev/local.tsx +0 -952
- package/src/dev/remote.tsx +0 -635
- package/src/dev/start-server.ts +0 -545
- package/src/dev/use-esbuild.ts +0 -215
- package/src/dev/validate-dev-props.ts +0 -40
- package/src/dev-registry.ts +0 -202
- package/src/dev.tsx +0 -934
- package/src/dialogs.ts +0 -136
- package/src/dispatch-namespace.ts +0 -211
- package/src/docs/helpers.ts +0 -50
- package/src/docs/index.ts +0 -54
- package/src/durable.ts +0 -102
- package/src/entry.ts +0 -344
- package/src/environment-variables/factory.ts +0 -89
- package/src/environment-variables/misc-variables.ts +0 -30
- package/src/errors.ts +0 -11
- package/src/generate/index.ts +0 -298
- package/src/git-client.ts +0 -135
- package/src/global-wrangler-config-path.ts +0 -26
- package/src/https-options.ts +0 -127
- package/src/index.ts +0 -768
- package/src/init.ts +0 -1037
- package/src/inspect.ts +0 -883
- package/src/intl-polyfill.d.ts +0 -139
- package/src/is-ci.ts +0 -14
- package/src/is-interactive.ts +0 -16
- package/src/jest.d.ts +0 -4
- package/src/kv/helpers.ts +0 -433
- package/src/kv/index.ts +0 -594
- package/src/logger.ts +0 -123
- package/src/metrics/index.ts +0 -5
- package/src/metrics/metrics-config.ts +0 -239
- package/src/metrics/metrics-dispatcher.ts +0 -96
- package/src/metrics/metrics-usage-headers.ts +0 -24
- package/src/metrics/send-event.ts +0 -99
- package/src/miniflare-cli/README.md +0 -30
- package/src/miniflare-cli/assets.ts +0 -251
- package/src/miniflare-cli/index.ts +0 -210
- package/src/miniflare-cli/request-context.ts +0 -40
- package/src/miniflare-cli/tsconfig.json +0 -9
- package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
- package/src/miniflare-cli/types.ts +0 -11
- package/src/module-collection.ts +0 -333
- package/src/mtls-certificate/cli.ts +0 -155
- package/src/open-in-browser.ts +0 -17
- package/src/package-manager.ts +0 -219
- package/src/pages/build.ts +0 -423
- package/src/pages/buildFunctions.ts +0 -140
- package/src/pages/constants.ts +0 -18
- package/src/pages/deployment-tails.ts +0 -281
- package/src/pages/deployments.tsx +0 -84
- package/src/pages/dev.ts +0 -734
- package/src/pages/errors.ts +0 -67
- package/src/pages/functions/buildPlugin.ts +0 -114
- package/src/pages/functions/buildWorker.ts +0 -350
- package/src/pages/functions/filepath-routing.test.ts +0 -234
- package/src/pages/functions/filepath-routing.ts +0 -189
- package/src/pages/functions/identifiers.ts +0 -78
- package/src/pages/functions/routes-consolidation.test.ts +0 -250
- package/src/pages/functions/routes-consolidation.ts +0 -73
- package/src/pages/functions/routes-transformation.test.ts +0 -282
- package/src/pages/functions/routes-transformation.ts +0 -115
- package/src/pages/functions/routes-validation.test.ts +0 -403
- package/src/pages/functions/routes-validation.ts +0 -202
- package/src/pages/functions/routes.ts +0 -151
- package/src/pages/functions/tsconfig.json +0 -8
- package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
- package/src/pages/functions.ts +0 -86
- package/src/pages/hash.ts +0 -13
- package/src/pages/index.ts +0 -102
- package/src/pages/projects.tsx +0 -159
- package/src/pages/prompt-select-project.tsx +0 -31
- package/src/pages/publish.tsx +0 -267
- package/src/pages/types.ts +0 -46
- package/src/pages/upload.tsx +0 -469
- package/src/pages/utils.ts +0 -23
- package/src/parse.ts +0 -308
- package/src/paths.ts +0 -71
- package/src/proxy.ts +0 -694
- package/src/publish/index.ts +0 -274
- package/src/publish/publish.ts +0 -1065
- package/src/pubsub/index.ts +0 -286
- package/src/pubsub/pubsub-commands.ts +0 -623
- package/src/queues/cli/commands/consumer/add.ts +0 -71
- package/src/queues/cli/commands/consumer/index.ts +0 -19
- package/src/queues/cli/commands/consumer/remove.ts +0 -31
- package/src/queues/cli/commands/create.ts +0 -25
- package/src/queues/cli/commands/delete.ts +0 -26
- package/src/queues/cli/commands/index.ts +0 -35
- package/src/queues/cli/commands/list.ts +0 -25
- package/src/queues/client.ts +0 -136
- package/src/queues/utils.ts +0 -18
- package/src/r2/constants.ts +0 -4
- package/src/r2/helpers.ts +0 -132
- package/src/r2/index.ts +0 -289
- package/src/routes.ts +0 -140
- package/src/secret/index.ts +0 -377
- package/src/selfsigned.d.ts +0 -29
- package/src/sites.ts +0 -484
- package/src/tail/createTail.ts +0 -415
- package/src/tail/filters.ts +0 -277
- package/src/tail/index.ts +0 -211
- package/src/tail/printing.ts +0 -132
- package/src/traverse-module-graph.ts +0 -54
- package/src/tsconfig-sanity.ts +0 -16
- package/src/type-generation.ts +0 -181
- package/src/update-check.ts +0 -19
- package/src/user/access.ts +0 -68
- package/src/user/auth-variables.ts +0 -113
- package/src/user/choose-account.tsx +0 -39
- package/src/user/generate-auth-url.ts +0 -33
- package/src/user/generate-random-state.ts +0 -16
- package/src/user/index.ts +0 -2
- package/src/user/user.ts +0 -1234
- package/src/utils/collectKeyValues.ts +0 -14
- package/src/utils/render.ts +0 -93
- package/src/whoami.ts +0 -135
- package/src/worker.ts +0 -279
- package/src/yargs-types.ts +0 -37
- 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
|
-
"[31mX [41;31m[[41;97mERROR[41;31m][0m [1m🚨 Error uploading secret for key: secret-name-1:[0m
|
|
189
|
-
|
|
190
|
-
request to
|
|
191
|
-
[4mhttps://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets[0m
|
|
192
|
-
failed, reason: Failed to create secret 1
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
[31mX [41;31m[[41;97mERROR[41;31m][0m [1m🚨 Error uploading secret for key: secret-name-2:[0m
|
|
196
|
-
|
|
197
|
-
request to
|
|
198
|
-
[4mhttps://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets[0m
|
|
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
|
-
"[31mX [41;31m[[41;97mERROR[41;31m][0m [1m🚨 Error uploading secret for key: secret-name-1:[0m
|
|
258
|
-
|
|
259
|
-
request to
|
|
260
|
-
[4mhttps://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets[0m
|
|
261
|
-
failed, reason: Failed to create secret 1
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
[31mX [41;31m[[41;97mERROR[41;31m][0m [1m🚨 Error uploading secret for key: secret-name-3:[0m
|
|
265
|
-
|
|
266
|
-
request to
|
|
267
|
-
[4mhttps://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets[0m
|
|
268
|
-
failed, reason: Failed to create secret 3
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
[31mX [41;31m[[41;97mERROR[41;31m][0m [1m🚨 Error uploading secret for key: secret-name-5:[0m
|
|
272
|
-
|
|
273
|
-
request to
|
|
274
|
-
[4mhttps://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets[0m
|
|
275
|
-
failed, reason: Failed to create secret 5
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
[31mX [41;31m[[41;97mERROR[41;31m][0m [1m🚨 Error uploading secret for key: secret-name-7:[0m
|
|
279
|
-
|
|
280
|
-
request to
|
|
281
|
-
[4mhttps://api.cloudflare.com/client/v4/accounts/some-account-id/workers/scripts/script-name/secrets[0m
|
|
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
|
-
[32mIf you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose[0m"
|
|
344
|
-
`);
|
|
345
|
-
expect(std.err).toMatchInlineSnapshot(`
|
|
346
|
-
"[31mX [41;31m[[41;97mERROR[41;31m][0m [1mRequired Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`[0m
|
|
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
|
-
[32mIf you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose[0m"
|
|
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
|
-
[32mIf you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose[0m"
|
|
576
|
-
`);
|
|
577
|
-
expect(std.err).toMatchInlineSnapshot(`
|
|
578
|
-
"[31mX [41;31m[[41;97mERROR[41;31m][0m [1mRequired Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`[0m
|
|
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
|
-
[32mIf you think this is a bug then please create an issue at https://github.com/cloudflare/workers-sdk/issues/new/choose[0m"
|
|
682
|
-
`);
|
|
683
|
-
expect(std.err).toMatchInlineSnapshot(`
|
|
684
|
-
"[31mX [41;31m[[41;97mERROR[41;31m][0m [1mRequired Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`--name <worker-name>\`[0m
|
|
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
|
-
});
|