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