wrangler 2.20.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/bin/wrangler.js +9 -75
- package/package.json +5 -13
- package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
- package/templates/checked-fetch.js +1 -1
- package/templates/first-party-worker-module-facade.ts +2 -2
- package/templates/middleware/common.ts +9 -4
- package/templates/middleware/loader-sw.ts +2 -7
- package/templates/new-worker-scheduled.ts +1 -1
- package/templates/new-worker.ts +1 -1
- package/templates/pages-dev-util.ts +4 -1
- package/templates/pages-shim.ts +0 -3
- package/templates/tsconfig.tsbuildinfo +1 -1
- package/wrangler-dist/cli.d.ts +149 -75
- package/wrangler-dist/cli.js +60062 -64338
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/miniflare-dist/index.mjs +0 -6442
- package/src/__tests__/access.test.ts +0 -25
- package/src/__tests__/api-dev.test.ts +0 -238
- package/src/__tests__/api-devregistry.test.ts +0 -121
- package/src/__tests__/api.test.ts +0 -102
- package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
- package/src/__tests__/config-cache.test.ts +0 -42
- package/src/__tests__/configuration.test.ts +0 -4517
- package/src/__tests__/constellation.test.ts +0 -371
- package/src/__tests__/d1/d1.test.ts +0 -82
- package/src/__tests__/d1/execute.test.ts +0 -66
- package/src/__tests__/d1/migrate.test.ts +0 -257
- package/src/__tests__/d1/splitter.test.ts +0 -255
- package/src/__tests__/delete.test.ts +0 -272
- package/src/__tests__/deployments.test.ts +0 -369
- package/src/__tests__/dev.test.tsx +0 -1617
- package/src/__tests__/generate.test.ts +0 -237
- package/src/__tests__/get-host-from-url.test.ts +0 -16
- package/src/__tests__/guess-worker-format.test.ts +0 -120
- package/src/__tests__/helpers/clipboardy-mock.js +0 -4
- package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
- package/src/__tests__/helpers/end-event-loop.ts +0 -6
- package/src/__tests__/helpers/mock-account-id.ts +0 -48
- package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
- package/src/__tests__/helpers/mock-bin.ts +0 -36
- package/src/__tests__/helpers/mock-console.ts +0 -112
- package/src/__tests__/helpers/mock-dialogs.ts +0 -139
- package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
- package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
- package/src/__tests__/helpers/mock-http-server.ts +0 -46
- package/src/__tests__/helpers/mock-istty.ts +0 -74
- package/src/__tests__/helpers/mock-known-routes.ts +0 -12
- package/src/__tests__/helpers/mock-kv.ts +0 -46
- package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
- package/src/__tests__/helpers/mock-process.ts +0 -34
- package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
- package/src/__tests__/helpers/mock-stdin.ts +0 -108
- package/src/__tests__/helpers/mock-web-socket.ts +0 -29
- package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
- package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
- package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
- package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
- package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
- package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
- package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
- package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
- package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
- package/src/__tests__/helpers/msw/index.ts +0 -52
- package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
- package/src/__tests__/helpers/run-in-tmp.ts +0 -38
- package/src/__tests__/helpers/run-wrangler.ts +0 -16
- package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
- package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
- package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
- package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
- package/src/__tests__/helpers/write-worker-source.ts +0 -31
- package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
- package/src/__tests__/https-options.test.ts +0 -163
- package/src/__tests__/index.test.ts +0 -282
- package/src/__tests__/init.test.ts +0 -3196
- package/src/__tests__/jest.setup.ts +0 -179
- package/src/__tests__/kv.test.ts +0 -1799
- package/src/__tests__/logger.test.ts +0 -207
- package/src/__tests__/logout.test.ts +0 -47
- package/src/__tests__/metrics.test.ts +0 -493
- package/src/__tests__/middleware.scheduled.test.ts +0 -145
- package/src/__tests__/middleware.test.ts +0 -816
- package/src/__tests__/mtls-certificates.test.ts +0 -589
- package/src/__tests__/package-manager.test.ts +0 -353
- package/src/__tests__/pages/deployment-list.test.ts +0 -80
- package/src/__tests__/pages/functions-build.test.ts +0 -528
- package/src/__tests__/pages/pages.test.ts +0 -81
- package/src/__tests__/pages/project-create.test.ts +0 -63
- package/src/__tests__/pages/project-list.test.ts +0 -110
- package/src/__tests__/pages/project-upload.test.ts +0 -500
- package/src/__tests__/pages/publish.test.ts +0 -2864
- package/src/__tests__/pages-deployment-tail.test.ts +0 -957
- package/src/__tests__/parse.test.ts +0 -436
- package/src/__tests__/paths.test.ts +0 -39
- package/src/__tests__/publish.test.ts +0 -8849
- package/src/__tests__/pubsub.test.ts +0 -496
- package/src/__tests__/queues.test.ts +0 -532
- package/src/__tests__/r2.test.ts +0 -374
- package/src/__tests__/route.test.ts +0 -45
- package/src/__tests__/secret.test.ts +0 -693
- package/src/__tests__/tail.test.ts +0 -989
- package/src/__tests__/test-old-node-version.js +0 -31
- package/src/__tests__/traverse-module-graph.test.ts +0 -220
- package/src/__tests__/tsconfig-sanity.ts +0 -12
- package/src/__tests__/tsconfig.json +0 -8
- package/src/__tests__/tsconfig.tsbuildinfo +0 -1
- package/src/__tests__/type-generation.test.ts +0 -234
- package/src/__tests__/user.test.ts +0 -118
- package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
- package/src/__tests__/validate-dev-props.test.ts +0 -56
- package/src/__tests__/version.test.ts +0 -35
- package/src/__tests__/whoami.test.tsx +0 -172
- package/src/__tests__/worker-namespace.test.ts +0 -340
- package/src/abort.d.ts +0 -3
- package/src/api/dev.ts +0 -321
- package/src/api/index.ts +0 -11
- package/src/api/mtls-certificate.ts +0 -148
- package/src/api/pages/create-worker-bundle-contents.ts +0 -77
- package/src/api/pages/index.ts +0 -5
- package/src/api/pages/publish.tsx +0 -371
- package/src/bundle-reporter.ts +0 -68
- package/src/bundle.ts +0 -929
- package/src/cfetch/index.ts +0 -158
- package/src/cfetch/internal.ts +0 -258
- package/src/cli.ts +0 -28
- package/src/config/README.md +0 -107
- package/src/config/config.ts +0 -282
- package/src/config/diagnostics.ts +0 -80
- package/src/config/environment.ts +0 -625
- package/src/config/index.ts +0 -403
- package/src/config/validation-helpers.ts +0 -597
- package/src/config/validation.ts +0 -2369
- package/src/config-cache.ts +0 -85
- package/src/constellation/createProject.tsx +0 -51
- package/src/constellation/deleteProject.ts +0 -51
- package/src/constellation/deleteProjectModel.ts +0 -68
- package/src/constellation/index.ts +0 -75
- package/src/constellation/listCatalog.tsx +0 -35
- package/src/constellation/listModel.tsx +0 -41
- package/src/constellation/listProject.tsx +0 -28
- package/src/constellation/listRuntime.tsx +0 -28
- package/src/constellation/options.ts +0 -17
- package/src/constellation/types.ts +0 -17
- package/src/constellation/uploadModel.tsx +0 -64
- package/src/constellation/utils.ts +0 -90
- package/src/create-worker-preview.ts +0 -293
- package/src/create-worker-upload-form.ts +0 -363
- package/src/d1/backups.tsx +0 -219
- package/src/d1/constants.ts +0 -2
- package/src/d1/create.tsx +0 -70
- package/src/d1/delete.ts +0 -53
- package/src/d1/execute.tsx +0 -357
- package/src/d1/formatTimeAgo.ts +0 -14
- package/src/d1/index.ts +0 -100
- package/src/d1/list.tsx +0 -62
- package/src/d1/migrations/apply.tsx +0 -212
- package/src/d1/migrations/create.tsx +0 -79
- package/src/d1/migrations/helpers.ts +0 -169
- package/src/d1/migrations/index.ts +0 -3
- package/src/d1/migrations/list.tsx +0 -95
- package/src/d1/migrations/options.ts +0 -23
- package/src/d1/options.ts +0 -22
- package/src/d1/splitter.ts +0 -161
- package/src/d1/types.ts +0 -25
- package/src/d1/utils.ts +0 -49
- package/src/delete.ts +0 -100
- package/src/deployments.ts +0 -368
- package/src/deprecated/index.ts +0 -144
- package/src/dev/dev-vars.ts +0 -39
- package/src/dev/dev.tsx +0 -605
- package/src/dev/get-local-persistence-path.ts +0 -31
- package/src/dev/local.tsx +0 -952
- package/src/dev/remote.tsx +0 -635
- package/src/dev/start-server.ts +0 -545
- package/src/dev/use-esbuild.ts +0 -215
- package/src/dev/validate-dev-props.ts +0 -40
- package/src/dev-registry.ts +0 -202
- package/src/dev.tsx +0 -934
- package/src/dialogs.ts +0 -136
- package/src/dispatch-namespace.ts +0 -211
- package/src/docs/helpers.ts +0 -50
- package/src/docs/index.ts +0 -54
- package/src/durable.ts +0 -102
- package/src/entry.ts +0 -344
- package/src/environment-variables/factory.ts +0 -89
- package/src/environment-variables/misc-variables.ts +0 -30
- package/src/errors.ts +0 -11
- package/src/generate/index.ts +0 -298
- package/src/git-client.ts +0 -135
- package/src/global-wrangler-config-path.ts +0 -26
- package/src/https-options.ts +0 -127
- package/src/index.ts +0 -768
- package/src/init.ts +0 -1037
- package/src/inspect.ts +0 -883
- package/src/intl-polyfill.d.ts +0 -139
- package/src/is-ci.ts +0 -14
- package/src/is-interactive.ts +0 -16
- package/src/jest.d.ts +0 -4
- package/src/kv/helpers.ts +0 -433
- package/src/kv/index.ts +0 -594
- package/src/logger.ts +0 -123
- package/src/metrics/index.ts +0 -5
- package/src/metrics/metrics-config.ts +0 -239
- package/src/metrics/metrics-dispatcher.ts +0 -96
- package/src/metrics/metrics-usage-headers.ts +0 -24
- package/src/metrics/send-event.ts +0 -99
- package/src/miniflare-cli/README.md +0 -30
- package/src/miniflare-cli/assets.ts +0 -251
- package/src/miniflare-cli/index.ts +0 -210
- package/src/miniflare-cli/request-context.ts +0 -40
- package/src/miniflare-cli/tsconfig.json +0 -9
- package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
- package/src/miniflare-cli/types.ts +0 -11
- package/src/module-collection.ts +0 -333
- package/src/mtls-certificate/cli.ts +0 -155
- package/src/open-in-browser.ts +0 -17
- package/src/package-manager.ts +0 -219
- package/src/pages/build.ts +0 -423
- package/src/pages/buildFunctions.ts +0 -140
- package/src/pages/constants.ts +0 -18
- package/src/pages/deployment-tails.ts +0 -281
- package/src/pages/deployments.tsx +0 -84
- package/src/pages/dev.ts +0 -734
- package/src/pages/errors.ts +0 -67
- package/src/pages/functions/buildPlugin.ts +0 -114
- package/src/pages/functions/buildWorker.ts +0 -350
- package/src/pages/functions/filepath-routing.test.ts +0 -234
- package/src/pages/functions/filepath-routing.ts +0 -189
- package/src/pages/functions/identifiers.ts +0 -78
- package/src/pages/functions/routes-consolidation.test.ts +0 -250
- package/src/pages/functions/routes-consolidation.ts +0 -73
- package/src/pages/functions/routes-transformation.test.ts +0 -282
- package/src/pages/functions/routes-transformation.ts +0 -115
- package/src/pages/functions/routes-validation.test.ts +0 -403
- package/src/pages/functions/routes-validation.ts +0 -202
- package/src/pages/functions/routes.ts +0 -151
- package/src/pages/functions/tsconfig.json +0 -8
- package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
- package/src/pages/functions.ts +0 -86
- package/src/pages/hash.ts +0 -13
- package/src/pages/index.ts +0 -102
- package/src/pages/projects.tsx +0 -159
- package/src/pages/prompt-select-project.tsx +0 -31
- package/src/pages/publish.tsx +0 -267
- package/src/pages/types.ts +0 -46
- package/src/pages/upload.tsx +0 -469
- package/src/pages/utils.ts +0 -23
- package/src/parse.ts +0 -308
- package/src/paths.ts +0 -71
- package/src/proxy.ts +0 -694
- package/src/publish/index.ts +0 -274
- package/src/publish/publish.ts +0 -1065
- package/src/pubsub/index.ts +0 -286
- package/src/pubsub/pubsub-commands.ts +0 -623
- package/src/queues/cli/commands/consumer/add.ts +0 -71
- package/src/queues/cli/commands/consumer/index.ts +0 -19
- package/src/queues/cli/commands/consumer/remove.ts +0 -31
- package/src/queues/cli/commands/create.ts +0 -25
- package/src/queues/cli/commands/delete.ts +0 -26
- package/src/queues/cli/commands/index.ts +0 -35
- package/src/queues/cli/commands/list.ts +0 -25
- package/src/queues/client.ts +0 -136
- package/src/queues/utils.ts +0 -18
- package/src/r2/constants.ts +0 -4
- package/src/r2/helpers.ts +0 -132
- package/src/r2/index.ts +0 -289
- package/src/routes.ts +0 -140
- package/src/secret/index.ts +0 -377
- package/src/selfsigned.d.ts +0 -29
- package/src/sites.ts +0 -484
- package/src/tail/createTail.ts +0 -415
- package/src/tail/filters.ts +0 -277
- package/src/tail/index.ts +0 -211
- package/src/tail/printing.ts +0 -132
- package/src/traverse-module-graph.ts +0 -54
- package/src/tsconfig-sanity.ts +0 -16
- package/src/type-generation.ts +0 -181
- package/src/update-check.ts +0 -19
- package/src/user/access.ts +0 -68
- package/src/user/auth-variables.ts +0 -113
- package/src/user/choose-account.tsx +0 -39
- package/src/user/generate-auth-url.ts +0 -33
- package/src/user/generate-random-state.ts +0 -16
- package/src/user/index.ts +0 -2
- package/src/user/user.ts +0 -1234
- package/src/utils/collectKeyValues.ts +0 -14
- package/src/utils/render.ts +0 -93
- package/src/whoami.ts +0 -135
- package/src/worker.ts +0 -279
- package/src/yargs-types.ts +0 -37
- package/src/zones.ts +0 -191
|
@@ -1,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
|
-
});
|