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