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.
Files changed (297) hide show
  1. package/README.md +4 -4
  2. package/bin/wrangler.js +9 -75
  3. package/package.json +5 -13
  4. package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
  5. package/templates/checked-fetch.js +1 -1
  6. package/templates/first-party-worker-module-facade.ts +2 -2
  7. package/templates/middleware/common.ts +9 -4
  8. package/templates/middleware/loader-sw.ts +2 -7
  9. package/templates/new-worker-scheduled.ts +1 -1
  10. package/templates/new-worker.ts +1 -1
  11. package/templates/pages-dev-util.ts +4 -1
  12. package/templates/pages-shim.ts +0 -3
  13. package/templates/tsconfig.tsbuildinfo +1 -1
  14. package/wrangler-dist/cli.d.ts +149 -75
  15. package/wrangler-dist/cli.js +60062 -64338
  16. package/import_meta_url.js +0 -3
  17. package/miniflare-config-stubs/.env.empty +0 -0
  18. package/miniflare-config-stubs/package.empty.json +0 -1
  19. package/miniflare-config-stubs/wrangler.empty.toml +0 -0
  20. package/miniflare-dist/index.mjs +0 -6442
  21. package/src/__tests__/access.test.ts +0 -25
  22. package/src/__tests__/api-dev.test.ts +0 -238
  23. package/src/__tests__/api-devregistry.test.ts +0 -121
  24. package/src/__tests__/api.test.ts +0 -102
  25. package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
  26. package/src/__tests__/config-cache.test.ts +0 -42
  27. package/src/__tests__/configuration.test.ts +0 -4517
  28. package/src/__tests__/constellation.test.ts +0 -371
  29. package/src/__tests__/d1/d1.test.ts +0 -82
  30. package/src/__tests__/d1/execute.test.ts +0 -66
  31. package/src/__tests__/d1/migrate.test.ts +0 -257
  32. package/src/__tests__/d1/splitter.test.ts +0 -255
  33. package/src/__tests__/delete.test.ts +0 -272
  34. package/src/__tests__/deployments.test.ts +0 -369
  35. package/src/__tests__/dev.test.tsx +0 -1617
  36. package/src/__tests__/generate.test.ts +0 -237
  37. package/src/__tests__/get-host-from-url.test.ts +0 -16
  38. package/src/__tests__/guess-worker-format.test.ts +0 -120
  39. package/src/__tests__/helpers/clipboardy-mock.js +0 -4
  40. package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
  41. package/src/__tests__/helpers/end-event-loop.ts +0 -6
  42. package/src/__tests__/helpers/mock-account-id.ts +0 -48
  43. package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
  44. package/src/__tests__/helpers/mock-bin.ts +0 -36
  45. package/src/__tests__/helpers/mock-console.ts +0 -112
  46. package/src/__tests__/helpers/mock-dialogs.ts +0 -139
  47. package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
  48. package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
  49. package/src/__tests__/helpers/mock-http-server.ts +0 -46
  50. package/src/__tests__/helpers/mock-istty.ts +0 -74
  51. package/src/__tests__/helpers/mock-known-routes.ts +0 -12
  52. package/src/__tests__/helpers/mock-kv.ts +0 -46
  53. package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
  54. package/src/__tests__/helpers/mock-process.ts +0 -34
  55. package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
  56. package/src/__tests__/helpers/mock-stdin.ts +0 -108
  57. package/src/__tests__/helpers/mock-web-socket.ts +0 -29
  58. package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
  59. package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
  60. package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
  61. package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
  62. package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
  63. package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
  64. package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
  65. package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
  66. package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
  67. package/src/__tests__/helpers/msw/index.ts +0 -52
  68. package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
  69. package/src/__tests__/helpers/run-in-tmp.ts +0 -38
  70. package/src/__tests__/helpers/run-wrangler.ts +0 -16
  71. package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
  72. package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
  73. package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
  74. package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
  75. package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
  76. package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
  77. package/src/__tests__/helpers/write-worker-source.ts +0 -31
  78. package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
  79. package/src/__tests__/https-options.test.ts +0 -163
  80. package/src/__tests__/index.test.ts +0 -282
  81. package/src/__tests__/init.test.ts +0 -3196
  82. package/src/__tests__/jest.setup.ts +0 -179
  83. package/src/__tests__/kv.test.ts +0 -1799
  84. package/src/__tests__/logger.test.ts +0 -207
  85. package/src/__tests__/logout.test.ts +0 -47
  86. package/src/__tests__/metrics.test.ts +0 -493
  87. package/src/__tests__/middleware.scheduled.test.ts +0 -145
  88. package/src/__tests__/middleware.test.ts +0 -816
  89. package/src/__tests__/mtls-certificates.test.ts +0 -589
  90. package/src/__tests__/package-manager.test.ts +0 -353
  91. package/src/__tests__/pages/deployment-list.test.ts +0 -80
  92. package/src/__tests__/pages/functions-build.test.ts +0 -528
  93. package/src/__tests__/pages/pages.test.ts +0 -81
  94. package/src/__tests__/pages/project-create.test.ts +0 -63
  95. package/src/__tests__/pages/project-list.test.ts +0 -110
  96. package/src/__tests__/pages/project-upload.test.ts +0 -500
  97. package/src/__tests__/pages/publish.test.ts +0 -2864
  98. package/src/__tests__/pages-deployment-tail.test.ts +0 -957
  99. package/src/__tests__/parse.test.ts +0 -436
  100. package/src/__tests__/paths.test.ts +0 -39
  101. package/src/__tests__/publish.test.ts +0 -8849
  102. package/src/__tests__/pubsub.test.ts +0 -496
  103. package/src/__tests__/queues.test.ts +0 -532
  104. package/src/__tests__/r2.test.ts +0 -374
  105. package/src/__tests__/route.test.ts +0 -45
  106. package/src/__tests__/secret.test.ts +0 -693
  107. package/src/__tests__/tail.test.ts +0 -989
  108. package/src/__tests__/test-old-node-version.js +0 -31
  109. package/src/__tests__/traverse-module-graph.test.ts +0 -220
  110. package/src/__tests__/tsconfig-sanity.ts +0 -12
  111. package/src/__tests__/tsconfig.json +0 -8
  112. package/src/__tests__/tsconfig.tsbuildinfo +0 -1
  113. package/src/__tests__/type-generation.test.ts +0 -234
  114. package/src/__tests__/user.test.ts +0 -118
  115. package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
  116. package/src/__tests__/validate-dev-props.test.ts +0 -56
  117. package/src/__tests__/version.test.ts +0 -35
  118. package/src/__tests__/whoami.test.tsx +0 -172
  119. package/src/__tests__/worker-namespace.test.ts +0 -340
  120. package/src/abort.d.ts +0 -3
  121. package/src/api/dev.ts +0 -321
  122. package/src/api/index.ts +0 -11
  123. package/src/api/mtls-certificate.ts +0 -148
  124. package/src/api/pages/create-worker-bundle-contents.ts +0 -77
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -371
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -929
  129. package/src/cfetch/index.ts +0 -158
  130. package/src/cfetch/internal.ts +0 -258
  131. package/src/cli.ts +0 -28
  132. package/src/config/README.md +0 -107
  133. package/src/config/config.ts +0 -282
  134. package/src/config/diagnostics.ts +0 -80
  135. package/src/config/environment.ts +0 -625
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2369
  139. package/src/config-cache.ts +0 -85
  140. package/src/constellation/createProject.tsx +0 -51
  141. package/src/constellation/deleteProject.ts +0 -51
  142. package/src/constellation/deleteProjectModel.ts +0 -68
  143. package/src/constellation/index.ts +0 -75
  144. package/src/constellation/listCatalog.tsx +0 -35
  145. package/src/constellation/listModel.tsx +0 -41
  146. package/src/constellation/listProject.tsx +0 -28
  147. package/src/constellation/listRuntime.tsx +0 -28
  148. package/src/constellation/options.ts +0 -17
  149. package/src/constellation/types.ts +0 -17
  150. package/src/constellation/uploadModel.tsx +0 -64
  151. package/src/constellation/utils.ts +0 -90
  152. package/src/create-worker-preview.ts +0 -293
  153. package/src/create-worker-upload-form.ts +0 -363
  154. package/src/d1/backups.tsx +0 -219
  155. package/src/d1/constants.ts +0 -2
  156. package/src/d1/create.tsx +0 -70
  157. package/src/d1/delete.ts +0 -53
  158. package/src/d1/execute.tsx +0 -357
  159. package/src/d1/formatTimeAgo.ts +0 -14
  160. package/src/d1/index.ts +0 -100
  161. package/src/d1/list.tsx +0 -62
  162. package/src/d1/migrations/apply.tsx +0 -212
  163. package/src/d1/migrations/create.tsx +0 -79
  164. package/src/d1/migrations/helpers.ts +0 -169
  165. package/src/d1/migrations/index.ts +0 -3
  166. package/src/d1/migrations/list.tsx +0 -95
  167. package/src/d1/migrations/options.ts +0 -23
  168. package/src/d1/options.ts +0 -22
  169. package/src/d1/splitter.ts +0 -161
  170. package/src/d1/types.ts +0 -25
  171. package/src/d1/utils.ts +0 -49
  172. package/src/delete.ts +0 -100
  173. package/src/deployments.ts +0 -368
  174. package/src/deprecated/index.ts +0 -144
  175. package/src/dev/dev-vars.ts +0 -39
  176. package/src/dev/dev.tsx +0 -605
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -952
  179. package/src/dev/remote.tsx +0 -635
  180. package/src/dev/start-server.ts +0 -545
  181. package/src/dev/use-esbuild.ts +0 -215
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -934
  185. package/src/dialogs.ts +0 -136
  186. package/src/dispatch-namespace.ts +0 -211
  187. package/src/docs/helpers.ts +0 -50
  188. package/src/docs/index.ts +0 -54
  189. package/src/durable.ts +0 -102
  190. package/src/entry.ts +0 -344
  191. package/src/environment-variables/factory.ts +0 -89
  192. package/src/environment-variables/misc-variables.ts +0 -30
  193. package/src/errors.ts +0 -11
  194. package/src/generate/index.ts +0 -298
  195. package/src/git-client.ts +0 -135
  196. package/src/global-wrangler-config-path.ts +0 -26
  197. package/src/https-options.ts +0 -127
  198. package/src/index.ts +0 -768
  199. package/src/init.ts +0 -1037
  200. package/src/inspect.ts +0 -883
  201. package/src/intl-polyfill.d.ts +0 -139
  202. package/src/is-ci.ts +0 -14
  203. package/src/is-interactive.ts +0 -16
  204. package/src/jest.d.ts +0 -4
  205. package/src/kv/helpers.ts +0 -433
  206. package/src/kv/index.ts +0 -594
  207. package/src/logger.ts +0 -123
  208. package/src/metrics/index.ts +0 -5
  209. package/src/metrics/metrics-config.ts +0 -239
  210. package/src/metrics/metrics-dispatcher.ts +0 -96
  211. package/src/metrics/metrics-usage-headers.ts +0 -24
  212. package/src/metrics/send-event.ts +0 -99
  213. package/src/miniflare-cli/README.md +0 -30
  214. package/src/miniflare-cli/assets.ts +0 -251
  215. package/src/miniflare-cli/index.ts +0 -210
  216. package/src/miniflare-cli/request-context.ts +0 -40
  217. package/src/miniflare-cli/tsconfig.json +0 -9
  218. package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
  219. package/src/miniflare-cli/types.ts +0 -11
  220. package/src/module-collection.ts +0 -333
  221. package/src/mtls-certificate/cli.ts +0 -155
  222. package/src/open-in-browser.ts +0 -17
  223. package/src/package-manager.ts +0 -219
  224. package/src/pages/build.ts +0 -423
  225. package/src/pages/buildFunctions.ts +0 -140
  226. package/src/pages/constants.ts +0 -18
  227. package/src/pages/deployment-tails.ts +0 -281
  228. package/src/pages/deployments.tsx +0 -84
  229. package/src/pages/dev.ts +0 -734
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -114
  232. package/src/pages/functions/buildWorker.ts +0 -350
  233. package/src/pages/functions/filepath-routing.test.ts +0 -234
  234. package/src/pages/functions/filepath-routing.ts +0 -189
  235. package/src/pages/functions/identifiers.ts +0 -78
  236. package/src/pages/functions/routes-consolidation.test.ts +0 -250
  237. package/src/pages/functions/routes-consolidation.ts +0 -73
  238. package/src/pages/functions/routes-transformation.test.ts +0 -282
  239. package/src/pages/functions/routes-transformation.ts +0 -115
  240. package/src/pages/functions/routes-validation.test.ts +0 -403
  241. package/src/pages/functions/routes-validation.ts +0 -202
  242. package/src/pages/functions/routes.ts +0 -151
  243. package/src/pages/functions/tsconfig.json +0 -8
  244. package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
  245. package/src/pages/functions.ts +0 -86
  246. package/src/pages/hash.ts +0 -13
  247. package/src/pages/index.ts +0 -102
  248. package/src/pages/projects.tsx +0 -159
  249. package/src/pages/prompt-select-project.tsx +0 -31
  250. package/src/pages/publish.tsx +0 -267
  251. package/src/pages/types.ts +0 -46
  252. package/src/pages/upload.tsx +0 -469
  253. package/src/pages/utils.ts +0 -23
  254. package/src/parse.ts +0 -308
  255. package/src/paths.ts +0 -71
  256. package/src/proxy.ts +0 -694
  257. package/src/publish/index.ts +0 -274
  258. package/src/publish/publish.ts +0 -1065
  259. package/src/pubsub/index.ts +0 -286
  260. package/src/pubsub/pubsub-commands.ts +0 -623
  261. package/src/queues/cli/commands/consumer/add.ts +0 -71
  262. package/src/queues/cli/commands/consumer/index.ts +0 -19
  263. package/src/queues/cli/commands/consumer/remove.ts +0 -31
  264. package/src/queues/cli/commands/create.ts +0 -25
  265. package/src/queues/cli/commands/delete.ts +0 -26
  266. package/src/queues/cli/commands/index.ts +0 -35
  267. package/src/queues/cli/commands/list.ts +0 -25
  268. package/src/queues/client.ts +0 -136
  269. package/src/queues/utils.ts +0 -18
  270. package/src/r2/constants.ts +0 -4
  271. package/src/r2/helpers.ts +0 -132
  272. package/src/r2/index.ts +0 -289
  273. package/src/routes.ts +0 -140
  274. package/src/secret/index.ts +0 -377
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -415
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -132
  281. package/src/traverse-module-graph.ts +0 -54
  282. package/src/tsconfig-sanity.ts +0 -16
  283. package/src/type-generation.ts +0 -181
  284. package/src/update-check.ts +0 -19
  285. package/src/user/access.ts +0 -68
  286. package/src/user/auth-variables.ts +0 -113
  287. package/src/user/choose-account.tsx +0 -39
  288. package/src/user/generate-auth-url.ts +0 -33
  289. package/src/user/generate-random-state.ts +0 -16
  290. package/src/user/index.ts +0 -2
  291. package/src/user/user.ts +0 -1234
  292. package/src/utils/collectKeyValues.ts +0 -14
  293. package/src/utils/render.ts +0 -93
  294. package/src/whoami.ts +0 -135
  295. package/src/worker.ts +0 -279
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
@@ -1,989 +0,0 @@
1
- import MockWebSocket from "jest-websocket-mock";
2
- import { rest } from "msw";
3
- import { Headers, Request } from "undici";
4
- import { mockAccountId, mockApiToken } from "./helpers/mock-account-id";
5
- import { mockConsoleMethods } from "./helpers/mock-console";
6
- import { mockConfirm, clearDialogs } from "./helpers/mock-dialogs";
7
- import { useMockIsTTY } from "./helpers/mock-istty";
8
- import { createFetchResult, msw, mswSucessScriptHandlers } from "./helpers/msw";
9
- import { runInTempDir } from "./helpers/run-in-tmp";
10
- import { runWrangler } from "./helpers/run-wrangler";
11
- import type {
12
- TailEventMessage,
13
- RequestEvent,
14
- ScheduledEvent,
15
- AlarmEvent,
16
- EmailEvent,
17
- TailInfo,
18
- } from "../tail/createTail";
19
- import type { RequestInit } from "undici";
20
- import type WebSocket from "ws";
21
-
22
- describe("tail", () => {
23
- beforeEach(() => msw.use(...mswSucessScriptHandlers));
24
- runInTempDir();
25
- mockAccountId();
26
- mockApiToken();
27
-
28
- const std = mockConsoleMethods();
29
-
30
- afterEach(() => {
31
- mockWebSockets.forEach((ws) => ws.close());
32
- mockWebSockets.splice(0);
33
- clearDialogs();
34
- });
35
-
36
- /**
37
- * Interaction with the tailing API, including tail creation,
38
- * deletion, and connection.
39
- */
40
- describe("API interaction", () => {
41
- const { setIsTTY } = useMockIsTTY();
42
- it("should throw an error if name isn't provided", async () => {
43
- await expect(
44
- runWrangler("tail")
45
- ).rejects.toThrowErrorMatchingInlineSnapshot(
46
- `"Required Worker name missing. Please specify the Worker name in wrangler.toml, or pass it as an argument with \`wrangler tail <worker-name>\`"`
47
- );
48
- });
49
- it("warns about durable object restarts for tty", async () => {
50
- setIsTTY(true);
51
- mockConfirm({
52
- text: "Would you like to continue?",
53
- result: false,
54
- });
55
- const api = mockWebsocketAPIs();
56
- expect(api.requests.creation.length).toStrictEqual(0);
57
- await runWrangler("tail durable-object--websocket--response");
58
- expect(std.out).toMatchInlineSnapshot(`""`);
59
- expect(std.warn).toMatchInlineSnapshot(`
60
- "▲ [WARNING] Beginning log collection requires restarting the Durable Objects associated with durable-object--websocket--response. Any WebSocket connections or other non-persisted state will be lost as part of this restart.
61
-
62
- "
63
- `);
64
- expect(std.err).toMatchInlineSnapshot(`""`);
65
- });
66
- it("creates and then delete tails", async () => {
67
- const api = mockWebsocketAPIs();
68
- expect(api.requests.creation.length).toStrictEqual(0);
69
-
70
- await runWrangler("tail test-worker");
71
-
72
- await expect(api.ws.connected).resolves.toBeTruthy();
73
- expect(api.requests.creation.length).toStrictEqual(1);
74
- expect(api.requests.deletion.count).toStrictEqual(0);
75
-
76
- await api.closeHelper();
77
- expect(api.requests.deletion.count).toStrictEqual(1);
78
- });
79
- it("should connect to the worker assigned to a given route", async () => {
80
- const api = mockWebsocketAPIs();
81
- expect(api.requests.creation.length).toStrictEqual(0);
82
-
83
- msw.use(
84
- rest.get(`*/zones`, (req, res, ctx) => {
85
- expect(req.url.searchParams.get("name")).toBe("example.com");
86
- return res.once(
87
- ctx.status(200),
88
- ctx.json({
89
- success: true,
90
- errors: [],
91
- messages: [],
92
- result: [{ id: "test-zone" }],
93
- })
94
- );
95
- })
96
- );
97
- msw.use(
98
- rest.get(`*/zones/:zoneId/workers/routes`, (req, res, ctx) => {
99
- return res.once(
100
- ctx.status(200),
101
- ctx.json({
102
- success: true,
103
- errors: [],
104
- messages: [],
105
- result: [
106
- {
107
- pattern: "example.com/*",
108
- script: "test-worker",
109
- },
110
- ],
111
- })
112
- );
113
- })
114
- );
115
- await runWrangler("tail example.com/*");
116
-
117
- await expect(api.ws.connected).resolves.toBeTruthy();
118
- expect(api.requests.creation.length).toStrictEqual(1);
119
- expect(api.requests.deletion.count).toStrictEqual(0);
120
-
121
- await api.closeHelper();
122
- expect(api.requests.deletion.count).toStrictEqual(1);
123
- });
124
-
125
- it("should error if a given route is not assigned to the user's zone", async () => {
126
- msw.use(
127
- rest.get(`*/zones`, (req, res, ctx) => {
128
- expect(req.url.searchParams.get("name")).toBe("example.com");
129
- return res.once(
130
- ctx.status(200),
131
- ctx.json({
132
- success: true,
133
- errors: [],
134
- messages: [],
135
- result: [{ id: "test-zone" }],
136
- })
137
- );
138
- })
139
- );
140
- msw.use(
141
- rest.get(`*/zones/:zoneId/workers/routes`, (req, res, ctx) => {
142
- return res.once(
143
- ctx.status(200),
144
- ctx.json({
145
- success: true,
146
- errors: [],
147
- messages: [],
148
- result: [],
149
- })
150
- );
151
- })
152
- );
153
-
154
- await expect(runWrangler("tail example.com/*")).rejects.toThrow();
155
- });
156
- it("should error if a given route is not within the user's zone", async () => {
157
- msw.use(
158
- rest.get(`*/zones`, (req, res, ctx) => {
159
- expect(req.url.searchParams.get("name")).toBe("example.com");
160
- return res.once(
161
- ctx.status(200),
162
- ctx.json({
163
- success: true,
164
- errors: [],
165
- messages: [],
166
- result: [],
167
- })
168
- );
169
- })
170
- );
171
-
172
- await expect(runWrangler("tail example.com/*")).rejects.toThrow();
173
- });
174
-
175
- it("creates and then delete tails: legacy envs", async () => {
176
- const api = mockWebsocketAPIs("some-env", true);
177
- expect(api.requests.creation.length).toStrictEqual(0);
178
-
179
- await runWrangler("tail test-worker --env some-env --legacy-env true");
180
-
181
- await expect(api.ws.connected).resolves.toBeTruthy();
182
- expect(api.requests.creation.length).toStrictEqual(1);
183
- expect(api.requests.deletion.count).toStrictEqual(0);
184
-
185
- await api.closeHelper();
186
- expect(api.requests.deletion.count).toStrictEqual(1);
187
- });
188
-
189
- it("creates and then delete tails: service envs", async () => {
190
- const api = mockWebsocketAPIs("some-env");
191
- expect(api.requests.creation.length).toStrictEqual(0);
192
-
193
- await runWrangler("tail test-worker --env some-env --legacy-env false");
194
-
195
- await expect(api.ws.connected).resolves.toBeTruthy();
196
- expect(api.requests.creation.length).toStrictEqual(1);
197
- expect(api.requests.deletion.count).toStrictEqual(0);
198
-
199
- await api.closeHelper();
200
- expect(api.requests.deletion.count).toStrictEqual(1);
201
- });
202
-
203
- it("errors when the websocket closes unexpectedly", async () => {
204
- const api = mockWebsocketAPIs();
205
- await api.closeHelper();
206
-
207
- await expect(runWrangler("tail test-worker")).rejects.toThrow();
208
- });
209
-
210
- it("activates debug mode when the cli arg is passed in", async () => {
211
- const api = mockWebsocketAPIs();
212
- await runWrangler("tail test-worker --debug");
213
- await expect(api.nextMessageJson()).resolves.toHaveProperty(
214
- "debug",
215
- true
216
- );
217
- });
218
- });
219
-
220
- describe("filtering", () => {
221
- it("sends sampling rate filters", async () => {
222
- const api = mockWebsocketAPIs();
223
- const tooHigh = runWrangler("tail test-worker --sampling-rate 10");
224
- await expect(tooHigh).rejects.toThrow();
225
-
226
- const tooLow = runWrangler("tail test-worker --sampling-rate -5");
227
- await expect(tooLow).rejects.toThrow();
228
-
229
- await runWrangler("tail test-worker --sampling-rate 0.25");
230
-
231
- expect(api.requests.creation[0]).toEqual({
232
- filters: [{ sampling_rate: 0.25 }],
233
- });
234
- });
235
-
236
- it("sends single status filters", async () => {
237
- const api = mockWebsocketAPIs();
238
- await runWrangler("tail test-worker --status error");
239
- expect(api.requests.creation[0]).toEqual({
240
- filters: [
241
- {
242
- outcome: ["exception", "exceededCpu", "exceededMemory", "unknown"],
243
- },
244
- ],
245
- });
246
- });
247
-
248
- it("sends multiple status filters", async () => {
249
- const api = mockWebsocketAPIs();
250
- await runWrangler("tail test-worker --status error --status canceled");
251
- expect(api.requests.creation[0]).toEqual({
252
- filters: [
253
- {
254
- outcome: [
255
- "exception",
256
- "exceededCpu",
257
- "exceededMemory",
258
- "unknown",
259
- "canceled",
260
- ],
261
- },
262
- ],
263
- });
264
- });
265
-
266
- it("sends single HTTP method filters", async () => {
267
- const api = mockWebsocketAPIs();
268
- await runWrangler("tail test-worker --method POST");
269
- expect(api.requests.creation[0]).toEqual({
270
- filters: [{ method: ["POST"] }],
271
- });
272
- });
273
-
274
- it("sends multiple HTTP method filters", async () => {
275
- const api = mockWebsocketAPIs();
276
- await runWrangler("tail test-worker --method POST --method GET");
277
- expect(api.requests.creation[0]).toEqual({
278
- filters: [{ method: ["POST", "GET"] }],
279
- });
280
- });
281
-
282
- it("sends header filters without a query", async () => {
283
- const api = mockWebsocketAPIs();
284
- await runWrangler("tail test-worker --header X-CUSTOM-HEADER");
285
- expect(api.requests.creation[0]).toEqual({
286
- filters: [{ header: { key: "X-CUSTOM-HEADER" } }],
287
- });
288
- });
289
-
290
- it("sends header filters with a query", async () => {
291
- const api = mockWebsocketAPIs();
292
- await runWrangler("tail test-worker --header X-CUSTOM-HEADER:some-value");
293
- expect(api.requests.creation[0]).toEqual({
294
- filters: [{ header: { key: "X-CUSTOM-HEADER", query: "some-value" } }],
295
- });
296
- });
297
-
298
- it("sends single IP filters", async () => {
299
- const api = mockWebsocketAPIs();
300
- const fakeIp = "192.0.2.1";
301
-
302
- await runWrangler(`tail test-worker --ip ${fakeIp}`);
303
- expect(api.requests.creation[0]).toEqual({
304
- filters: [{ client_ip: [fakeIp] }],
305
- });
306
- });
307
-
308
- it("sends multiple IP filters", async () => {
309
- const api = mockWebsocketAPIs();
310
- const fakeIp = "192.0.2.1";
311
-
312
- await runWrangler(`tail test-worker --ip ${fakeIp} --ip self`);
313
- expect(api.requests.creation[0]).toEqual({
314
- filters: [{ client_ip: [fakeIp, "self"] }],
315
- });
316
- });
317
-
318
- it("sends search filters", async () => {
319
- const api = mockWebsocketAPIs();
320
- const search = "filterMe";
321
-
322
- await runWrangler(`tail test-worker --search ${search}`);
323
- expect(api.requests.creation[0]).toEqual({
324
- filters: [{ query: search }],
325
- });
326
- });
327
-
328
- it("sends everything but the kitchen sink", async () => {
329
- const api = mockWebsocketAPIs();
330
- const sampling_rate = 0.69;
331
- const status = ["ok", "error"];
332
- const method = ["GET", "POST", "PUT"];
333
- const header = "X-HELLO:world";
334
- const client_ip = ["192.0.2.1", "self"];
335
- const query = "onlyTheseMessagesPlease";
336
-
337
- const cliFilters =
338
- `--sampling-rate ${sampling_rate} ` +
339
- status.map((s) => `--status ${s} `).join("") +
340
- method.map((m) => `--method ${m} `).join("") +
341
- `--header ${header} ` +
342
- client_ip.map((c) => `--ip ${c} `).join("") +
343
- `--search ${query} ` +
344
- `--debug`;
345
-
346
- const expectedWebsocketMessage = {
347
- filters: [
348
- { sampling_rate: 0.69 },
349
- {
350
- outcome: [
351
- "ok",
352
- "exception",
353
- "exceededCpu",
354
- "exceededMemory",
355
- "unknown",
356
- ],
357
- },
358
- { method: ["GET", "POST", "PUT"] },
359
- { header: { key: "X-HELLO", query: "world" } },
360
- { client_ip: ["192.0.2.1", "self"] },
361
- { query: "onlyTheseMessagesPlease" },
362
- ],
363
- };
364
-
365
- await runWrangler(`tail test-worker ${cliFilters}`);
366
- expect(api.requests.creation[0]).toEqual(expectedWebsocketMessage);
367
- });
368
- });
369
-
370
- describe("printing", () => {
371
- const { setIsTTY } = useMockIsTTY();
372
-
373
- it("logs request messages in JSON format", async () => {
374
- const api = mockWebsocketAPIs();
375
- await runWrangler("tail test-worker --format json");
376
-
377
- const event = generateMockRequestEvent();
378
- const message = generateMockEventMessage({ event });
379
- const serializedMessage = serialize(message);
380
-
381
- api.ws.send(serializedMessage);
382
- expect(std.out).toMatch(deserializeToJson(serializedMessage));
383
- });
384
-
385
- it("logs scheduled messages in JSON format", async () => {
386
- const api = mockWebsocketAPIs();
387
- await runWrangler("tail test-worker --format json");
388
-
389
- const event = generateMockScheduledEvent();
390
- const message = generateMockEventMessage({ event });
391
- const serializedMessage = serialize(message);
392
-
393
- api.ws.send(serializedMessage);
394
- expect(std.out).toMatch(deserializeToJson(serializedMessage));
395
- });
396
-
397
- it("logs alarm messages in json format", async () => {
398
- const api = mockWebsocketAPIs();
399
- await runWrangler("tail test-worker --format json");
400
-
401
- const event = generateMockAlarmEvent();
402
- const message = generateMockEventMessage({ event });
403
- const serializedMessage = serialize(message);
404
-
405
- api.ws.send(serializedMessage);
406
- expect(std.out).toMatch(deserializeToJson(serializedMessage));
407
- });
408
-
409
- it("logs email messages in json format", async () => {
410
- const api = mockWebsocketAPIs();
411
- await runWrangler("tail test-worker --format json");
412
-
413
- const event = generateMockEmailEvent();
414
- const message = generateMockEventMessage({ event });
415
- const serializedMessage = serialize(message);
416
-
417
- api.ws.send(serializedMessage);
418
- expect(std.out).toMatch(deserializeToJson(serializedMessage));
419
- });
420
-
421
- it("logs request messages in pretty format", async () => {
422
- const api = mockWebsocketAPIs();
423
- await runWrangler("tail test-worker --format pretty");
424
-
425
- const event = generateMockRequestEvent();
426
- const message = generateMockEventMessage({ event });
427
- const serializedMessage = serialize(message);
428
-
429
- api.ws.send(serializedMessage);
430
- expect(
431
- std.out
432
- .replace(
433
- new Date(mockEventTimestamp).toLocaleString(),
434
- "[mock event timestamp]"
435
- )
436
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
437
- ).toMatchInlineSnapshot(`
438
- "Successfully created tail, expires at [mock expiration date]
439
- Connected to test-worker, waiting for logs...
440
- GET https://example.org/ - Ok @ [mock event timestamp]"
441
- `);
442
- });
443
-
444
- it("logs scheduled messages in pretty format", async () => {
445
- const api = mockWebsocketAPIs();
446
- await runWrangler("tail test-worker --format pretty");
447
-
448
- const event = generateMockScheduledEvent();
449
- const message = generateMockEventMessage({ event });
450
- const serializedMessage = serialize(message);
451
-
452
- api.ws.send(serializedMessage);
453
- expect(
454
- std.out
455
- .replace(
456
- new Date(mockEventTimestamp).toLocaleString(),
457
- "[mock timestamp string]"
458
- )
459
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
460
- ).toMatchInlineSnapshot(`
461
- "Successfully created tail, expires at [mock expiration date]
462
- Connected to test-worker, waiting for logs...
463
- \\"* * * * *\\" @ [mock timestamp string] - Ok"
464
- `);
465
- });
466
-
467
- it("logs alarm messages in pretty format", async () => {
468
- const api = mockWebsocketAPIs();
469
- await runWrangler("tail test-worker --format pretty");
470
-
471
- const event = generateMockAlarmEvent();
472
- const message = generateMockEventMessage({ event });
473
- const serializedMessage = serialize(message);
474
-
475
- api.ws.send(serializedMessage);
476
- expect(
477
- std.out
478
- .replace(
479
- new Date(mockEventScheduledTime).toLocaleString(),
480
- "[mock scheduled time]"
481
- )
482
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
483
- ).toMatchInlineSnapshot(`
484
- "Successfully created tail, expires at [mock expiration date]
485
- Connected to test-worker, waiting for logs...
486
- Alarm @ [mock scheduled time] - Ok"
487
- `);
488
- });
489
-
490
- it("logs email messages in pretty format", async () => {
491
- const api = mockWebsocketAPIs();
492
- await runWrangler("tail test-worker --format pretty");
493
-
494
- const event = generateMockEmailEvent();
495
- const message = generateMockEventMessage({ event });
496
- const serializedMessage = serialize(message);
497
-
498
- api.ws.send(serializedMessage);
499
- expect(
500
- std.out
501
- .replace(
502
- new Date(mockEventTimestamp).toLocaleString(),
503
- "[mock event timestamp]"
504
- )
505
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
506
- ).toMatchInlineSnapshot(`
507
- "Successfully created tail, expires at [mock expiration date]
508
- Connected to test-worker, waiting for logs...
509
- Email from:from@example.com to:to@example.com size:45416 @ [mock event timestamp] - Ok"
510
- `);
511
- });
512
-
513
- it("logs tail overload message", async () => {
514
- const api = mockWebsocketAPIs();
515
- await runWrangler("tail test-worker --format pretty");
516
-
517
- const event = generateTailInfo();
518
- const message = generateMockEventMessage({ event });
519
- const serializedMessage = serialize(message);
520
-
521
- api.ws.send(serializedMessage);
522
- expect(
523
- std.out.replace(
524
- mockTailExpiration.toISOString(),
525
- "[mock expiration date]"
526
- )
527
- ).toMatchInlineSnapshot(`
528
- "Successfully created tail, expires at [mock expiration date]
529
- Connected to test-worker, waiting for logs...
530
- Tail is currently in sampling mode due to the high volume of messages. To prevent messages from being dropped consider adding filters."
531
- `);
532
- });
533
-
534
- it("should not crash when the tail message has a void event", async () => {
535
- const api = mockWebsocketAPIs();
536
- await runWrangler("tail test-worker --format pretty");
537
-
538
- const message = generateMockEventMessage({ event: null });
539
- const serializedMessage = serialize(message);
540
-
541
- api.ws.send(serializedMessage);
542
- expect(
543
- std.out
544
- .replace(
545
- new Date(mockEventTimestamp).toLocaleString(),
546
- "[mock timestamp string]"
547
- )
548
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
549
- ).toMatchInlineSnapshot(`
550
- "Successfully created tail, expires at [mock expiration date]
551
- Connected to test-worker, waiting for logs...
552
- Unknown Event - Ok @ [mock timestamp string]"
553
- `);
554
- });
555
-
556
- it("defaults to logging in pretty format when the output is a TTY", async () => {
557
- setIsTTY(true);
558
- const api = mockWebsocketAPIs();
559
- await runWrangler("tail test-worker");
560
-
561
- const event = generateMockRequestEvent();
562
- const message = generateMockEventMessage({ event });
563
- const serializedMessage = serialize(message);
564
-
565
- api.ws.send(serializedMessage);
566
- expect(
567
- std.out
568
- .replace(
569
- new Date(mockEventTimestamp).toLocaleString(),
570
- "[mock event timestamp]"
571
- )
572
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
573
- ).toMatchInlineSnapshot(`
574
- "Successfully created tail, expires at [mock expiration date]
575
- Connected to test-worker, waiting for logs...
576
- GET https://example.org/ - Ok @ [mock event timestamp]"
577
- `);
578
- });
579
-
580
- it("defaults to logging in json format when the output is not a TTY", async () => {
581
- setIsTTY(false);
582
-
583
- const api = mockWebsocketAPIs();
584
- await runWrangler("tail test-worker");
585
-
586
- const event = generateMockRequestEvent();
587
- const message = generateMockEventMessage({ event });
588
- const serializedMessage = serialize(message);
589
-
590
- api.ws.send(serializedMessage);
591
- expect(std.out).toMatch(deserializeToJson(serializedMessage));
592
- });
593
-
594
- it("logs console messages and exceptions", async () => {
595
- setIsTTY(true);
596
- const api = mockWebsocketAPIs();
597
- await runWrangler("tail test-worker");
598
-
599
- const event = generateMockRequestEvent();
600
- const message = generateMockEventMessage({
601
- event,
602
- logs: [
603
- { message: ["some string"], level: "log", timestamp: 1234561 },
604
- {
605
- message: [{ complex: "object" }],
606
- level: "log",
607
- timestamp: 1234562,
608
- },
609
- { message: [1234], level: "error", timestamp: 1234563 },
610
- ],
611
- exceptions: [
612
- { name: "Error", message: "some error", timestamp: 1234564 },
613
- { name: "Error", message: { complex: "error" }, timestamp: 1234564 },
614
- ],
615
- });
616
- const serializedMessage = serialize(message);
617
-
618
- api.ws.send(serializedMessage);
619
- expect(
620
- std.out
621
- .replace(
622
- new Date(mockEventTimestamp).toLocaleString(),
623
- "[mock event timestamp]"
624
- )
625
- .replace(mockTailExpiration.toISOString(), "[mock expiration date]")
626
- ).toMatchInlineSnapshot(`
627
- "Successfully created tail, expires at [mock expiration date]
628
- Connected to test-worker, waiting for logs...
629
- GET https://example.org/ - Ok @ [mock event timestamp]
630
- (log) some string
631
- (log) { complex: 'object' }
632
- (error) 1234"
633
- `);
634
- expect(std.err).toMatchInlineSnapshot(`
635
- "X [ERROR]  Error: some error
636
-
637
-
638
- X [ERROR]  Error: { complex: 'error' }
639
-
640
- "
641
- `);
642
- expect(std.warn).toMatchInlineSnapshot(`""`);
643
- });
644
- });
645
- });
646
-
647
- /* helpers */
648
-
649
- /**
650
- * The built in serialize-to-JSON feature of our mock websocket doesn't work
651
- * for our use-case since we actually expect a raw buffer,
652
- * not a Javascript string. Additionally, we have to do some fiddling
653
- * with `RequestEvent`s to get them to serialize properly.
654
- *
655
- * @param message a message to serialize to JSON
656
- * @returns the same type we expect when deserializing in wrangler
657
- */
658
- function serialize(message: TailEventMessage): WebSocket.RawData {
659
- if (!isRequest(message.event)) {
660
- // `ScheduledEvent`s and `TailEvent`s work just fine
661
- const stringified = JSON.stringify(message);
662
- return Buffer.from(stringified, "utf-8");
663
- } else {
664
- // Since the "properties" of an `undici.Request` are actually getters,
665
- // which don't serialize properly, we need to hydrate them manually.
666
- // This isn't a problem outside of testing since deserialization
667
- // works just fine and wrangler never _sends_ any event messages,
668
- // it only receives them.
669
- const request = ((message.event as RequestEvent | undefined | null) || {})
670
- .request;
671
- const stringified = JSON.stringify(message, (key, value) => {
672
- if (key !== "request") {
673
- return value;
674
- }
675
-
676
- return {
677
- ...request,
678
- url: request?.url,
679
- headers: request?.headers,
680
- method: request?.method,
681
- };
682
- });
683
-
684
- return Buffer.from(stringified, "utf-8");
685
- }
686
- }
687
-
688
- /**
689
- * Small helper to disambiguate the event types possible in a `TailEventMessage`
690
- *
691
- * @param event A TailEvent
692
- * @returns true if `event` is a RequestEvent
693
- */
694
- function isRequest(
695
- event:
696
- | ScheduledEvent
697
- | RequestEvent
698
- | AlarmEvent
699
- | EmailEvent
700
- | TailInfo
701
- | undefined
702
- | null
703
- ): event is RequestEvent {
704
- return Boolean(event && "request" in event);
705
- }
706
-
707
- /**
708
- * Similarly, we need to deserialize from a raw buffer instead
709
- * of just JSON.parsing a raw string. This deserializer also then
710
- * re-stringifies with some spacing, the same way wrangler tail does.
711
- *
712
- * @param message a buffer of data received from the websocket
713
- * @returns a string ready to be printed to the terminal or compared against
714
- */
715
- function deserializeToJson(message: WebSocket.RawData): string {
716
- return JSON.stringify(JSON.parse(message.toString()), null, 2);
717
- }
718
-
719
- /**
720
- * A mock for all the different API resources wrangler accesses
721
- * when running `wrangler tail`
722
- */
723
- type MockAPI = {
724
- requests: {
725
- creation: RequestInit[];
726
- deletion: RequestCounter;
727
- };
728
- ws: MockWebSocket;
729
- nextMessageJson(): Promise<unknown>;
730
- closeHelper: () => Promise<void>;
731
- };
732
-
733
- /**
734
- * A counter used to check how many times a mock API has been hit.
735
- * Useful as a helper in our testing to check if wrangler is making
736
- * the correct API calls without actually sending any web traffic
737
- */
738
- type RequestCounter = {
739
- count: number;
740
- };
741
-
742
- /**
743
- * Mock out the API hit during Tail creation
744
- *
745
- * @param websocketURL a fake URL for wrangler to connect a websocket to
746
- * @returns a `RequestCounter` for counting how many times the API is hit
747
- */
748
- function mockCreateTailRequest(
749
- websocketURL: string,
750
- env?: string,
751
- legacyEnv = false,
752
- expectedScriptName = legacyEnv && env ? `test-worker-${env}` : "test-worker"
753
- ): RequestInit[] {
754
- const requests: RequestInit[] = [];
755
- const servicesOrScripts = env && !legacyEnv ? "services" : "scripts";
756
- const environment = env && !legacyEnv ? "/environments/:envName" : "";
757
- msw.use(
758
- rest.post(
759
- `*/accounts/:accountId/workers/${servicesOrScripts}/:scriptName${environment}/tails`,
760
- async (req, res, ctx) => {
761
- const request = await req.json();
762
- requests.push(request);
763
- expect(req.params.accountId).toEqual("some-account-id");
764
- expect(req.params.scriptName).toEqual(expectedScriptName);
765
- if (!legacyEnv) {
766
- expect(req.params.envName).toEqual(env);
767
- }
768
- return res.once(
769
- ctx.json(
770
- createFetchResult({
771
- url: websocketURL,
772
- id: "tail-id",
773
- expires_at: mockTailExpiration,
774
- })
775
- )
776
- );
777
- }
778
- )
779
- );
780
-
781
- return requests;
782
- }
783
-
784
- /**
785
- * Mock expiration datetime for tails created during testing
786
- */
787
- const mockTailExpiration = new Date(3005, 1);
788
-
789
- /**
790
- * Default value for event timestamps
791
- */
792
- const mockEventTimestamp = 1645454470467;
793
-
794
- /**
795
- * Default value for event time ISO strings
796
- */
797
- const mockEventScheduledTime = new Date(mockEventTimestamp).toISOString();
798
-
799
- /**
800
- * Default value for email event from
801
- */
802
- const mockEmailEventFrom = "from@example.com";
803
-
804
- /**
805
- * Default value for email event to
806
- */
807
- const mockEmailEventTo = "to@example.com";
808
-
809
- /**
810
- * Default value for email event mail size
811
- */
812
- const mockEmailEventSize = 45416;
813
-
814
- /**
815
- * Mock out the API hit during Tail deletion
816
- *
817
- * @returns a `RequestCounter` for counting how many times the API is hit
818
- */
819
- function mockDeleteTailRequest(
820
- env?: string,
821
- legacyEnv = false,
822
- expectedScriptName = legacyEnv && env ? `test-worker-${env}` : "test-worker"
823
- ): RequestCounter {
824
- const requests = { count: 0 };
825
- const servicesOrScripts = env && !legacyEnv ? "services" : "scripts";
826
- const environment = env && !legacyEnv ? "/environments/:envName" : "";
827
- msw.use(
828
- rest.delete(
829
- `*/accounts/:accountId/workers/${servicesOrScripts}/:scriptName${environment}/tails/:tailId`,
830
- async (req, res, ctx) => {
831
- requests.count++;
832
- expect(req.params.accountId).toEqual("some-account-id");
833
- expect(req.params.scriptName).toEqual(expectedScriptName);
834
- if (!legacyEnv) {
835
- if (env) {
836
- expect(req.params.tailId).toEqual("tail-id");
837
- }
838
- }
839
- expect(req.params.tailId).toEqual("tail-id");
840
- return res(ctx.json(createFetchResult(null)));
841
- }
842
- )
843
- );
844
-
845
- return requests;
846
- }
847
-
848
- const mockWebSockets: MockWebSocket[] = [];
849
-
850
- /**
851
- * All-in-one convenience method to mock the appropriate API calls before
852
- * each test, and clean up afterwards.
853
- *
854
- * @param websocketURL a fake websocket URL for wrangler to connect to
855
- * @returns a mocked-out version of the API
856
- */
857
- function mockWebsocketAPIs(
858
- env?: string,
859
- legacyEnv = false,
860
- expectedScriptName?: string
861
- ): MockAPI {
862
- const websocketURL = "ws://localhost:1234";
863
- const api: MockAPI = {
864
- requests: {
865
- deletion: { count: 0 },
866
- creation: [],
867
- },
868
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
869
- ws: null!, // will be set in the `beforeEach()` below.
870
-
871
- /**
872
- * Parse the next message received by the mock websocket as JSON
873
- * @returns JSON.parse of the next message received by the websocket
874
- */
875
- async nextMessageJson() {
876
- const message = await api.ws.nextMessage;
877
- return JSON.parse(message as string);
878
- },
879
- /**
880
- * Close the mock websocket and clean up the API.
881
- * The setTimeout forces a cycle to allow for closing and cleanup
882
- * @returns a Promise that resolves when the websocket is closed
883
- */
884
- async closeHelper() {
885
- api.ws.close();
886
- await new Promise((resolve) => setTimeout(resolve, 0));
887
- },
888
- };
889
- api.requests.creation = mockCreateTailRequest(
890
- websocketURL,
891
- env,
892
- legacyEnv,
893
- expectedScriptName
894
- );
895
- api.requests.deletion = mockDeleteTailRequest(
896
- env,
897
- legacyEnv,
898
- expectedScriptName
899
- );
900
- api.ws = new MockWebSocket(websocketURL);
901
- mockWebSockets.push(api.ws);
902
-
903
- return api;
904
- }
905
-
906
- /**
907
- * Generate a mock `TailEventMessage` of the same shape sent back by the
908
- * tail worker.
909
- *
910
- * @param opts Any specific parts of the message to use instead of defaults
911
- * @returns a `TailEventMessage` that wrangler can process and display
912
- */
913
- function generateMockEventMessage({
914
- outcome = "ok",
915
- exceptions = [],
916
- logs = [],
917
- eventTimestamp = mockEventTimestamp,
918
- event = generateMockRequestEvent(),
919
- }: Partial<TailEventMessage>): TailEventMessage {
920
- return {
921
- outcome,
922
- exceptions,
923
- logs,
924
- eventTimestamp,
925
- event,
926
- };
927
- }
928
-
929
- /**
930
- * Generate a mock `RequestEvent` that, in an alternate timeline, was used
931
- * to trigger a worker. You can't disprove this!
932
- *
933
- * @param opts Any specific parts of the event to use instead of defaults
934
- * @returns a `RequestEvent` that can be used within an `EventMessage`
935
- */
936
- function generateMockRequestEvent(
937
- opts?: Partial<RequestEvent["request"]>
938
- ): RequestEvent {
939
- return {
940
- request: Object.assign(
941
- new Request(opts?.url || "https://example.org/", {
942
- method: opts?.method || "GET",
943
- headers:
944
- opts?.headers || new Headers({ "X-EXAMPLE-HEADER": "some_value" }),
945
- }),
946
- {
947
- cf: opts?.cf || {
948
- tlsCipher: "AEAD-ENCRYPT-O-MATIC-SHA",
949
- tlsVersion: "TLSv2.0",
950
- asn: 42069,
951
- colo: "ATL",
952
- httpProtocol: "HTTP/4",
953
- asOrganization: "Cloudflare",
954
- },
955
- }
956
- ),
957
- };
958
- }
959
-
960
- function generateMockScheduledEvent(
961
- opts?: Partial<ScheduledEvent>
962
- ): ScheduledEvent {
963
- return {
964
- cron: opts?.cron || "* * * * *",
965
- scheduledTime: opts?.scheduledTime || mockEventTimestamp,
966
- };
967
- }
968
-
969
- function generateMockAlarmEvent(opts?: Partial<AlarmEvent>): AlarmEvent {
970
- return {
971
- scheduledTime: opts?.scheduledTime || mockEventScheduledTime,
972
- };
973
- }
974
-
975
- function generateMockEmailEvent(opts?: Partial<EmailEvent>): EmailEvent {
976
- return {
977
- mailFrom: opts?.mailFrom || mockEmailEventFrom,
978
- rcptTo: opts?.rcptTo || mockEmailEventTo,
979
- rawSize: opts?.rawSize || mockEmailEventSize,
980
- };
981
- }
982
-
983
- function generateTailInfo(): TailInfo {
984
- return {
985
- message:
986
- "Tail is currently in sampling mode due to the high volume of messages. To prevent messages from being dropped consider adding filters.",
987
- type: "overload",
988
- };
989
- }