Commit f89fba1
authored
fix(patches): sort endsWith checks by path length to prevent suffix collisions (#1166)
* fix(patches): sort endsWith checks by path length to prevent suffix collisions
Routes whose paths are suffixes of other routes (e.g. `/test/app` vs `/`)
were resolved to the wrong module because the shorter path matched first
in the generated `.endsWith()` chain.
Sort files by path length descending before generating the chain so that
longer (more specific) paths are always checked first.
Applied to all three `.endsWith()` chains:
- `getRequires()` in dynamic-requires.ts (JS files for requirePage and NodeModuleLoader)
- `htmlFiles` in dynamic-requires.ts (HTML files for requirePage)
- `getEvalManifestRule()` in load-manifest.ts (client-reference-manifest files)
* test: add unit tests for getRequires path sorting1 parent da62708 commit f89fba1
4 files changed
Lines changed: 46 additions & 4 deletions
File tree
- .changeset
- packages/cloudflare/src/cli/build/patches/plugins
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
Lines changed: 24 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
Lines changed: 9 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
30 | 30 | | |
31 | 31 | | |
32 | 32 | | |
33 | | - | |
| 33 | + | |
34 | 34 | | |
35 | | - | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
36 | 40 | | |
37 | 41 | | |
38 | 42 | | |
| |||
111 | 115 | | |
112 | 116 | | |
113 | 117 | | |
114 | | - | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
115 | 121 | | |
116 | 122 | | |
117 | 123 | | |
| |||
Lines changed: 4 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
100 | 100 | | |
101 | 101 | | |
102 | 102 | | |
103 | | - | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
104 | 107 | | |
105 | 108 | | |
106 | 109 | | |
| |||
0 commit comments