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,816 +0,0 @@
|
|
|
1
|
-
import * as fs from "node:fs";
|
|
2
|
-
import { unstable_dev } from "../api";
|
|
3
|
-
import { runInTempDir } from "./helpers/run-in-tmp";
|
|
4
|
-
|
|
5
|
-
jest.unmock("undici");
|
|
6
|
-
|
|
7
|
-
describe("workers change behaviour with middleware with wrangler dev", () => {
|
|
8
|
-
runInTempDir();
|
|
9
|
-
|
|
10
|
-
process.env.EXPERIMENTAL_MIDDLEWARE = "true";
|
|
11
|
-
|
|
12
|
-
describe("module workers", () => {
|
|
13
|
-
it("should register a middleware and intercept", async () => {
|
|
14
|
-
const scriptContent = `
|
|
15
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
16
|
-
const response = await middlewareCtx.next(request, env);
|
|
17
|
-
const text = await response.text();
|
|
18
|
-
return new Response(text + ' world');
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export default {
|
|
22
|
-
middleware: [middleware],
|
|
23
|
-
fetch(request, env, ctx) {
|
|
24
|
-
return new Response('Hello');
|
|
25
|
-
}
|
|
26
|
-
};
|
|
27
|
-
`;
|
|
28
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
29
|
-
|
|
30
|
-
const worker = await unstable_dev("index.js", {
|
|
31
|
-
experimental: {
|
|
32
|
-
disableExperimentalWarning: true,
|
|
33
|
-
disableDevRegistry: true,
|
|
34
|
-
},
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
const resp = await worker.fetch();
|
|
38
|
-
let text;
|
|
39
|
-
if (resp) text = await resp.text();
|
|
40
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
41
|
-
await worker.stop();
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
it("should be able to access scheduled workers from middleware", async () => {
|
|
45
|
-
const scriptContent = `
|
|
46
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
47
|
-
await middlewareCtx.dispatch("scheduled", { cron: "* * * * *" });
|
|
48
|
-
return new Response("OK");
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export default {
|
|
52
|
-
middleware: [middleware],
|
|
53
|
-
scheduled(controller, env, ctx) {
|
|
54
|
-
// Scheduled worker called
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
`;
|
|
58
|
-
|
|
59
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
60
|
-
|
|
61
|
-
const worker = await unstable_dev("index.js", {
|
|
62
|
-
experimental: {
|
|
63
|
-
disableExperimentalWarning: true,
|
|
64
|
-
disableDevRegistry: true,
|
|
65
|
-
},
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
const resp = await worker.fetch();
|
|
69
|
-
let text;
|
|
70
|
-
if (resp) text = await resp.text();
|
|
71
|
-
expect(text).toMatchInlineSnapshot(`"OK"`);
|
|
72
|
-
await worker.stop();
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
it("should trigger an error in a scheduled work from middleware", async () => {
|
|
76
|
-
const scriptContent = `
|
|
77
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
78
|
-
try {
|
|
79
|
-
await middlewareCtx.dispatch("scheduled", { cron: "* * * * *" });
|
|
80
|
-
} catch (e) {
|
|
81
|
-
return new Response(e.message);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export default {
|
|
86
|
-
middleware: [middleware],
|
|
87
|
-
scheduled(controller, env, ctx) {
|
|
88
|
-
throw new Error("Error in scheduled worker");
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
`;
|
|
92
|
-
|
|
93
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
94
|
-
|
|
95
|
-
const worker = await unstable_dev("index.js", {
|
|
96
|
-
experimental: {
|
|
97
|
-
disableExperimentalWarning: true,
|
|
98
|
-
disableDevRegistry: true,
|
|
99
|
-
},
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
const resp = await worker.fetch();
|
|
103
|
-
let text;
|
|
104
|
-
if (resp) text = await resp.text();
|
|
105
|
-
expect(text).toMatchInlineSnapshot(`"Error in scheduled worker"`);
|
|
106
|
-
await worker.stop();
|
|
107
|
-
});
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
describe("service workers", () => {
|
|
111
|
-
it("should register a middleware and intercept using addMiddleware", async () => {
|
|
112
|
-
const scriptContent = `
|
|
113
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
114
|
-
const response = await middlewareCtx.next(request, env);
|
|
115
|
-
const text = await response.text();
|
|
116
|
-
return new Response(text + ' world');
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
addMiddleware(middleware);
|
|
120
|
-
|
|
121
|
-
addEventListener("fetch", (event) => {
|
|
122
|
-
event.respondWith(new Response('Hello'));
|
|
123
|
-
});
|
|
124
|
-
`;
|
|
125
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
126
|
-
|
|
127
|
-
const worker = await unstable_dev("index.js", {
|
|
128
|
-
experimental: {
|
|
129
|
-
disableExperimentalWarning: true,
|
|
130
|
-
disableDevRegistry: true,
|
|
131
|
-
},
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
const resp = await worker.fetch();
|
|
135
|
-
let text;
|
|
136
|
-
if (resp) text = await resp.text();
|
|
137
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
138
|
-
await worker.stop();
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
it("should register a middleware and intercept using addMiddlewareInternal", async () => {
|
|
142
|
-
const scriptContent = `
|
|
143
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
144
|
-
const response = await middlewareCtx.next(request, env);
|
|
145
|
-
const text = await response.text();
|
|
146
|
-
return new Response(text + ' world');
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
addMiddlewareInternal(middleware);
|
|
150
|
-
|
|
151
|
-
addEventListener("fetch", (event) => {
|
|
152
|
-
event.respondWith(new Response('Hello'));
|
|
153
|
-
});
|
|
154
|
-
`;
|
|
155
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
156
|
-
|
|
157
|
-
const worker = await unstable_dev("index.js", {
|
|
158
|
-
experimental: {
|
|
159
|
-
disableExperimentalWarning: true,
|
|
160
|
-
disableDevRegistry: true,
|
|
161
|
-
},
|
|
162
|
-
});
|
|
163
|
-
|
|
164
|
-
const resp = await worker.fetch();
|
|
165
|
-
let text;
|
|
166
|
-
if (resp) text = await resp.text();
|
|
167
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
168
|
-
await worker.stop();
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
it("should be able to access scheduled workers from middleware", async () => {
|
|
172
|
-
const scriptContent = `
|
|
173
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
174
|
-
await middlewareCtx.dispatch("scheduled", { cron: "* * * * *" });
|
|
175
|
-
return new Response("OK");
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
addMiddleware(middleware);
|
|
179
|
-
|
|
180
|
-
addEventListener("scheduled", (event) => {
|
|
181
|
-
// Scheduled worker called
|
|
182
|
-
});
|
|
183
|
-
`;
|
|
184
|
-
|
|
185
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
186
|
-
|
|
187
|
-
const worker = await unstable_dev("index.js", {
|
|
188
|
-
experimental: {
|
|
189
|
-
disableExperimentalWarning: true,
|
|
190
|
-
disableDevRegistry: true,
|
|
191
|
-
},
|
|
192
|
-
});
|
|
193
|
-
|
|
194
|
-
const resp = await worker.fetch();
|
|
195
|
-
let text;
|
|
196
|
-
if (resp) text = await resp.text();
|
|
197
|
-
expect(text).toMatchInlineSnapshot(`"OK"`);
|
|
198
|
-
await worker.stop();
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
it("should trigger an error in a scheduled work from middleware", async () => {
|
|
202
|
-
const scriptContent = `
|
|
203
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
204
|
-
try {
|
|
205
|
-
await middlewareCtx.dispatch("scheduled", { cron: "* * * * *" });
|
|
206
|
-
} catch (e) {
|
|
207
|
-
return new Response(e.message);
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
addMiddleware(middleware);
|
|
212
|
-
|
|
213
|
-
addEventListener("scheduled", (event) => {
|
|
214
|
-
throw new Error("Error in scheduled worker");
|
|
215
|
-
});
|
|
216
|
-
`;
|
|
217
|
-
|
|
218
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
219
|
-
|
|
220
|
-
const worker = await unstable_dev("index.js", {
|
|
221
|
-
experimental: {
|
|
222
|
-
disableExperimentalWarning: true,
|
|
223
|
-
disableDevRegistry: true,
|
|
224
|
-
},
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
const resp = await worker.fetch();
|
|
228
|
-
let text;
|
|
229
|
-
if (resp) text = await resp.text();
|
|
230
|
-
expect(text).toMatchInlineSnapshot(`"Error in scheduled worker"`);
|
|
231
|
-
await worker.stop();
|
|
232
|
-
});
|
|
233
|
-
});
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
describe("unchanged functionality when wrapping with middleware", () => {
|
|
237
|
-
runInTempDir();
|
|
238
|
-
|
|
239
|
-
process.env.EXPERIMENTAL_MIDDLEWARE = "true";
|
|
240
|
-
|
|
241
|
-
describe("module workers", () => {
|
|
242
|
-
it("should return Hello World with no middleware export", async () => {
|
|
243
|
-
const scriptContent = `
|
|
244
|
-
export default {
|
|
245
|
-
fetch(request, env, ctx) {
|
|
246
|
-
return new Response("Hello world");
|
|
247
|
-
}
|
|
248
|
-
};
|
|
249
|
-
`;
|
|
250
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
251
|
-
|
|
252
|
-
const worker = await unstable_dev("index.js", {
|
|
253
|
-
experimental: {
|
|
254
|
-
disableExperimentalWarning: true,
|
|
255
|
-
disableDevRegistry: true,
|
|
256
|
-
},
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
const resp = await worker.fetch();
|
|
260
|
-
if (resp) {
|
|
261
|
-
const text = await resp.text();
|
|
262
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
263
|
-
}
|
|
264
|
-
await worker.stop();
|
|
265
|
-
});
|
|
266
|
-
|
|
267
|
-
it("should return hello world with empty middleware array", async () => {
|
|
268
|
-
const scriptContent = `
|
|
269
|
-
export default {
|
|
270
|
-
middleware: [],
|
|
271
|
-
fetch() {
|
|
272
|
-
return new Response("Hello world");
|
|
273
|
-
}
|
|
274
|
-
}
|
|
275
|
-
`;
|
|
276
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
277
|
-
|
|
278
|
-
const worker = await unstable_dev("index.js", {
|
|
279
|
-
experimental: {
|
|
280
|
-
disableExperimentalWarning: true,
|
|
281
|
-
disableDevRegistry: true,
|
|
282
|
-
},
|
|
283
|
-
});
|
|
284
|
-
|
|
285
|
-
const resp = await worker.fetch();
|
|
286
|
-
let text;
|
|
287
|
-
if (resp) text = await resp.text();
|
|
288
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
289
|
-
await worker.stop();
|
|
290
|
-
});
|
|
291
|
-
|
|
292
|
-
it("should return hello world passing through middleware", async () => {
|
|
293
|
-
const scriptContent = `
|
|
294
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
295
|
-
return middlewareCtx.next(request, env);
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
export default {
|
|
299
|
-
middleware: [middleware],
|
|
300
|
-
fetch(request, env, ctx) {
|
|
301
|
-
return new Response("Hello world");
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
`;
|
|
305
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
306
|
-
|
|
307
|
-
const worker = await unstable_dev("index.js", {
|
|
308
|
-
experimental: {
|
|
309
|
-
disableExperimentalWarning: true,
|
|
310
|
-
disableDevRegistry: true,
|
|
311
|
-
},
|
|
312
|
-
});
|
|
313
|
-
|
|
314
|
-
const resp = await worker.fetch();
|
|
315
|
-
if (resp) {
|
|
316
|
-
const text = await resp.text();
|
|
317
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
318
|
-
}
|
|
319
|
-
await worker.stop();
|
|
320
|
-
});
|
|
321
|
-
|
|
322
|
-
it("should return hello world with multiple middleware in array", async () => {
|
|
323
|
-
const scriptContent = `
|
|
324
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
325
|
-
return middlewareCtx.next(request, env);
|
|
326
|
-
}
|
|
327
|
-
const middleware2 = async (request, env, _ctx, middlewareCtx) => {
|
|
328
|
-
return middlewareCtx.next(request, env);
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
export default {
|
|
333
|
-
middleware: [middleware, middleware2],
|
|
334
|
-
fetch() {
|
|
335
|
-
return new Response("Hello world");
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
`;
|
|
339
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
340
|
-
|
|
341
|
-
const worker = await unstable_dev("index.js", {
|
|
342
|
-
experimental: {
|
|
343
|
-
disableExperimentalWarning: true,
|
|
344
|
-
disableDevRegistry: true,
|
|
345
|
-
},
|
|
346
|
-
});
|
|
347
|
-
|
|
348
|
-
const resp = await worker.fetch();
|
|
349
|
-
let text;
|
|
350
|
-
if (resp) text = await resp.text();
|
|
351
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
352
|
-
await worker.stop();
|
|
353
|
-
});
|
|
354
|
-
|
|
355
|
-
it("should leave response headers unchanged with middleware", async () => {
|
|
356
|
-
const scriptContent = `
|
|
357
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
358
|
-
return middlewareCtx.next(request, env);
|
|
359
|
-
}
|
|
360
|
-
|
|
361
|
-
export default {
|
|
362
|
-
middleware: [middleware],
|
|
363
|
-
fetch() {
|
|
364
|
-
return new Response("Hello world", { status: 500, headers: { "x-test": "test" } });
|
|
365
|
-
}
|
|
366
|
-
}
|
|
367
|
-
`;
|
|
368
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
369
|
-
|
|
370
|
-
const worker = await unstable_dev("index.js", {
|
|
371
|
-
experimental: {
|
|
372
|
-
disableExperimentalWarning: true,
|
|
373
|
-
disableDevRegistry: true,
|
|
374
|
-
},
|
|
375
|
-
});
|
|
376
|
-
|
|
377
|
-
const resp = await worker.fetch();
|
|
378
|
-
const status = resp?.status;
|
|
379
|
-
let text;
|
|
380
|
-
if (resp) text = await resp.text();
|
|
381
|
-
const testHeader = resp?.headers.get("x-test");
|
|
382
|
-
expect(status).toEqual(500);
|
|
383
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
384
|
-
expect(testHeader).toEqual("test");
|
|
385
|
-
await worker.stop();
|
|
386
|
-
});
|
|
387
|
-
|
|
388
|
-
it("waitUntil should not block responses", async () => {
|
|
389
|
-
const scriptContent = `
|
|
390
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
391
|
-
return middlewareCtx.next(request, env);
|
|
392
|
-
}
|
|
393
|
-
|
|
394
|
-
export default {
|
|
395
|
-
middleware: [middleware],
|
|
396
|
-
async fetch(request, env, ctx) {
|
|
397
|
-
let count = 0;
|
|
398
|
-
ctx.waitUntil(new Promise(resolve => {
|
|
399
|
-
setTimeout(() => {
|
|
400
|
-
count += 1;
|
|
401
|
-
console.log("waitUntil", count);
|
|
402
|
-
resolve()
|
|
403
|
-
}, 1000);
|
|
404
|
-
}));
|
|
405
|
-
return new Response("Hello world" + String(count));
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
`;
|
|
409
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
410
|
-
|
|
411
|
-
const worker = await unstable_dev("index.js", {
|
|
412
|
-
experimental: {
|
|
413
|
-
disableExperimentalWarning: true,
|
|
414
|
-
disableDevRegistry: true,
|
|
415
|
-
},
|
|
416
|
-
});
|
|
417
|
-
|
|
418
|
-
const resp = await worker.fetch();
|
|
419
|
-
let text;
|
|
420
|
-
if (resp) text = await resp.text();
|
|
421
|
-
expect(text).toMatchInlineSnapshot(`"Hello world0"`);
|
|
422
|
-
await worker.stop();
|
|
423
|
-
});
|
|
424
|
-
});
|
|
425
|
-
|
|
426
|
-
describe("service workers", () => {
|
|
427
|
-
it("should return Hello World with no middleware export", async () => {
|
|
428
|
-
const scriptContent = `
|
|
429
|
-
addEventListener("fetch", (event) => {
|
|
430
|
-
event.respondWith(new Response("Hello world"));
|
|
431
|
-
});
|
|
432
|
-
`;
|
|
433
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
434
|
-
|
|
435
|
-
const worker = await unstable_dev("index.js", {
|
|
436
|
-
experimental: {
|
|
437
|
-
disableExperimentalWarning: true,
|
|
438
|
-
disableDevRegistry: true,
|
|
439
|
-
},
|
|
440
|
-
});
|
|
441
|
-
|
|
442
|
-
const resp = await worker.fetch();
|
|
443
|
-
if (resp) {
|
|
444
|
-
const text = await resp.text();
|
|
445
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
446
|
-
}
|
|
447
|
-
await worker.stop();
|
|
448
|
-
});
|
|
449
|
-
|
|
450
|
-
it("should return hello world with empty middleware array", async () => {
|
|
451
|
-
const scriptContent = `
|
|
452
|
-
addMiddleware([]);
|
|
453
|
-
|
|
454
|
-
addEventListener("fetch", (event) => {
|
|
455
|
-
event.respondWith(new Response("Hello world"));
|
|
456
|
-
});
|
|
457
|
-
`;
|
|
458
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
459
|
-
|
|
460
|
-
const worker = await unstable_dev("index.js", {
|
|
461
|
-
experimental: {
|
|
462
|
-
disableExperimentalWarning: true,
|
|
463
|
-
disableDevRegistry: true,
|
|
464
|
-
},
|
|
465
|
-
});
|
|
466
|
-
|
|
467
|
-
const resp = await worker.fetch();
|
|
468
|
-
let text;
|
|
469
|
-
if (resp) text = await resp.text();
|
|
470
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
471
|
-
await worker.stop();
|
|
472
|
-
});
|
|
473
|
-
|
|
474
|
-
it("should return hello world passing through middleware", async () => {
|
|
475
|
-
const scriptContent = `
|
|
476
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
477
|
-
return middlewareCtx.next(request, env);
|
|
478
|
-
}
|
|
479
|
-
|
|
480
|
-
addMiddleware(middleware);
|
|
481
|
-
|
|
482
|
-
addEventListener("fetch", (event) => {
|
|
483
|
-
event.respondWith(new Response("Hello world"));
|
|
484
|
-
});
|
|
485
|
-
`;
|
|
486
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
487
|
-
|
|
488
|
-
const worker = await unstable_dev("index.js", {
|
|
489
|
-
experimental: {
|
|
490
|
-
disableExperimentalWarning: true,
|
|
491
|
-
disableDevRegistry: true,
|
|
492
|
-
},
|
|
493
|
-
});
|
|
494
|
-
|
|
495
|
-
const resp = await worker.fetch();
|
|
496
|
-
if (resp) {
|
|
497
|
-
const text = await resp.text();
|
|
498
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
499
|
-
}
|
|
500
|
-
await worker.stop();
|
|
501
|
-
});
|
|
502
|
-
|
|
503
|
-
it("should return hello world with addMiddleware function called multiple times", async () => {
|
|
504
|
-
const scriptContent = `
|
|
505
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
506
|
-
return middlewareCtx.next(request, env);
|
|
507
|
-
}
|
|
508
|
-
const middleware2 = async (request, env, _ctx, middlewareCtx) => {
|
|
509
|
-
return middlewareCtx.next(request, env);
|
|
510
|
-
}
|
|
511
|
-
|
|
512
|
-
addMiddleware(middleware);
|
|
513
|
-
addMiddleware(middleware2);
|
|
514
|
-
|
|
515
|
-
addEventListener("fetch", (event) => {
|
|
516
|
-
event.respondWith(new Response("Hello world"));
|
|
517
|
-
});
|
|
518
|
-
`;
|
|
519
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
520
|
-
|
|
521
|
-
const worker = await unstable_dev("index.js", {
|
|
522
|
-
experimental: {
|
|
523
|
-
disableExperimentalWarning: true,
|
|
524
|
-
disableDevRegistry: true,
|
|
525
|
-
},
|
|
526
|
-
});
|
|
527
|
-
|
|
528
|
-
const resp = await worker.fetch();
|
|
529
|
-
let text;
|
|
530
|
-
if (resp) text = await resp.text();
|
|
531
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
532
|
-
await worker.stop();
|
|
533
|
-
});
|
|
534
|
-
|
|
535
|
-
it("should return hello world with addMiddleware function called with array of middleware", async () => {
|
|
536
|
-
const scriptContent = `
|
|
537
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
538
|
-
return middlewareCtx.next(request, env);
|
|
539
|
-
}
|
|
540
|
-
const middleware2 = async (request, env, _ctx, middlewareCtx) => {
|
|
541
|
-
return middlewareCtx.next(request, env);
|
|
542
|
-
}
|
|
543
|
-
|
|
544
|
-
addMiddleware(middleware, middleware2);
|
|
545
|
-
|
|
546
|
-
addEventListener("fetch", (event) => {
|
|
547
|
-
event.respondWith(new Response("Hello world"));
|
|
548
|
-
});
|
|
549
|
-
`;
|
|
550
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
551
|
-
|
|
552
|
-
const worker = await unstable_dev("index.js", {
|
|
553
|
-
experimental: {
|
|
554
|
-
disableExperimentalWarning: true,
|
|
555
|
-
disableDevRegistry: true,
|
|
556
|
-
},
|
|
557
|
-
});
|
|
558
|
-
|
|
559
|
-
const resp = await worker.fetch();
|
|
560
|
-
let text;
|
|
561
|
-
if (resp) text = await resp.text();
|
|
562
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
563
|
-
await worker.stop();
|
|
564
|
-
});
|
|
565
|
-
|
|
566
|
-
it("should return hello world with addMiddlewareInternal function called multiple times", async () => {
|
|
567
|
-
const scriptContent = `
|
|
568
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
569
|
-
return middlewareCtx.next(request, env);
|
|
570
|
-
}
|
|
571
|
-
const middleware2 = async (request, env, _ctx, middlewareCtx) => {
|
|
572
|
-
return middlewareCtx.next(request, env);
|
|
573
|
-
}
|
|
574
|
-
|
|
575
|
-
addMiddlewareInternal(middleware);
|
|
576
|
-
addMiddlewareInternal(middleware2);
|
|
577
|
-
|
|
578
|
-
addEventListener("fetch", (event) => {
|
|
579
|
-
event.respondWith(new Response("Hello world"));
|
|
580
|
-
});
|
|
581
|
-
`;
|
|
582
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
583
|
-
|
|
584
|
-
const worker = await unstable_dev("index.js", {
|
|
585
|
-
experimental: {
|
|
586
|
-
disableExperimentalWarning: true,
|
|
587
|
-
disableDevRegistry: true,
|
|
588
|
-
},
|
|
589
|
-
});
|
|
590
|
-
|
|
591
|
-
const resp = await worker.fetch();
|
|
592
|
-
let text;
|
|
593
|
-
if (resp) text = await resp.text();
|
|
594
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
595
|
-
await worker.stop();
|
|
596
|
-
});
|
|
597
|
-
|
|
598
|
-
it("should return hello world with addMiddlewareInternal function called with array of middleware", async () => {
|
|
599
|
-
const scriptContent = `
|
|
600
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
601
|
-
return middlewareCtx.next(request, env);
|
|
602
|
-
}
|
|
603
|
-
const middleware2 = async (request, env, _ctx, middlewareCtx) => {
|
|
604
|
-
return middlewareCtx.next(request, env);
|
|
605
|
-
}
|
|
606
|
-
|
|
607
|
-
addMiddlewareInternal(middleware, middleware2);
|
|
608
|
-
|
|
609
|
-
addEventListener("fetch", (event) => {
|
|
610
|
-
event.respondWith(new Response("Hello world"));
|
|
611
|
-
});
|
|
612
|
-
`;
|
|
613
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
614
|
-
|
|
615
|
-
const worker = await unstable_dev("index.js", {
|
|
616
|
-
experimental: {
|
|
617
|
-
disableExperimentalWarning: true,
|
|
618
|
-
disableDevRegistry: true,
|
|
619
|
-
},
|
|
620
|
-
});
|
|
621
|
-
|
|
622
|
-
const resp = await worker.fetch();
|
|
623
|
-
let text;
|
|
624
|
-
if (resp) text = await resp.text();
|
|
625
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
626
|
-
await worker.stop();
|
|
627
|
-
});
|
|
628
|
-
|
|
629
|
-
it("should return hello world with both addMiddleware and addMiddlewareInternal called", async () => {
|
|
630
|
-
const scriptContent = `
|
|
631
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
632
|
-
return middlewareCtx.next(request, env);
|
|
633
|
-
}
|
|
634
|
-
const middleware2 = async (request, env, _ctx, middlewareCtx) => {
|
|
635
|
-
return middlewareCtx.next(request, env);
|
|
636
|
-
}
|
|
637
|
-
|
|
638
|
-
addMiddleware(middleware);
|
|
639
|
-
addMiddlewareInternal(middleware2);
|
|
640
|
-
|
|
641
|
-
addEventListener("fetch", (event) => {
|
|
642
|
-
event.respondWith(new Response("Hello world"));
|
|
643
|
-
});
|
|
644
|
-
`;
|
|
645
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
646
|
-
|
|
647
|
-
const worker = await unstable_dev("index.js", {
|
|
648
|
-
experimental: {
|
|
649
|
-
disableExperimentalWarning: true,
|
|
650
|
-
disableDevRegistry: true,
|
|
651
|
-
},
|
|
652
|
-
});
|
|
653
|
-
|
|
654
|
-
const resp = await worker.fetch();
|
|
655
|
-
let text;
|
|
656
|
-
if (resp) text = await resp.text();
|
|
657
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
658
|
-
await worker.stop();
|
|
659
|
-
});
|
|
660
|
-
|
|
661
|
-
it("should leave response headers unchanged with middleware", async () => {
|
|
662
|
-
const scriptContent = `
|
|
663
|
-
const middleware = async (request, env, _ctx, middlewareCtx) => {
|
|
664
|
-
return middlewareCtx.next(request, env);
|
|
665
|
-
}
|
|
666
|
-
|
|
667
|
-
addEventListener("fetch", (event) => {
|
|
668
|
-
event.respondWith(new Response("Hello world", { status: 500, headers: { "x-test": "test" } }));
|
|
669
|
-
});
|
|
670
|
-
`;
|
|
671
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
672
|
-
|
|
673
|
-
const worker = await unstable_dev("index.js", {
|
|
674
|
-
experimental: {
|
|
675
|
-
disableExperimentalWarning: true,
|
|
676
|
-
disableDevRegistry: true,
|
|
677
|
-
},
|
|
678
|
-
});
|
|
679
|
-
|
|
680
|
-
const resp = await worker.fetch();
|
|
681
|
-
const status = resp?.status;
|
|
682
|
-
let text;
|
|
683
|
-
if (resp) text = await resp.text();
|
|
684
|
-
const testHeader = resp?.headers.get("x-test");
|
|
685
|
-
expect(status).toEqual(500);
|
|
686
|
-
expect(text).toMatchInlineSnapshot(`"Hello world"`);
|
|
687
|
-
expect(testHeader).toEqual("test");
|
|
688
|
-
await worker.stop();
|
|
689
|
-
});
|
|
690
|
-
|
|
691
|
-
it("should allow multiple addEventListeners for fetch", async () => {
|
|
692
|
-
const scriptContent = `
|
|
693
|
-
let count = 0;
|
|
694
|
-
|
|
695
|
-
addEventListener("fetch", (event) => {
|
|
696
|
-
count += 1;
|
|
697
|
-
});
|
|
698
|
-
|
|
699
|
-
addEventListener("fetch", (event) => {
|
|
700
|
-
event.respondWith(new Response("Hello world" + String(count)));
|
|
701
|
-
});
|
|
702
|
-
`;
|
|
703
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
704
|
-
|
|
705
|
-
const worker = await unstable_dev("index.js", {
|
|
706
|
-
experimental: {
|
|
707
|
-
disableExperimentalWarning: true,
|
|
708
|
-
disableDevRegistry: true,
|
|
709
|
-
},
|
|
710
|
-
});
|
|
711
|
-
|
|
712
|
-
const resp = await worker.fetch();
|
|
713
|
-
let text;
|
|
714
|
-
if (resp) text = await resp.text();
|
|
715
|
-
expect(text).toMatchInlineSnapshot(`"Hello world1"`);
|
|
716
|
-
await worker.stop();
|
|
717
|
-
});
|
|
718
|
-
|
|
719
|
-
it("waitUntil should not block responses", async () => {
|
|
720
|
-
const scriptContent = `
|
|
721
|
-
addEventListener("fetch", (event) => {
|
|
722
|
-
|
|
723
|
-
let count = 0;
|
|
724
|
-
event.waitUntil(new Promise((resolve) => {
|
|
725
|
-
setTimeout(() => {
|
|
726
|
-
count +=1;
|
|
727
|
-
console.log('waitUntil', count);
|
|
728
|
-
resolve();
|
|
729
|
-
}, 1000);
|
|
730
|
-
}));
|
|
731
|
-
event.respondWith(new Response("Hello world" + String(count)));
|
|
732
|
-
});
|
|
733
|
-
`;
|
|
734
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
735
|
-
|
|
736
|
-
const worker = await unstable_dev("index.js", {
|
|
737
|
-
experimental: {
|
|
738
|
-
disableExperimentalWarning: true,
|
|
739
|
-
disableDevRegistry: true,
|
|
740
|
-
},
|
|
741
|
-
});
|
|
742
|
-
|
|
743
|
-
const resp = await worker.fetch();
|
|
744
|
-
let text;
|
|
745
|
-
if (resp) text = await resp.text();
|
|
746
|
-
expect(text).toMatchInlineSnapshot(`"Hello world0"`);
|
|
747
|
-
await worker.stop();
|
|
748
|
-
});
|
|
749
|
-
});
|
|
750
|
-
});
|
|
751
|
-
|
|
752
|
-
describe("multiple middleware", () => {
|
|
753
|
-
runInTempDir();
|
|
754
|
-
it("should respond correctly with D1 databases, scheduled testing, and formatted dev errors", async () => {
|
|
755
|
-
// Kitchen sink test to check interaction between multiple middlewares
|
|
756
|
-
const scriptContent = `
|
|
757
|
-
export default {
|
|
758
|
-
async fetch(request, env, ctx) {
|
|
759
|
-
const { pathname } = new URL(request.url);
|
|
760
|
-
if (pathname === "/setup") {
|
|
761
|
-
await env.DB.exec("CREATE TABLE IF NOT EXISTS test (id INTEGER PRIMARY KEY, value TEXT);");
|
|
762
|
-
return new Response(null, { status: 204 });
|
|
763
|
-
} else if (pathname === "/query") {
|
|
764
|
-
const rows = await env.DB.prepare("SELECT * FROM test;").all();
|
|
765
|
-
return Response.json(rows.results);
|
|
766
|
-
}
|
|
767
|
-
throw new Error("Not found!");
|
|
768
|
-
},
|
|
769
|
-
async scheduled(controller, env, ctx) {
|
|
770
|
-
const stmt = await env.DB.prepare("INSERT INTO test (id, value) VALUES (?, ?)");
|
|
771
|
-
await stmt.bind(1, "one").run();
|
|
772
|
-
}
|
|
773
|
-
}
|
|
774
|
-
`;
|
|
775
|
-
fs.writeFileSync("index.js", scriptContent);
|
|
776
|
-
|
|
777
|
-
const originalFormatErrors = process.env.FORMAT_WRANGLER_ERRORS;
|
|
778
|
-
process.env.FORMAT_WRANGLER_ERRORS = "true";
|
|
779
|
-
|
|
780
|
-
const worker = await unstable_dev("index.js", {
|
|
781
|
-
experimental: {
|
|
782
|
-
disableExperimentalWarning: true,
|
|
783
|
-
disableDevRegistry: true,
|
|
784
|
-
testScheduled: true,
|
|
785
|
-
d1Databases: [
|
|
786
|
-
{
|
|
787
|
-
binding: "DB",
|
|
788
|
-
database_name: "db",
|
|
789
|
-
database_id: "00000000-0000-0000-0000-000000000000",
|
|
790
|
-
},
|
|
791
|
-
],
|
|
792
|
-
},
|
|
793
|
-
});
|
|
794
|
-
|
|
795
|
-
try {
|
|
796
|
-
let res = await worker.fetch("http://localhost/setup");
|
|
797
|
-
expect(res.status).toBe(204);
|
|
798
|
-
|
|
799
|
-
res = await worker.fetch("http://localhost/__scheduled");
|
|
800
|
-
expect(res.status).toBe(200);
|
|
801
|
-
expect(await res.text()).toBe("Ran scheduled event");
|
|
802
|
-
|
|
803
|
-
res = await worker.fetch("http://localhost/query");
|
|
804
|
-
expect(res.status).toBe(200);
|
|
805
|
-
expect(await res.json()).toEqual([{ id: 1, value: "one" }]);
|
|
806
|
-
|
|
807
|
-
res = await worker.fetch("http://localhost/bad");
|
|
808
|
-
expect(res.status).toBe(500);
|
|
809
|
-
expect(res.headers.get("Content-Type")).toBe("text/html");
|
|
810
|
-
expect(await res.text()).toContain("Error: Not found!");
|
|
811
|
-
} finally {
|
|
812
|
-
process.env.FORMAT_WRANGLER_ERRORS = originalFormatErrors;
|
|
813
|
-
await worker.stop();
|
|
814
|
-
}
|
|
815
|
-
});
|
|
816
|
-
});
|