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,496 +0,0 @@
|
|
|
1
|
-
import { rest } from "msw";
|
|
2
|
-
import { mockAccountId, mockApiToken } from "./helpers/mock-account-id";
|
|
3
|
-
import { mockConsoleMethods } from "./helpers/mock-console";
|
|
4
|
-
import { msw } from "./helpers/msw";
|
|
5
|
-
import { runInTempDir } from "./helpers/run-in-tmp";
|
|
6
|
-
import { runWrangler } from "./helpers/run-wrangler";
|
|
7
|
-
import type {
|
|
8
|
-
PubSubNamespace,
|
|
9
|
-
PubSubBroker,
|
|
10
|
-
PubSubBrokerUpdate,
|
|
11
|
-
PubSubBrokerOnPublish,
|
|
12
|
-
} from "../pubsub";
|
|
13
|
-
|
|
14
|
-
describe("wrangler", () => {
|
|
15
|
-
mockAccountId();
|
|
16
|
-
mockApiToken();
|
|
17
|
-
runInTempDir();
|
|
18
|
-
const std = mockConsoleMethods();
|
|
19
|
-
|
|
20
|
-
describe("pubsub", () => {
|
|
21
|
-
describe("help menu", () => {
|
|
22
|
-
it("shows usage details", async () => {
|
|
23
|
-
await runWrangler("pubsub --help");
|
|
24
|
-
expect(std).toMatchInlineSnapshot(`
|
|
25
|
-
Object {
|
|
26
|
-
"debug": "",
|
|
27
|
-
"err": "",
|
|
28
|
-
"info": "",
|
|
29
|
-
"out": "wrangler pubsub
|
|
30
|
-
|
|
31
|
-
📮 Interact and manage Pub/Sub Brokers
|
|
32
|
-
|
|
33
|
-
Commands:
|
|
34
|
-
wrangler pubsub namespace Manage your Pub/Sub Namespaces
|
|
35
|
-
wrangler pubsub broker Interact with your Pub/Sub Brokers
|
|
36
|
-
|
|
37
|
-
Flags:
|
|
38
|
-
-j, --experimental-json-config Experimental: Support wrangler.json [boolean]
|
|
39
|
-
-c, --config Path to .toml configuration file [string]
|
|
40
|
-
-e, --env Environment to use for operations and .env files [string]
|
|
41
|
-
-h, --help Show help [boolean]
|
|
42
|
-
-v, --version Show version number [boolean]
|
|
43
|
-
|
|
44
|
-
👷🏽 'wrangler pubsub ...' commands are currently in private beta. If your account isn't authorized, commands will fail. Visit the Pub/Sub docs for more info: https://developers.cloudflare.com/pub-sub/",
|
|
45
|
-
"warn": "",
|
|
46
|
-
}
|
|
47
|
-
`);
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
describe("namespaces", () => {
|
|
52
|
-
describe("help menu", () => {
|
|
53
|
-
it("shows usage details", async () => {
|
|
54
|
-
await runWrangler("pubsub namespace --help");
|
|
55
|
-
expect(std).toMatchInlineSnapshot(`
|
|
56
|
-
Object {
|
|
57
|
-
"debug": "",
|
|
58
|
-
"err": "",
|
|
59
|
-
"info": "",
|
|
60
|
-
"out": "wrangler pubsub namespace
|
|
61
|
-
|
|
62
|
-
Manage your Pub/Sub Namespaces
|
|
63
|
-
|
|
64
|
-
Commands:
|
|
65
|
-
wrangler pubsub namespace create <name> Create a new Pub/Sub Namespace
|
|
66
|
-
wrangler pubsub namespace list List your existing Pub/Sub Namespaces
|
|
67
|
-
wrangler pubsub namespace delete <name> Delete a Pub/Sub Namespace
|
|
68
|
-
wrangler pubsub namespace describe <name> Describe a Pub/Sub Namespace
|
|
69
|
-
|
|
70
|
-
Flags:
|
|
71
|
-
-j, --experimental-json-config Experimental: Support wrangler.json [boolean]
|
|
72
|
-
-c, --config Path to .toml configuration file [string]
|
|
73
|
-
-e, --env Environment to use for operations and .env files [string]
|
|
74
|
-
-h, --help Show help [boolean]
|
|
75
|
-
-v, --version Show version number [boolean]
|
|
76
|
-
|
|
77
|
-
👷🏽 'wrangler pubsub ...' commands are currently in private beta. If your account isn't authorized, commands will fail. Visit the Pub/Sub docs for more info: https://developers.cloudflare.com/pub-sub/",
|
|
78
|
-
"warn": "",
|
|
79
|
-
}
|
|
80
|
-
`);
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
describe("create", () => {
|
|
85
|
-
function mockCreateRequest(expectedNamespaceName: string) {
|
|
86
|
-
const requests = { count: 0 };
|
|
87
|
-
msw.use(
|
|
88
|
-
rest.post(
|
|
89
|
-
"*/accounts/:accountId/pubsub/namespaces",
|
|
90
|
-
async (req, res, ctx) => {
|
|
91
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
92
|
-
const namespace = await req.json();
|
|
93
|
-
expect(namespace.name).toEqual(expectedNamespaceName);
|
|
94
|
-
requests.count++;
|
|
95
|
-
return res.once(
|
|
96
|
-
ctx.status(200),
|
|
97
|
-
ctx.json({
|
|
98
|
-
success: true,
|
|
99
|
-
errors: [],
|
|
100
|
-
messages: [],
|
|
101
|
-
result: {
|
|
102
|
-
id: "some-namespace-id",
|
|
103
|
-
name: namespace.name,
|
|
104
|
-
created_at: "3005-01-01T00:00:00.000000Z",
|
|
105
|
-
updated_at: "3005-01-01T00:00:00.000000Z",
|
|
106
|
-
},
|
|
107
|
-
})
|
|
108
|
-
);
|
|
109
|
-
}
|
|
110
|
-
)
|
|
111
|
-
);
|
|
112
|
-
return requests;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
it("should create a namespace", async () => {
|
|
116
|
-
const requests = mockCreateRequest("my-namespace");
|
|
117
|
-
await runWrangler("pubsub namespace create my-namespace");
|
|
118
|
-
// TODO: check returned object
|
|
119
|
-
expect(requests.count).toEqual(1);
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
describe("list", () => {
|
|
124
|
-
function mockListRequest(namespaces: PubSubNamespace[]) {
|
|
125
|
-
const requests = { count: 0 };
|
|
126
|
-
msw.use(
|
|
127
|
-
rest.get(
|
|
128
|
-
"*/accounts/:accountId/pubsub/namespaces",
|
|
129
|
-
async (req, res, ctx) => {
|
|
130
|
-
requests.count++;
|
|
131
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
132
|
-
|
|
133
|
-
return res.once(
|
|
134
|
-
ctx.status(200),
|
|
135
|
-
ctx.json({
|
|
136
|
-
success: true,
|
|
137
|
-
errors: [],
|
|
138
|
-
messages: [],
|
|
139
|
-
result: namespaces,
|
|
140
|
-
})
|
|
141
|
-
);
|
|
142
|
-
}
|
|
143
|
-
)
|
|
144
|
-
);
|
|
145
|
-
return requests;
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
it("should list namespaces", async () => {
|
|
149
|
-
const expectedNamespaces: PubSubNamespace[] = [
|
|
150
|
-
{ name: "namespace-1", created_on: "01-01-2001" },
|
|
151
|
-
{ name: "namespace-2", created_on: "01-01-2001" },
|
|
152
|
-
];
|
|
153
|
-
const requests = mockListRequest(expectedNamespaces);
|
|
154
|
-
await runWrangler("pubsub namespace list");
|
|
155
|
-
|
|
156
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
157
|
-
expect(std.out).toMatchInlineSnapshot(`
|
|
158
|
-
"[
|
|
159
|
-
{ name: 'namespace-1', created_on: '01-01-2001' },
|
|
160
|
-
{ name: 'namespace-2', created_on: '01-01-2001' }
|
|
161
|
-
]"
|
|
162
|
-
`);
|
|
163
|
-
expect(requests.count).toEqual(1);
|
|
164
|
-
});
|
|
165
|
-
});
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
describe("brokers", () => {
|
|
169
|
-
describe("help menu", () => {
|
|
170
|
-
it("shows usage details", async () => {
|
|
171
|
-
await runWrangler("pubsub broker --help");
|
|
172
|
-
expect(std).toMatchInlineSnapshot(`
|
|
173
|
-
Object {
|
|
174
|
-
"debug": "",
|
|
175
|
-
"err": "",
|
|
176
|
-
"info": "",
|
|
177
|
-
"out": "wrangler pubsub broker
|
|
178
|
-
|
|
179
|
-
Interact with your Pub/Sub Brokers
|
|
180
|
-
|
|
181
|
-
Commands:
|
|
182
|
-
wrangler pubsub broker create <name> Create a new Pub/Sub Broker
|
|
183
|
-
wrangler pubsub broker update <name> Update an existing Pub/Sub Broker's configuration.
|
|
184
|
-
wrangler pubsub broker list List the Pub/Sub Brokers within a Namespace
|
|
185
|
-
wrangler pubsub broker delete <name> Delete an existing Pub/Sub Broker
|
|
186
|
-
wrangler pubsub broker describe <name> Describe an existing Pub/Sub Broker.
|
|
187
|
-
wrangler pubsub broker issue <name> Issue new client credentials for a specific Pub/Sub Broker.
|
|
188
|
-
wrangler pubsub broker revoke <name> Revoke a set of active client credentials associated with the given Broker
|
|
189
|
-
wrangler pubsub broker unrevoke <name> Restore access to a set of previously revoked client credentials.
|
|
190
|
-
wrangler pubsub broker show-revocations <name> Show all previously revoked client credentials.
|
|
191
|
-
wrangler pubsub broker public-keys <name> Show the public keys used for verifying on-publish hooks and credentials for a Broker.
|
|
192
|
-
|
|
193
|
-
Flags:
|
|
194
|
-
-j, --experimental-json-config Experimental: Support wrangler.json [boolean]
|
|
195
|
-
-c, --config Path to .toml configuration file [string]
|
|
196
|
-
-e, --env Environment to use for operations and .env files [string]
|
|
197
|
-
-h, --help Show help [boolean]
|
|
198
|
-
-v, --version Show version number [boolean]
|
|
199
|
-
|
|
200
|
-
👷🏽 'wrangler pubsub ...' commands are currently in private beta. If your account isn't authorized, commands will fail. Visit the Pub/Sub docs for more info: https://developers.cloudflare.com/pub-sub/",
|
|
201
|
-
"warn": "",
|
|
202
|
-
}
|
|
203
|
-
`);
|
|
204
|
-
});
|
|
205
|
-
});
|
|
206
|
-
|
|
207
|
-
describe("create", () => {
|
|
208
|
-
function mockCreateRequest(expectedBrokerName: string) {
|
|
209
|
-
const requests = { count: 0 };
|
|
210
|
-
msw.use(
|
|
211
|
-
rest.post(
|
|
212
|
-
"*/accounts/:accountId/pubsub/namespaces/:namespaceName/brokers",
|
|
213
|
-
async (req, res, ctx) => {
|
|
214
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
215
|
-
expect(req.params.namespaceName).toEqual("some-namespace");
|
|
216
|
-
const broker = await req.json();
|
|
217
|
-
expect(broker.name).toEqual(expectedBrokerName);
|
|
218
|
-
requests.count++;
|
|
219
|
-
return res.once(
|
|
220
|
-
ctx.status(200),
|
|
221
|
-
ctx.json({
|
|
222
|
-
success: true,
|
|
223
|
-
errors: [],
|
|
224
|
-
messages: [],
|
|
225
|
-
result: {
|
|
226
|
-
name: expectedBrokerName,
|
|
227
|
-
created_on: "01-01-2001",
|
|
228
|
-
},
|
|
229
|
-
})
|
|
230
|
-
);
|
|
231
|
-
}
|
|
232
|
-
)
|
|
233
|
-
);
|
|
234
|
-
return requests;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
it("should create a broker", async () => {
|
|
238
|
-
const requests = mockCreateRequest("my-broker");
|
|
239
|
-
await runWrangler(
|
|
240
|
-
"pubsub broker create my-broker --namespace=some-namespace"
|
|
241
|
-
);
|
|
242
|
-
|
|
243
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
244
|
-
expect(std.out).toMatchInlineSnapshot(
|
|
245
|
-
`"{ name: 'my-broker', created_on: '01-01-2001' }"`
|
|
246
|
-
);
|
|
247
|
-
expect(requests.count).toEqual(1);
|
|
248
|
-
});
|
|
249
|
-
|
|
250
|
-
it("fail to create broker when no namespace is set", async () => {
|
|
251
|
-
await expect(
|
|
252
|
-
runWrangler("pubsub broker create my-broker")
|
|
253
|
-
).rejects.toThrowErrorMatchingInlineSnapshot(
|
|
254
|
-
`"Missing required argument: namespace"`
|
|
255
|
-
);
|
|
256
|
-
});
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
describe("update", () => {
|
|
260
|
-
function mockUpdateRequest(
|
|
261
|
-
expectedBrokerName: string,
|
|
262
|
-
expectedExpiration: number,
|
|
263
|
-
expectedDescription: string,
|
|
264
|
-
expectedOnPublishConfig: PubSubBrokerOnPublish
|
|
265
|
-
) {
|
|
266
|
-
const requests = { count: 0 };
|
|
267
|
-
msw.use(
|
|
268
|
-
rest.patch(
|
|
269
|
-
"*/accounts/:accountId/pubsub/namespaces/:namespaceName/brokers/:brokerName",
|
|
270
|
-
async (req, res, cxt) => {
|
|
271
|
-
requests.count += 1;
|
|
272
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
273
|
-
expect(req.params.namespaceName).toEqual("some-namespace");
|
|
274
|
-
expect(req.params.brokerName).toEqual(expectedBrokerName);
|
|
275
|
-
|
|
276
|
-
const patchBody: PubSubBrokerUpdate = await req.json();
|
|
277
|
-
|
|
278
|
-
expect(patchBody.expiration).toEqual(expectedExpiration);
|
|
279
|
-
expect(patchBody.description).toEqual(expectedDescription);
|
|
280
|
-
expect(patchBody.on_publish).toEqual(expectedOnPublishConfig);
|
|
281
|
-
return res.once(
|
|
282
|
-
cxt.status(200),
|
|
283
|
-
cxt.json({
|
|
284
|
-
success: true,
|
|
285
|
-
errors: [],
|
|
286
|
-
messages: [],
|
|
287
|
-
result: {
|
|
288
|
-
name: expectedBrokerName,
|
|
289
|
-
created_on: "01-01-2001",
|
|
290
|
-
},
|
|
291
|
-
})
|
|
292
|
-
);
|
|
293
|
-
}
|
|
294
|
-
)
|
|
295
|
-
);
|
|
296
|
-
return requests;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
it("should update a broker's properties", async () => {
|
|
300
|
-
const expectedOnPublish: PubSubBrokerOnPublish = {
|
|
301
|
-
url: "https://foo.bar.example.com",
|
|
302
|
-
};
|
|
303
|
-
const requests = mockUpdateRequest(
|
|
304
|
-
"my-broker",
|
|
305
|
-
86400,
|
|
306
|
-
"hello",
|
|
307
|
-
expectedOnPublish
|
|
308
|
-
);
|
|
309
|
-
await runWrangler(
|
|
310
|
-
"pubsub broker update my-broker --namespace=some-namespace --expiration=24h --description='hello' --on-publish-url='https://foo.bar.example.com'"
|
|
311
|
-
);
|
|
312
|
-
|
|
313
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
314
|
-
expect(std.out).toMatchInlineSnapshot(`
|
|
315
|
-
"{ name: 'my-broker', created_on: '01-01-2001' }
|
|
316
|
-
Successfully updated Pub/Sub Broker my-broker"
|
|
317
|
-
`);
|
|
318
|
-
expect(requests.count).toEqual(1);
|
|
319
|
-
});
|
|
320
|
-
});
|
|
321
|
-
|
|
322
|
-
describe("list", () => {
|
|
323
|
-
function mockListRequest(brokers: PubSubBroker[]) {
|
|
324
|
-
const requests = { count: 0 };
|
|
325
|
-
msw.use(
|
|
326
|
-
rest.get(
|
|
327
|
-
"*/accounts/:accountId/pubsub/namespaces/:namespaceName/brokers",
|
|
328
|
-
async (req, res, cxt) => {
|
|
329
|
-
requests.count++;
|
|
330
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
331
|
-
expect(req.params.namespaceName).toEqual("some-namespace");
|
|
332
|
-
return res.once(
|
|
333
|
-
cxt.status(200),
|
|
334
|
-
cxt.json({
|
|
335
|
-
success: true,
|
|
336
|
-
errors: [],
|
|
337
|
-
messages: [],
|
|
338
|
-
result: brokers,
|
|
339
|
-
})
|
|
340
|
-
);
|
|
341
|
-
}
|
|
342
|
-
)
|
|
343
|
-
);
|
|
344
|
-
return requests;
|
|
345
|
-
}
|
|
346
|
-
|
|
347
|
-
it("should list brokers", async () => {
|
|
348
|
-
const expectedBrokers: PubSubBroker[] = [
|
|
349
|
-
{ name: "broker-1", created_on: "01-01-2001" },
|
|
350
|
-
{ name: "broker-2", created_on: "01-01-2001" },
|
|
351
|
-
];
|
|
352
|
-
const requests = mockListRequest(expectedBrokers);
|
|
353
|
-
await runWrangler("pubsub broker list --namespace=some-namespace");
|
|
354
|
-
|
|
355
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
356
|
-
expect(std.out).toMatchInlineSnapshot(`
|
|
357
|
-
"[
|
|
358
|
-
{ name: 'broker-1', created_on: '01-01-2001' },
|
|
359
|
-
{ name: 'broker-2', created_on: '01-01-2001' }
|
|
360
|
-
]"
|
|
361
|
-
`);
|
|
362
|
-
expect(requests.count).toEqual(1);
|
|
363
|
-
});
|
|
364
|
-
});
|
|
365
|
-
|
|
366
|
-
describe("describe", () => {
|
|
367
|
-
function mockGetRequest(broker: PubSubBroker) {
|
|
368
|
-
const requests = { count: 0 };
|
|
369
|
-
msw.use(
|
|
370
|
-
rest.get(
|
|
371
|
-
"*/accounts/:accountId/pubsub/namespaces/:namespaceName/brokers/:brokerName",
|
|
372
|
-
(req, res, cxt) => {
|
|
373
|
-
requests.count++;
|
|
374
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
375
|
-
expect(req.params.namespaceName).toEqual("some-namespace");
|
|
376
|
-
expect(req.params.brokerName).toEqual(broker.name);
|
|
377
|
-
return res.once(
|
|
378
|
-
cxt.status(200),
|
|
379
|
-
cxt.json({
|
|
380
|
-
success: true,
|
|
381
|
-
errors: [],
|
|
382
|
-
messages: [],
|
|
383
|
-
result: broker,
|
|
384
|
-
})
|
|
385
|
-
);
|
|
386
|
-
}
|
|
387
|
-
)
|
|
388
|
-
);
|
|
389
|
-
return requests;
|
|
390
|
-
}
|
|
391
|
-
|
|
392
|
-
it("should describe a single broker", async () => {
|
|
393
|
-
const requests = mockGetRequest({ id: "1234", name: "my-broker" });
|
|
394
|
-
await runWrangler(
|
|
395
|
-
"pubsub broker describe my-broker --namespace=some-namespace"
|
|
396
|
-
);
|
|
397
|
-
|
|
398
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
399
|
-
expect(std.out).toMatchInlineSnapshot(
|
|
400
|
-
`"{ id: '1234', name: 'my-broker' }"`
|
|
401
|
-
);
|
|
402
|
-
expect(requests.count).toEqual(1);
|
|
403
|
-
});
|
|
404
|
-
});
|
|
405
|
-
|
|
406
|
-
describe("issue", () => {
|
|
407
|
-
function mockIssueRequest(expectedBrokerName: string) {
|
|
408
|
-
const requests = { count: 0 };
|
|
409
|
-
msw.use(
|
|
410
|
-
rest.get(
|
|
411
|
-
"*/accounts/:accountId/pubsub/namespaces/:namespaceName/brokers/:brokerName/credentials",
|
|
412
|
-
(req, res, cxt) => {
|
|
413
|
-
requests.count++;
|
|
414
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
415
|
-
expect(req.params.namespaceName).toEqual("some-namespace");
|
|
416
|
-
expect(req.params.brokerName).toEqual(expectedBrokerName);
|
|
417
|
-
return res.once(
|
|
418
|
-
cxt.status(200),
|
|
419
|
-
cxt.json({
|
|
420
|
-
success: true,
|
|
421
|
-
errors: [],
|
|
422
|
-
messages: [],
|
|
423
|
-
result: {
|
|
424
|
-
"MOCK-89T6DXG3SVG1WQRA": `<base-64-encoded-JWT>`,
|
|
425
|
-
"MOCK-393REE4WRRE4NHAV96": `<base-64-encoded-JWT>`,
|
|
426
|
-
},
|
|
427
|
-
})
|
|
428
|
-
);
|
|
429
|
-
}
|
|
430
|
-
)
|
|
431
|
-
);
|
|
432
|
-
return requests;
|
|
433
|
-
}
|
|
434
|
-
|
|
435
|
-
it("should issue a token for the broker", async () => {
|
|
436
|
-
const requests = mockIssueRequest("my-broker");
|
|
437
|
-
await runWrangler(
|
|
438
|
-
"pubsub broker issue my-broker --namespace=some-namespace"
|
|
439
|
-
);
|
|
440
|
-
|
|
441
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
442
|
-
expect(std.out).toMatchInlineSnapshot(`
|
|
443
|
-
"🔑 Issuing credential(s) for my-broker.some-namespace...
|
|
444
|
-
{
|
|
445
|
-
'MOCK-89T6DXG3SVG1WQRA': '<base-64-encoded-JWT>',
|
|
446
|
-
'MOCK-393REE4WRRE4NHAV96': '<base-64-encoded-JWT>'
|
|
447
|
-
}"
|
|
448
|
-
`);
|
|
449
|
-
expect(requests.count).toEqual(1);
|
|
450
|
-
});
|
|
451
|
-
});
|
|
452
|
-
|
|
453
|
-
describe("public-keys", () => {
|
|
454
|
-
function mockIssueRequest(expectedBrokerName: string) {
|
|
455
|
-
const requests = { count: 0 };
|
|
456
|
-
msw.use(
|
|
457
|
-
rest.get(
|
|
458
|
-
"*/accounts/:accountId/pubsub/namespaces/:namespaceName/brokers/:brokerName/publickeys",
|
|
459
|
-
(req, res, cxt) => {
|
|
460
|
-
requests.count++;
|
|
461
|
-
expect(req.params.accountId).toEqual("some-account-id");
|
|
462
|
-
expect(req.params.namespaceName).toEqual("some-namespace");
|
|
463
|
-
expect(req.params.brokerName).toEqual(expectedBrokerName);
|
|
464
|
-
return res.once(
|
|
465
|
-
cxt.status(200),
|
|
466
|
-
cxt.json({
|
|
467
|
-
success: true,
|
|
468
|
-
errors: [],
|
|
469
|
-
messages: [],
|
|
470
|
-
result: {
|
|
471
|
-
public_keys: "Mock-Public-Key",
|
|
472
|
-
},
|
|
473
|
-
})
|
|
474
|
-
);
|
|
475
|
-
}
|
|
476
|
-
)
|
|
477
|
-
);
|
|
478
|
-
return requests;
|
|
479
|
-
}
|
|
480
|
-
|
|
481
|
-
it("should return the public keys for a broker", async () => {
|
|
482
|
-
const requests = mockIssueRequest("my-broker");
|
|
483
|
-
await runWrangler(
|
|
484
|
-
"pubsub broker public-keys my-broker --namespace=some-namespace"
|
|
485
|
-
);
|
|
486
|
-
|
|
487
|
-
expect(std.err).toMatchInlineSnapshot(`""`);
|
|
488
|
-
expect(std.out).toMatchInlineSnapshot(
|
|
489
|
-
`"{ public_keys: 'Mock-Public-Key' }"`
|
|
490
|
-
);
|
|
491
|
-
expect(requests.count).toEqual(1);
|
|
492
|
-
});
|
|
493
|
-
});
|
|
494
|
-
});
|
|
495
|
-
});
|
|
496
|
-
});
|