Commit 996adcf
committed
Add comparison budget to OverlappingFieldsCanBeMerged
Inline fragments bypass the named-fragment PairSet cache because they
have no name — they are flattened directly into the parent field map.
This allows O(n^2 × m^2) pairwise comparisons, consuming minutes of
CPU for a sub-megabyte query.
Add a configurable comparison counter in findConflict() that caps
worst-case CPU. Defaults to 100,000 comparisons, well above any
realistic query.
🤖 Generated with Claude Code1 parent ff116ea commit 996adcf
2 files changed
Lines changed: 39 additions & 0 deletions
File tree
- src/Validator/Rules
- tests/Validator
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
| 36 | + | |
| 37 | + | |
36 | 38 | | |
37 | 39 | | |
38 | 40 | | |
| |||
49 | 51 | | |
50 | 52 | | |
51 | 53 | | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
52 | 63 | | |
53 | 64 | | |
54 | 65 | | |
55 | 66 | | |
| 67 | + | |
56 | 68 | | |
57 | 69 | | |
58 | 70 | | |
| |||
399 | 411 | | |
400 | 412 | | |
401 | 413 | | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
402 | 422 | | |
403 | 423 | | |
404 | 424 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
13 | 14 | | |
14 | 15 | | |
15 | 16 | | |
| |||
1274 | 1275 | | |
1275 | 1276 | | |
1276 | 1277 | | |
| 1278 | + | |
| 1279 | + | |
| 1280 | + | |
| 1281 | + | |
| 1282 | + | |
| 1283 | + | |
| 1284 | + | |
| 1285 | + | |
| 1286 | + | |
| 1287 | + | |
| 1288 | + | |
| 1289 | + | |
| 1290 | + | |
| 1291 | + | |
| 1292 | + | |
| 1293 | + | |
| 1294 | + | |
| 1295 | + | |
1277 | 1296 | | |
1278 | 1297 | | |
1279 | 1298 | | |
| |||
0 commit comments