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,493 +0,0 @@
1
- import { mkdirSync } from "node:fs";
2
- import { rest } from "msw";
3
- import { version as wranglerVersion } from "../../package.json";
4
- import { purgeConfigCaches, saveToConfigCache } from "../config-cache";
5
- import { CI } from "../is-ci";
6
- import { logger } from "../logger";
7
- import { getMetricsDispatcher, getMetricsConfig } from "../metrics";
8
- import {
9
- CURRENT_METRICS_DATE,
10
- readMetricsConfig,
11
- USER_ID_CACHE_PATH,
12
- writeMetricsConfig,
13
- } from "../metrics/metrics-config";
14
- import { writeAuthConfigFile } from "../user";
15
- import { mockConsoleMethods } from "./helpers/mock-console";
16
- import { mockConfirm, clearDialogs } from "./helpers/mock-dialogs";
17
- import { useMockIsTTY } from "./helpers/mock-istty";
18
- import { msw, mswSuccessOauthHandlers } from "./helpers/msw";
19
- import { runInTempDir } from "./helpers/run-in-tmp";
20
-
21
- declare const global: { SPARROW_SOURCE_KEY: string | undefined };
22
-
23
- describe("metrics", () => {
24
- const ORIGINAL_SPARROW_SOURCE_KEY = global.SPARROW_SOURCE_KEY;
25
- const std = mockConsoleMethods();
26
- runInTempDir();
27
-
28
- beforeEach(() => {
29
- // Tell jest to use the original version of the `getMetricsConfig()` function in these tests.
30
- const mockMetricsConfig = jest.requireMock("../metrics/metrics-config");
31
- mockMetricsConfig.useOriginal = true;
32
- global.SPARROW_SOURCE_KEY = "MOCK_KEY";
33
- logger.loggerLevel = "debug";
34
- // Create a node_modules directory to store config-cache files
35
- mkdirSync("node_modules");
36
- });
37
- afterEach(() => {
38
- global.SPARROW_SOURCE_KEY = ORIGINAL_SPARROW_SOURCE_KEY;
39
- purgeConfigCaches();
40
- clearDialogs();
41
- });
42
-
43
- describe("getMetricsDispatcher()", () => {
44
- const MOCK_DISPATCHER_OPTIONS = {
45
- // By setting this to true we avoid the `getMetricsConfig()` logic in these tests.
46
- sendMetrics: true,
47
- offline: false,
48
- };
49
-
50
- // These tests should never hit the `/user` API endpoint.
51
- const userRequests = mockUserRequest();
52
- afterEach(() => {
53
- expect(userRequests.count).toBe(0);
54
- });
55
-
56
- describe("identify()", () => {
57
- it("should send a request to the default URL", async () => {
58
- const request = mockMetricRequest(
59
- {
60
- event: "identify",
61
- properties: {
62
- category: "Workers",
63
- wranglerVersion,
64
- os: process.platform + ":" + process.arch,
65
- a: 1,
66
- b: 2,
67
- },
68
- },
69
- { "Sparrow-Source-Key": "MOCK_KEY" },
70
- "identify"
71
- );
72
- const dispatcher = await getMetricsDispatcher(MOCK_DISPATCHER_OPTIONS);
73
- await dispatcher.identify({ a: 1, b: 2 });
74
-
75
- expect(request.count).toBe(1);
76
- expect(std.debug).toMatchInlineSnapshot(
77
- `"Metrics dispatcher: Posting data {\\"type\\":\\"identify\\",\\"name\\":\\"identify\\",\\"properties\\":{\\"a\\":1,\\"b\\":2}}"`
78
- );
79
- expect(std.out).toMatchInlineSnapshot(`""`);
80
- expect(std.warn).toMatchInlineSnapshot(`""`);
81
- expect(std.err).toMatchInlineSnapshot(`""`);
82
- });
83
-
84
- it("should write a debug log if the dispatcher is disabled", async () => {
85
- const requests = mockMetricRequest({}, {}, "identify");
86
- const dispatcher = await getMetricsDispatcher({
87
- ...MOCK_DISPATCHER_OPTIONS,
88
- sendMetrics: false,
89
- });
90
- await dispatcher.identify({ a: 1, b: 2 });
91
- await flushPromises();
92
-
93
- expect(requests.count).toBe(0);
94
- expect(std.debug).toMatchInlineSnapshot(
95
- `"Metrics dispatcher: Dispatching disabled - would have sent {\\"type\\":\\"identify\\",\\"name\\":\\"identify\\",\\"properties\\":{\\"a\\":1,\\"b\\":2}}."`
96
- );
97
- expect(std.out).toMatchInlineSnapshot(`""`);
98
- expect(std.warn).toMatchInlineSnapshot(`""`);
99
- expect(std.err).toMatchInlineSnapshot(`""`);
100
- });
101
-
102
- it("should write a debug log if the request fails", async () => {
103
- msw.use(
104
- rest.post("*/identify", async (req, res) => {
105
- return res.networkError("BAD REQUEST");
106
- })
107
- );
108
-
109
- const dispatcher = await getMetricsDispatcher(MOCK_DISPATCHER_OPTIONS);
110
- await dispatcher.identify({ a: 1, b: 2 });
111
- await flushPromises();
112
- expect(std.debug).toMatchInlineSnapshot(`
113
- "Metrics dispatcher: Posting data {\\"type\\":\\"identify\\",\\"name\\":\\"identify\\",\\"properties\\":{\\"a\\":1,\\"b\\":2}}
114
- Metrics dispatcher: Failed to send request: request to https://sparrow.cloudflare.com/api/v1/identify failed, reason: BAD REQUEST"
115
- `);
116
- expect(std.out).toMatchInlineSnapshot(`""`);
117
- expect(std.warn).toMatchInlineSnapshot(`""`);
118
- expect(std.err).toMatchInlineSnapshot(`""`);
119
- });
120
-
121
- it("should write a warning log if no source key has been provided", async () => {
122
- global.SPARROW_SOURCE_KEY = undefined;
123
- const dispatcher = await getMetricsDispatcher(MOCK_DISPATCHER_OPTIONS);
124
- await dispatcher.identify({ a: 1, b: 2 });
125
- expect(std.debug).toMatchInlineSnapshot(
126
- `"Metrics dispatcher: Source Key not provided. Be sure to initialize before sending events. { type: 'identify', name: 'identify', properties: { a: 1, b: 2 } }"`
127
- );
128
- expect(std.out).toMatchInlineSnapshot(`""`);
129
- expect(std.warn).toMatchInlineSnapshot(`""`);
130
- expect(std.err).toMatchInlineSnapshot(`""`);
131
- });
132
- });
133
-
134
- describe("sendEvent()", () => {
135
- it("should send a request to the default URL", async () => {
136
- const requests = mockMetricRequest(
137
- {
138
- event: "some-event",
139
- properties: {
140
- category: "Workers",
141
- wranglerVersion,
142
- os: process.platform + ":" + process.arch,
143
- a: 1,
144
- b: 2,
145
- },
146
- },
147
- {
148
- "Sparrow-Source-Key": "MOCK_KEY",
149
- },
150
- "event"
151
- );
152
- const dispatcher = await getMetricsDispatcher(MOCK_DISPATCHER_OPTIONS);
153
- await dispatcher.sendEvent("some-event", { a: 1, b: 2 });
154
-
155
- expect(requests.count).toBe(1);
156
- expect(std.debug).toMatchInlineSnapshot(
157
- `"Metrics dispatcher: Posting data {\\"type\\":\\"event\\",\\"name\\":\\"some-event\\",\\"properties\\":{\\"a\\":1,\\"b\\":2}}"`
158
- );
159
- expect(std.out).toMatchInlineSnapshot(`""`);
160
- expect(std.warn).toMatchInlineSnapshot(`""`);
161
- expect(std.err).toMatchInlineSnapshot(`""`);
162
- });
163
-
164
- it("should write a debug log if the dispatcher is disabled", async () => {
165
- const requests = mockMetricRequest({}, {}, "event");
166
-
167
- const dispatcher = await getMetricsDispatcher({
168
- ...MOCK_DISPATCHER_OPTIONS,
169
- sendMetrics: false,
170
- });
171
- await dispatcher.sendEvent("some-event", { a: 1, b: 2 });
172
- await flushPromises();
173
-
174
- expect(requests.count).toBe(0);
175
- expect(std.debug).toMatchInlineSnapshot(
176
- `"Metrics dispatcher: Dispatching disabled - would have sent {\\"type\\":\\"event\\",\\"name\\":\\"some-event\\",\\"properties\\":{\\"a\\":1,\\"b\\":2}}."`
177
- );
178
- expect(std.out).toMatchInlineSnapshot(`""`);
179
- expect(std.warn).toMatchInlineSnapshot(`""`);
180
- expect(std.err).toMatchInlineSnapshot(`""`);
181
- });
182
-
183
- it("should write a debug log if the request fails", async () => {
184
- msw.use(
185
- rest.post("*/event", async (_, res) => {
186
- return res.networkError("BAD REQUEST");
187
- })
188
- );
189
- const dispatcher = await getMetricsDispatcher(MOCK_DISPATCHER_OPTIONS);
190
- await dispatcher.sendEvent("some-event", { a: 1, b: 2 });
191
- await flushPromises();
192
- expect(std.debug).toMatchInlineSnapshot(`
193
- "Metrics dispatcher: Posting data {\\"type\\":\\"event\\",\\"name\\":\\"some-event\\",\\"properties\\":{\\"a\\":1,\\"b\\":2}}
194
- Metrics dispatcher: Failed to send request: request to https://sparrow.cloudflare.com/api/v1/event failed, reason: BAD REQUEST"
195
- `);
196
- expect(std.out).toMatchInlineSnapshot(`""`);
197
- expect(std.warn).toMatchInlineSnapshot(`""`);
198
- expect(std.err).toMatchInlineSnapshot(`""`);
199
- });
200
-
201
- it("should write a warning log if no source key has been provided", async () => {
202
- global.SPARROW_SOURCE_KEY = undefined;
203
- const requests = mockMetricRequest({}, {}, "event");
204
- const dispatcher = await getMetricsDispatcher(MOCK_DISPATCHER_OPTIONS);
205
- await dispatcher.sendEvent("some-event", { a: 1, b: 2 });
206
-
207
- expect(requests.count).toBe(0);
208
- expect(std.debug).toMatchInlineSnapshot(
209
- `"Metrics dispatcher: Source Key not provided. Be sure to initialize before sending events. { type: 'event', name: 'some-event', properties: { a: 1, b: 2 } }"`
210
- );
211
- expect(std.out).toMatchInlineSnapshot(`""`);
212
- expect(std.warn).toMatchInlineSnapshot(`""`);
213
- expect(std.err).toMatchInlineSnapshot(`""`);
214
- });
215
- });
216
- });
217
-
218
- describe("getMetricsConfig()", () => {
219
- let isCISpy: jest.SpyInstance;
220
-
221
- const { setIsTTY } = useMockIsTTY();
222
- beforeEach(() => {
223
- // Default the mock TTY to interactive for all these tests.
224
- setIsTTY(true);
225
- isCISpy = jest.spyOn(CI, "isCI").mockReturnValue(false);
226
- });
227
-
228
- describe("enabled", () => {
229
- const ORIGINAL_ENV = process.env;
230
- beforeEach(() => {
231
- process.env = { ...ORIGINAL_ENV };
232
- });
233
- afterEach(() => {
234
- process.env = ORIGINAL_ENV;
235
- });
236
-
237
- it("should return the WRANGLER_SEND_METRICS environment variable for enabled if it is defined", async () => {
238
- process.env.WRANGLER_SEND_METRICS = "false";
239
- expect(await getMetricsConfig({})).toMatchObject({
240
- enabled: false,
241
- });
242
- process.env.WRANGLER_SEND_METRICS = "true";
243
- expect(await getMetricsConfig({})).toMatchObject({
244
- enabled: true,
245
- });
246
- });
247
-
248
- it("should return false if running in a CI environment", async () => {
249
- isCISpy.mockReturnValue(true);
250
- expect(await getMetricsConfig({})).toMatchObject({
251
- enabled: false,
252
- });
253
- });
254
-
255
- it("should return the sendMetrics argument for enabled if it is defined", async () => {
256
- expect(
257
- await getMetricsConfig({ sendMetrics: false, offline: false })
258
- ).toMatchObject({
259
- enabled: false,
260
- });
261
- expect(
262
- await getMetricsConfig({ sendMetrics: true, offline: false })
263
- ).toMatchObject({
264
- enabled: true,
265
- });
266
- });
267
-
268
- it("should return enabled false if the process is not interactive", async () => {
269
- setIsTTY(false);
270
- expect(
271
- await getMetricsConfig({
272
- sendMetrics: undefined,
273
- offline: false,
274
- })
275
- ).toMatchObject({
276
- enabled: false,
277
- });
278
- });
279
-
280
- it("should return enabled true if the user on this device previously agreed to send metrics", async () => {
281
- await writeMetricsConfig({
282
- permission: {
283
- enabled: true,
284
- date: new Date(2022, 6, 4),
285
- },
286
- });
287
- expect(
288
- await getMetricsConfig({
289
- sendMetrics: undefined,
290
- offline: false,
291
- })
292
- ).toMatchObject({
293
- enabled: true,
294
- });
295
- });
296
-
297
- it("should return enabled false if the user on this device previously refused to send metrics", async () => {
298
- await writeMetricsConfig({
299
- permission: {
300
- enabled: false,
301
- date: new Date(2022, 6, 4),
302
- },
303
- });
304
- expect(
305
- await getMetricsConfig({
306
- sendMetrics: undefined,
307
- offline: false,
308
- })
309
- ).toMatchObject({
310
- enabled: false,
311
- });
312
- });
313
-
314
- it("should accept and store permission granting to send metrics if the user agrees", async () => {
315
- mockConfirm({
316
- text: "Would you like to help improve Wrangler by sending usage metrics to Cloudflare?",
317
- result: true,
318
- });
319
- expect(
320
- await getMetricsConfig({
321
- sendMetrics: undefined,
322
- offline: false,
323
- })
324
- ).toMatchObject({
325
- enabled: true,
326
- });
327
- expect((await readMetricsConfig()).permission).toMatchObject({
328
- enabled: true,
329
- });
330
- });
331
-
332
- it("should accept and store permission declining to send metrics if the user declines", async () => {
333
- mockConfirm({
334
- text: "Would you like to help improve Wrangler by sending usage metrics to Cloudflare?",
335
- result: false,
336
- });
337
- expect(
338
- await getMetricsConfig({
339
- sendMetrics: undefined,
340
- offline: false,
341
- })
342
- ).toMatchObject({
343
- enabled: false,
344
- });
345
- expect((await readMetricsConfig()).permission).toMatchObject({
346
- enabled: false,
347
- });
348
- });
349
-
350
- it("should ignore the config if the permission date is older than the current metrics date", async () => {
351
- mockConfirm({
352
- text: "Would you like to help improve Wrangler by sending usage metrics to Cloudflare?",
353
- result: false,
354
- });
355
- const OLD_DATE = new Date(2000);
356
- await writeMetricsConfig({
357
- permission: { enabled: true, date: OLD_DATE },
358
- });
359
- expect(
360
- await getMetricsConfig({
361
- sendMetrics: undefined,
362
- offline: false,
363
- })
364
- ).toMatchObject({
365
- enabled: false,
366
- });
367
- const { permission } = await readMetricsConfig();
368
- expect(permission?.enabled).toBe(false);
369
- // The date should be updated to today's date
370
- expect(permission?.date).toEqual(CURRENT_METRICS_DATE);
371
-
372
- expect(std.out).toMatchInlineSnapshot(`
373
- "Usage metrics tracking has changed since you last granted permission.
374
- Your choice has been saved in the following file: test-xdg-config/metrics.json.
375
-
376
- You can override the user level setting for a project in \`wrangler.toml\`:
377
-
378
- - to disable sending metrics for a project: \`send_metrics = false\`
379
- - to enable sending metrics for a project: \`send_metrics = true\`"
380
- `);
381
- });
382
- });
383
-
384
- describe("deviceId", () => {
385
- it("should return a deviceId found in the config file", async () => {
386
- await writeMetricsConfig({ deviceId: "XXXX-YYYY-ZZZZ" });
387
- const { deviceId } = await getMetricsConfig({
388
- sendMetrics: true,
389
- offline: false,
390
- });
391
- expect(deviceId).toEqual("XXXX-YYYY-ZZZZ");
392
- expect((await readMetricsConfig()).deviceId).toEqual(deviceId);
393
- });
394
-
395
- it("should create and store a new deviceId if none is found in the config file", async () => {
396
- await writeMetricsConfig({});
397
- const { deviceId } = await getMetricsConfig({
398
- sendMetrics: true,
399
- offline: false,
400
- });
401
- expect(deviceId).toMatch(
402
- /[0-9a-fA-F]{8}-([0-9a-fA-F]{4}-){3}[0-9a-fA-F]{12}/
403
- );
404
- expect((await readMetricsConfig()).deviceId).toEqual(deviceId);
405
- });
406
- });
407
-
408
- describe("userId", () => {
409
- const userRequests = mockUserRequest();
410
- it("should return a userId found in a cache file", async () => {
411
- await saveToConfigCache(USER_ID_CACHE_PATH, {
412
- userId: "CACHED_USER_ID",
413
- });
414
- const { userId } = await getMetricsConfig({
415
- sendMetrics: true,
416
- offline: false,
417
- });
418
- expect(userId).toEqual("CACHED_USER_ID");
419
- expect(userRequests.count).toBe(0);
420
- });
421
-
422
- it("should fetch the userId from Cloudflare and store it in a cache file", async () => {
423
- writeAuthConfigFile({ oauth_token: "DUMMY_TOKEN" });
424
- const { userId } = await getMetricsConfig({
425
- sendMetrics: true,
426
- offline: false,
427
- });
428
- await flushPromises();
429
-
430
- expect(userId).toEqual("MOCK_USER_ID");
431
- expect(userRequests.count).toBe(1);
432
- });
433
-
434
- it("should not fetch the userId from Cloudflare if running in `offline` mode", async () => {
435
- writeAuthConfigFile({ oauth_token: "DUMMY_TOKEN" });
436
- const { userId } = await getMetricsConfig({
437
- sendMetrics: true,
438
- offline: true,
439
- });
440
- expect(userId).toBe(undefined);
441
- expect(userRequests.count).toBe(0);
442
- });
443
- });
444
- });
445
- });
446
-
447
- function mockUserRequest() {
448
- const requests = { count: 0 };
449
- beforeEach(() => {
450
- msw.use(
451
- ...mswSuccessOauthHandlers,
452
- rest.get("*/user", (_, res, cxt) => {
453
- requests.count++;
454
- return res(
455
- cxt.status(200),
456
- cxt.json({
457
- success: true,
458
- errors: [],
459
- messages: [],
460
- result: { id: "MOCK_USER_ID" },
461
- })
462
- );
463
- })
464
- );
465
- });
466
- afterEach(() => {
467
- requests.count = 0;
468
- });
469
- return requests;
470
- }
471
-
472
- function mockMetricRequest(
473
- body: unknown,
474
- header: unknown,
475
- endpoint: "identify" | "event"
476
- ) {
477
- const requests = { count: 0 };
478
- msw.use(
479
- rest.post(`*/${endpoint}`, async (req, res, cxt) => {
480
- requests.count++;
481
- expect(await req.json()).toEqual(body);
482
- expect(req.headers).toContain(header);
483
- return res.once(cxt.status(200), cxt.json({}));
484
- })
485
- );
486
-
487
- return requests;
488
- }
489
-
490
- // Forces a tick to allow the non-awaited fetch promise to resolve.
491
- function flushPromises(): Promise<void> {
492
- return new Promise((resolve) => setTimeout(resolve, 0));
493
- }
@@ -1,145 +0,0 @@
1
- import * as fs from "node:fs";
2
- import { unstable_dev } from "../api";
3
- import { runInTempDir } from "./helpers/run-in-tmp";
4
-
5
- jest.unmock("undici");
6
-
7
- describe("run scheduled events with middleware", () => {
8
- describe("module workers", () => {
9
- runInTempDir();
10
-
11
- beforeEach(() => {
12
- const scriptContent = `
13
- export default {
14
- fetch(request, env, ctx) {
15
- const url = new URL(request.url);
16
- if (url.pathname === "/__scheduled") {
17
- return new Response("Fetch triggered at /__scheduled");
18
- }
19
- return new Response("Hello world!");
20
- },
21
- scheduled(controller, env, ctx) {
22
- // Doing something scheduled in modules...
23
- },
24
- };
25
- `;
26
- fs.writeFileSync("index.js", scriptContent);
27
- });
28
-
29
- it("should not intercept when middleware is not enabled", async () => {
30
- const worker = await unstable_dev("index.js", {
31
- experimental: {
32
- disableExperimentalWarning: true,
33
- disableDevRegistry: true,
34
- },
35
- });
36
-
37
- const resp = await worker.fetch("/__scheduled");
38
- let text;
39
- if (resp) text = await resp.text();
40
- expect(text).toMatchInlineSnapshot(`"Fetch triggered at /__scheduled"`);
41
- await worker.stop();
42
- });
43
-
44
- it("should intercept when middleware is enabled", async () => {
45
- const worker = await unstable_dev("index.js", {
46
- experimental: {
47
- disableExperimentalWarning: true,
48
- disableDevRegistry: true,
49
- testScheduled: true,
50
- },
51
- });
52
-
53
- const resp = await worker.fetch("/__scheduled");
54
- let text;
55
- if (resp) text = await resp.text();
56
- expect(text).toMatchInlineSnapshot(`"Ran scheduled event"`);
57
- await worker.stop();
58
- });
59
-
60
- it("should not trigger scheduled event on wrong route", async () => {
61
- const worker = await unstable_dev("index.js", {
62
- experimental: {
63
- disableExperimentalWarning: true,
64
- disableDevRegistry: true,
65
- testScheduled: true,
66
- },
67
- });
68
-
69
- const resp = await worker.fetch("/test");
70
- let text;
71
- if (resp) text = await resp.text();
72
- expect(text).toMatchInlineSnapshot(`"Hello world!"`);
73
- await worker.stop();
74
- });
75
- });
76
-
77
- describe("service workers", () => {
78
- runInTempDir();
79
-
80
- beforeEach(() => {
81
- const scriptContent = `
82
- addEventListener("scheduled", (event) => {
83
- // Doing something scheduled in service worker...
84
- });
85
-
86
- addEventListener("fetch", (event) => {
87
- const url = new URL(event.request.url);
88
- if (url.pathname === "/__scheduled") {
89
- event.respondWith(new Response("Fetch triggered at /__scheduled"));
90
- } else {
91
- event.respondWith(new Response("Hello world!"));
92
- }
93
- });
94
- `;
95
- fs.writeFileSync("index.js", scriptContent);
96
- });
97
-
98
- it("should not intercept when middleware is not enabled", async () => {
99
- const worker = await unstable_dev("index.js", {
100
- experimental: {
101
- disableExperimentalWarning: true,
102
- disableDevRegistry: true,
103
- },
104
- });
105
-
106
- const resp = await worker.fetch("/__scheduled");
107
- let text;
108
- if (resp) text = await resp.text();
109
- expect(text).toMatchInlineSnapshot(`"Fetch triggered at /__scheduled"`);
110
- await worker.stop();
111
- });
112
-
113
- it("should intercept when middleware is enabled", async () => {
114
- const worker = await unstable_dev("index.js", {
115
- experimental: {
116
- disableExperimentalWarning: true,
117
- disableDevRegistry: true,
118
- testScheduled: true,
119
- },
120
- });
121
-
122
- const resp = await worker.fetch("/__scheduled");
123
- let text;
124
- if (resp) text = await resp.text();
125
- expect(text).toMatchInlineSnapshot(`"Ran scheduled event"`);
126
- await worker.stop();
127
- });
128
-
129
- it("should not trigger scheduled event on wrong route", async () => {
130
- const worker = await unstable_dev("index.js", {
131
- experimental: {
132
- disableExperimentalWarning: true,
133
- disableDevRegistry: true,
134
- testScheduled: true,
135
- },
136
- });
137
-
138
- const resp = await worker.fetch("/test");
139
- let text;
140
- if (resp) text = await resp.text();
141
- expect(text).toMatchInlineSnapshot(`"Hello world!"`);
142
- await worker.stop();
143
- });
144
- });
145
- });