wrangler 2.1.4 → 2.1.6

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