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,250 +0,0 @@
1
- import { consolidateRoutes, shortenRoute } from "./routes-consolidation";
2
-
3
- describe("route-consolidation", () => {
4
- const maxRuleLength = 100; // from constants.MAX_FUNCTIONS_ROUTES_RULE_LENGTH
5
- describe("consolidateRoutes()", () => {
6
- it("should consolidate redundant routes", () => {
7
- expect(consolidateRoutes(["/api/foo", "/api/*"])).toEqual(["/api/*"]);
8
- expect(
9
- consolidateRoutes([
10
- "/api/foo",
11
- "/api/foo/*",
12
- "/api/bar/*",
13
- "/api/*",
14
- "/foo",
15
- "/foo/bar",
16
- "/bar/*",
17
- "/bar/baz/*",
18
- "/bar/baz/hello",
19
- ])
20
- ).toEqual(["/api/*", "/foo", "/foo/bar", "/bar/*"]);
21
- });
22
- it("should consolidate thousands of redundant routes", () => {
23
- // Test to make sure the consolidator isn't horribly slow
24
- const routes: string[] = [];
25
- const limit = 1000;
26
- for (let i = 0; i < limit; i++) {
27
- // Add 3 routes per id
28
- const id = `some-id-${i}`;
29
- routes.push(`/${id}/*`, `/${id}/foo`, `/${id}/bar/*`);
30
- }
31
- const consolidated = consolidateRoutes(routes);
32
- expect(consolidated.length).toEqual(limit);
33
- // Should be all unique
34
- expect(Array.from(new Set(consolidated)).length).toEqual(limit);
35
- // Should all have pattern `/$id/*`
36
- expect(
37
- consolidated.every((route) => route.match(/\/[a-z0-9-]+\/\*/) !== null)
38
- ).toEqual(true);
39
- });
40
-
41
- it("should consolidate many redundant sub-routes", () => {
42
- const routes: string[] = [];
43
- const limit = 15;
44
-
45
- // Create $limit of top-level catch-all routes, with a lot of sub-routes
46
- for (let i = 0; i < limit; i++) {
47
- routes.push(`/foo-${i}/*`);
48
- for (let j = 0; j < limit; j++) {
49
- routes.push(`/foo-${i}/bar-${j}/hello`);
50
- for (let k = 0; k < limit; k++) {
51
- routes.push(`/foo-${i}/bar-${j}/baz-${k}/*`);
52
- routes.push(`/foo-${i}/bar-${j}/baz-${k}/profile`);
53
- }
54
- }
55
- }
56
-
57
- const consolidated = consolidateRoutes(routes);
58
- expect(consolidated.length).toEqual(limit);
59
- // Should be all unique
60
- expect(Array.from(new Set(consolidated)).length).toEqual(limit);
61
- // Should all have pattern `/$id/*`
62
- expect(
63
- consolidated.every((route) => route.match(/\/[a-z0-9-]+\/\*/) !== null)
64
- ).toEqual(true);
65
- });
66
-
67
- it("should truncate long single-level path into catch-all path, removing other paths", () => {
68
- expect(
69
- consolidateRoutes([
70
- // [/aaaaaaa, /foo] -> [/*]
71
- "/" + "a".repeat(maxRuleLength * 2),
72
- "/foo",
73
- "/bar/*",
74
- "/baz/bagel/coffee",
75
- ])
76
- ).toEqual(["/*"]);
77
- });
78
-
79
- it("should truncate long nested path, removing other paths", () => {
80
- expect(
81
- consolidateRoutes([
82
- // [/aaaaaaa, /foo] -> [/*]
83
- "/foo/" + "a".repeat(maxRuleLength * 2),
84
- "/foo/bar",
85
- ])
86
- ).toEqual(["/foo/*"]);
87
- });
88
- });
89
-
90
- describe(`shortenRoute()`, () => {
91
- it("should allow max length path", () => {
92
- const route = "/" + "a".repeat(maxRuleLength - 1);
93
- // Make sure we don't have an off-by-one error, that'd be embarrassing...
94
- expect(route.length).toEqual(maxRuleLength);
95
- expect(
96
- // Should stay the same
97
- shortenRoute(route)
98
- ).toEqual(route);
99
- });
100
-
101
- it("should allow max length path (with slash)", () => {
102
- const route = "/" + "a".repeat(maxRuleLength - 2) + "/";
103
- expect(route.length).toEqual(maxRuleLength);
104
- expect(
105
- // Should stay the same
106
- shortenRoute(route)
107
- ).toEqual(route);
108
- });
109
-
110
- it("should allow max length wildcard path", () => {
111
- const route = "/" + "a".repeat(maxRuleLength - 3) + "/*";
112
- expect(route.length).toEqual(maxRuleLength);
113
- expect(
114
- // Should stay the same
115
- shortenRoute(route)
116
- ).toEqual(route);
117
- });
118
-
119
- it("should truncate long specific path to shorter wildcard path", () => {
120
- const short = shortenRoute(
121
- // /aaa/bbb -> /aaa/*
122
- "/" +
123
- "a".repeat(maxRuleLength * 0.6) +
124
- "/" +
125
- "b".repeat(maxRuleLength * 0.6)
126
- );
127
- expect(short).toEqual("/" + "a".repeat(maxRuleLength * 0.6) + "/*");
128
- expect(short.length).toBeLessThanOrEqual(maxRuleLength);
129
- });
130
-
131
- it("should truncate long specific path (with slash) to shorter wildcard path", () => {
132
- const short = shortenRoute(
133
- // /aaa/bbb/ -> /aaa/*
134
- "/" +
135
- "a".repeat(maxRuleLength * 0.6) +
136
- "/" +
137
- "b".repeat(maxRuleLength * 0.6) +
138
- "/"
139
- );
140
- expect(short).toEqual("/" + "a".repeat(maxRuleLength * 0.6) + "/*");
141
- expect(short.length).toBeLessThanOrEqual(maxRuleLength);
142
- });
143
-
144
- it("should truncate long wildcard path to shorter wildcard path", () => {
145
- const short = shortenRoute(
146
- // /aaa/bbb/* -> /aaa/*
147
- "/" +
148
- "a".repeat(maxRuleLength * 0.6) +
149
- "/" +
150
- "b".repeat(maxRuleLength * 0.6) +
151
- "/*"
152
- );
153
- expect(short).toEqual("/" + "a".repeat(maxRuleLength * 0.6) + "/*");
154
- expect(short.length).toBeLessThanOrEqual(maxRuleLength);
155
- });
156
-
157
- it("should truncate long single-level specific path to catch-all path", () => {
158
- expect(
159
- shortenRoute(
160
- // /aaa -> /*
161
- "/" + "a".repeat(maxRuleLength * 2)
162
- )
163
- ).toEqual("/*");
164
- });
165
-
166
- it("should truncate long single-level specific path (with slash) to catch-all path", () => {
167
- expect(
168
- shortenRoute(
169
- // /aaa/ -> /*
170
- "/" + "a".repeat(maxRuleLength * 2) + "/"
171
- )
172
- ).toEqual("/*");
173
- });
174
-
175
- it("should truncate long single-level wildcard path to catch-all path", () => {
176
- expect(
177
- shortenRoute(
178
- // /aaa/* -> /*
179
- "/" + "a".repeat(maxRuleLength * 2) + "/*"
180
- )
181
- ).toEqual("/*");
182
- });
183
-
184
- it("should truncate many single-character segements", () => {
185
- const short = shortenRoute(
186
- // /a/a/a -> /a/a/*
187
- "/a".repeat(maxRuleLength) // 2x limit
188
- );
189
- expect(short).toEqual("/a".repeat(maxRuleLength / 2 - 1) + "/*");
190
- // Should be the exact max length
191
- expect(short.length).toEqual(maxRuleLength);
192
- });
193
-
194
- it("should truncate many double-character segements", () => {
195
- // === odd ===
196
- const short = shortenRoute(
197
- // /aa/aa/aa -> /aa/aa/*
198
- "/aa".repeat(maxRuleLength) // 3x limit
199
- );
200
- expect(short).toEqual("/aa".repeat(maxRuleLength / 3 - 1) + "/*");
201
- // Should be the exact max length
202
- expect(short.length).toEqual(maxRuleLength - 2); // -2 because of the odd number
203
- });
204
-
205
- it("should truncate many single-character segements with wildcard", () => {
206
- const short = shortenRoute(
207
- // /a/a/a -> /a/a/*
208
- "/a".repeat(maxRuleLength) + "/*" // 2x limit
209
- );
210
- expect(short).toEqual("/a".repeat(maxRuleLength / 2 - 1) + "/*");
211
- // Should be the exact max length
212
- expect(short.length).toEqual(maxRuleLength);
213
- });
214
-
215
- it("should truncate many double-character segements with wildcard", () => {
216
- const short = shortenRoute(
217
- // /aa/aa/aa -> /aa/*
218
- "/aa".repeat(maxRuleLength) + "/*" // 2x limit
219
- );
220
- expect(short).toEqual("/aa".repeat(maxRuleLength / 3 - 1) + "/*");
221
- // Should be the exact max length
222
- expect(short.length).toEqual(maxRuleLength - 2); // -2 because of the odd number
223
- });
224
-
225
- // This is probably the best test here - tests variable-length segments, up until the max.
226
- // This ensures that it's always able to shorten rules, without failing and returning "/*"
227
- // The other tests are great for ensuring exact sequences instead of only asserting length, though.
228
- for (const suffix of ["", "/", "/*"]) {
229
- // Test each type of path: /a, /a/a, /a/*
230
- it(`should truncate many variable-character segements (suffix="${suffix}") without truncating to /*`, () => {
231
- // "/" + 97 chars + "/*" === 100
232
- for (let i = 1; i < maxRuleLength - 2; i++) {
233
- const segment = "/" + "a".repeat(i);
234
- // make sure the segment isn't too long since we are testing not resulting to /*
235
- expect(segment.length).toBeLessThanOrEqual(maxRuleLength);
236
- const route =
237
- segment.repeat((maxRuleLength / segment.length) * 2) + suffix;
238
- // Make sure we made the rule too long
239
- expect(route.length).toBeGreaterThan(maxRuleLength);
240
- const short = shortenRoute(route);
241
-
242
- // Make sure it's not over the limit
243
- expect(short.length).toBeLessThanOrEqual(maxRuleLength);
244
- // It should never have to fall back to /*
245
- expect(short).not.toEqual("/*");
246
- }
247
- });
248
- }
249
- });
250
- });
@@ -1,73 +0,0 @@
1
- import { MAX_FUNCTIONS_ROUTES_RULE_LENGTH } from "../constants";
2
-
3
- /**
4
- * consolidateRoutes consolidates redundant routes - eg. ["/api/*"", "/api/foo"] -> ["/api/*""]
5
- * @param routes If this is the same order as Functions routes (with most-specific first),
6
- * it will be more efficient to reverse it first. Should be in the format: /api/foo, /api/*
7
- * @returns Non-redundant list of routes
8
- */
9
- export function consolidateRoutes(routes: string[]): string[] {
10
- // First we need to trim any rules that are too long and deduplicate the result
11
- const routesShortened = Array.from(
12
- new Set(routes.map((route) => shortenRoute(route)))
13
- );
14
-
15
- // create a map of the routes
16
- const routesMap = new Map<string, boolean>();
17
- for (const route of routesShortened) {
18
- routesMap.set(route, true);
19
- }
20
- // Find routes that might render other routes redundant
21
- for (const route of routesShortened.filter((r) => r.endsWith("/*"))) {
22
- // Make sure the route still exists in the map
23
- if (routesMap.has(route)) {
24
- // Remove splat at the end, leaving the /
25
- // eg. /api/* -> /api/
26
- const routeTrimmed = route.substring(0, route.length - 1);
27
- for (const nextRoute of routesMap.keys()) {
28
- // Delete any route that has the wildcard route as a prefix
29
- if (nextRoute !== route && nextRoute.startsWith(routeTrimmed)) {
30
- routesMap.delete(nextRoute);
31
- }
32
- }
33
- }
34
- }
35
- return Array.from(routesMap.keys());
36
- }
37
-
38
- /**
39
- * Shortens a route until it's within the rule length limit defined in
40
- * constants.MAX_FUNCTIONS_ROUTES_RULE_LENGTH
41
- * Eg. /aaa/bbb -> /aaa/*
42
- * @param routeToShorten Route to shorten if needed
43
- * @param maxLength Max length of route to try to shorten to
44
- */
45
- export function shortenRoute(
46
- routeToShorten: string,
47
- maxLength: number = MAX_FUNCTIONS_ROUTES_RULE_LENGTH
48
- ): string {
49
- if (routeToShorten.length <= maxLength) {
50
- return routeToShorten;
51
- }
52
-
53
- let route = routeToShorten;
54
- // May have to try multiple times for longer segments
55
- for (let i = 0; i < routeToShorten.length; i++) {
56
- // Shorten to the first slash within the limit
57
- for (let j = maxLength - 1 - i; j > 0; j--) {
58
- if (route[j] === "/") {
59
- route = route.slice(0, j) + "/*";
60
- break;
61
- }
62
- }
63
- if (route.length <= maxLength) {
64
- break;
65
- }
66
- }
67
-
68
- // If we failed to shorten it, fall back to include-all rather than breaking
69
- if (route.length > maxLength) {
70
- route = "/*";
71
- }
72
- return route;
73
- }
@@ -1,282 +0,0 @@
1
- import { toUrlPath } from "../../paths";
2
- import {
3
- MAX_FUNCTIONS_ROUTES_RULES,
4
- ROUTES_SPEC_VERSION,
5
- ROUTES_SPEC_DESCRIPTION,
6
- } from "../constants";
7
- import {
8
- compareRoutes,
9
- convertRoutesToGlobPatterns,
10
- convertRoutesToRoutesJSONSpec,
11
- optimizeRoutesJSONSpec,
12
- } from "./routes-transformation";
13
-
14
- // TODO: make a convenience function for creating a list
15
- // of `convertRoutesToGlobPatterns` inputs from a string array
16
- describe("route-paths-to-glob-patterns", () => {
17
- describe("convertRoutePathsToGlobPatterns()", () => {
18
- it("should pass through routes with no wildcards", () => {
19
- expect(
20
- convertRoutesToGlobPatterns([{ routePath: toUrlPath("/api/foo") }])
21
- ).toEqual(["/api/foo"]);
22
- expect(
23
- convertRoutesToGlobPatterns([
24
- { routePath: toUrlPath("/api/foo") },
25
- { routePath: toUrlPath("/api/bar") },
26
- ])
27
- ).toEqual(["/api/foo", "/api/bar"]);
28
- expect(
29
- convertRoutesToGlobPatterns([
30
- { routePath: toUrlPath("/api/foo") },
31
- { routePath: toUrlPath("/api/bar/foo") },
32
- { routePath: toUrlPath("/foo/bar") },
33
- ])
34
- ).toEqual(["/api/foo", "/api/bar/foo", "/foo/bar"]);
35
- });
36
-
37
- it("should escalate a single param route to a wildcard", () => {
38
- expect(
39
- convertRoutesToGlobPatterns([{ routePath: toUrlPath("/api/:foo") }])
40
- ).toEqual(["/api/*"]);
41
- expect(
42
- convertRoutesToGlobPatterns([{ routePath: toUrlPath("/api/foo/:bar") }])
43
- ).toEqual(["/api/foo/*"]);
44
- expect(
45
- convertRoutesToGlobPatterns([
46
- { routePath: toUrlPath("/bar/:barId/foo") },
47
- ])
48
- ).toEqual(["/bar/*"]);
49
- expect(
50
- convertRoutesToGlobPatterns([
51
- { routePath: toUrlPath("/bar/:barId/foo/:fooId") },
52
- ])
53
- ).toEqual(["/bar/*"]);
54
- expect(
55
- convertRoutesToGlobPatterns([
56
- { routePath: toUrlPath("/api/:foo") },
57
- { routePath: toUrlPath("/bar/:barName/profile") },
58
- { routePath: toUrlPath("/foo/bar/:barId/:fooId") },
59
- ])
60
- ).toEqual(["/api/*", "/bar/*", "/foo/bar/*"]);
61
- });
62
-
63
- it("should pass through a single wildcard route", () => {
64
- expect(
65
- convertRoutesToGlobPatterns([{ routePath: toUrlPath("/api/:baz*") }])
66
- ).toEqual(["/api/*"]);
67
- expect(
68
- convertRoutesToGlobPatterns([
69
- { routePath: toUrlPath("/api/foo/bar/:baz*") },
70
- ])
71
- ).toEqual(["/api/foo/bar/*"]);
72
- expect(
73
- convertRoutesToGlobPatterns([
74
- { routePath: toUrlPath("/api/:foo/:bar*") },
75
- ])
76
- ).toEqual(["/api/*"]);
77
- expect(
78
- convertRoutesToGlobPatterns([
79
- { routePath: toUrlPath("/foo/:foo*/bar/:bar*") },
80
- ])
81
- ).toEqual(["/foo/*"]);
82
- expect(
83
- convertRoutesToGlobPatterns([
84
- { routePath: toUrlPath("/foo/:foo/bar/:bar*") },
85
- ])
86
- ).toEqual(["/foo/*"]);
87
- expect(
88
- convertRoutesToGlobPatterns([
89
- { routePath: toUrlPath("/api/:baz*") },
90
- { routePath: toUrlPath("/api/foo/bar/:baz*") },
91
- { routePath: toUrlPath("/api/:foo/:bar*") },
92
- ])
93
- ).toEqual(["/api/*", "/api/foo/bar/*"]);
94
- });
95
-
96
- it("should deduplicate identical rules", () => {
97
- expect(
98
- convertRoutesToGlobPatterns([
99
- { routePath: toUrlPath("/api/foo") },
100
- { routePath: toUrlPath("/api/foo") },
101
- ])
102
- ).toEqual(["/api/foo"]);
103
- expect(
104
- convertRoutesToGlobPatterns([
105
- { routePath: toUrlPath("/api/foo/bar") },
106
- { routePath: toUrlPath("/foo/bar") },
107
- { routePath: toUrlPath("/api/foo/bar") },
108
- ])
109
- ).toEqual(["/api/foo/bar", "/foo/bar"]);
110
- expect(
111
- convertRoutesToGlobPatterns([
112
- { routePath: toUrlPath("/api/foo/:bar") },
113
- { routePath: toUrlPath("/api/foo") },
114
- { routePath: toUrlPath("/api/foo/:fooId/bar") },
115
- { routePath: toUrlPath("/api/foo/*") },
116
- ])
117
- ).toEqual(["/api/foo/*", "/api/foo"]);
118
- expect(
119
- convertRoutesToGlobPatterns([
120
- { routePath: toUrlPath("/api/:baz*") },
121
- { routePath: toUrlPath("/api/:foo") },
122
- ])
123
- ).toEqual(["/api/*"]);
124
- });
125
-
126
- it("should handle middleware mounting", () => {
127
- expect(
128
- convertRoutesToGlobPatterns([
129
- {
130
- routePath: toUrlPath("/middleware"),
131
- middleware: ["./some-middleware.ts"],
132
- },
133
- ])
134
- ).toEqual(["/middleware/*"]);
135
-
136
- expect(
137
- convertRoutesToGlobPatterns([
138
- {
139
- routePath: toUrlPath("/middleware"),
140
- middleware: "./some-middleware.ts",
141
- },
142
- ])
143
- ).toEqual(["/middleware/*"]);
144
-
145
- expect(
146
- convertRoutesToGlobPatterns([
147
- {
148
- routePath: toUrlPath("/middleware"),
149
- middleware: [],
150
- },
151
- ])
152
- ).toEqual(["/middleware"]);
153
- });
154
- });
155
-
156
- describe("convertRoutesToRoutesJSONSpec()", () => {
157
- it("should convert and consolidate routes into JSONSpec", () => {
158
- expect(
159
- convertRoutesToRoutesJSONSpec([
160
- { routePath: toUrlPath("/api/foo/bar") },
161
- { routePath: toUrlPath("/foo/bar") },
162
- { routePath: toUrlPath("/foo/:bar") },
163
- { routePath: toUrlPath("/api/foo/bar") },
164
- {
165
- routePath: toUrlPath("/middleware"),
166
- middleware: "./some-middleware.ts",
167
- },
168
- ])
169
- ).toEqual({
170
- version: ROUTES_SPEC_VERSION,
171
- description: ROUTES_SPEC_DESCRIPTION,
172
- include: ["/middleware/*", "/foo/*", "/api/foo/bar"],
173
- exclude: [],
174
- });
175
- });
176
-
177
- it("should truncate all routes if over limit", () => {
178
- const routes = [];
179
- for (let i = 0; i < MAX_FUNCTIONS_ROUTES_RULES + 1; i++) {
180
- routes.push({ routePath: toUrlPath(`/api/foo-${i}`) });
181
- }
182
- expect(convertRoutesToRoutesJSONSpec(routes)).toEqual({
183
- version: ROUTES_SPEC_VERSION,
184
- description: ROUTES_SPEC_DESCRIPTION,
185
- include: ["/*"],
186
- exclude: [],
187
- });
188
- });
189
-
190
- it("should allow max routes", () => {
191
- const routes = [];
192
- for (let i = 0; i < MAX_FUNCTIONS_ROUTES_RULES; i++) {
193
- routes.push({ routePath: toUrlPath(`/api/foo-${i}`) });
194
- }
195
- expect(convertRoutesToRoutesJSONSpec(routes).include.length).toEqual(
196
- MAX_FUNCTIONS_ROUTES_RULES
197
- );
198
- });
199
- });
200
-
201
- describe("optimizeRoutesJSONSpec()", () => {
202
- it("should convert and consolidate routes into JSONSpec", () => {
203
- expect(
204
- optimizeRoutesJSONSpec({
205
- version: ROUTES_SPEC_VERSION,
206
- description: ROUTES_SPEC_DESCRIPTION,
207
- exclude: [],
208
- include: [
209
- "/api/foo/bar",
210
- "/foo/bar",
211
- "/foo/*",
212
- "/api/foo/bar",
213
- "/middleware/*",
214
- ],
215
- })
216
- ).toEqual({
217
- version: ROUTES_SPEC_VERSION,
218
- description: ROUTES_SPEC_DESCRIPTION,
219
- include: ["/middleware/*", "/foo/*", "/api/foo/bar"],
220
- exclude: [],
221
- });
222
- });
223
-
224
- it("should truncate all routes if over limit", () => {
225
- const include: string[] = [];
226
- for (let i = 0; i < MAX_FUNCTIONS_ROUTES_RULES + 1; i++) {
227
- include.push(`/api/foo-${i}`);
228
- }
229
- expect(
230
- optimizeRoutesJSONSpec({
231
- version: ROUTES_SPEC_VERSION,
232
- description: ROUTES_SPEC_DESCRIPTION,
233
- include,
234
- exclude: [],
235
- })
236
- ).toEqual({
237
- version: ROUTES_SPEC_VERSION,
238
- description: ROUTES_SPEC_DESCRIPTION,
239
- include: ["/*"],
240
- exclude: [],
241
- });
242
- });
243
-
244
- it("should allow max routes", () => {
245
- const include: string[] = [];
246
- for (let i = 0; i < MAX_FUNCTIONS_ROUTES_RULES; i++) {
247
- include.push(`/api/foo-${i}`);
248
- }
249
- expect(
250
- optimizeRoutesJSONSpec({
251
- version: ROUTES_SPEC_VERSION,
252
- description: ROUTES_SPEC_DESCRIPTION,
253
- include,
254
- exclude: [],
255
- }).include.length
256
- ).toEqual(MAX_FUNCTIONS_ROUTES_RULES);
257
- });
258
- });
259
-
260
- describe("compareRoutes()", () => {
261
- describe("compareRoutes()", () => {
262
- test("routes / last", () => {
263
- expect(compareRoutes("/", "/foo")).toBeGreaterThanOrEqual(1);
264
- expect(compareRoutes("/", "/*")).toBeGreaterThanOrEqual(1);
265
- });
266
-
267
- test("routes with fewer segments come after those with more segments", () => {
268
- expect(compareRoutes("/foo", "/foo/bar")).toBeGreaterThanOrEqual(1);
269
- expect(compareRoutes("/foo", "/foo/bar/cat")).toBeGreaterThanOrEqual(1);
270
- });
271
-
272
- test("routes with wildcard segments come after those without", () => {
273
- expect(compareRoutes("/*", "/foo")).toBe(1);
274
- expect(compareRoutes("/foo/*", "/foo/bar")).toBe(1);
275
- });
276
-
277
- test("routes with dynamic segments occurring earlier come after those with dynamic segments in later positions", () => {
278
- expect(compareRoutes("/foo/*/bar", "/foo/bar/*")).toBe(1);
279
- });
280
- });
281
- });
282
- });