Commit 3d76fe9
committed
Improve cyclic thenable detection in ReactFlightReplyServer (facebook#35369)
## Summary
This PR improves cyclic thenable detection in
`ReactFlightReplyServer.js`. Fixes facebook#35368.
The previous fix only detected direct self-references (`inspectedValue
=== chunk`) and relied on the `cycleProtection` counter to eventually
bail out of longer cycles. This change keeps the existing
MAX_THENABLE_CYCLE_DEPTH ($1000$) `cycleProtection` cap as a hard
guardrail and adds a visited set so that we can detect self-cycles and
multi-node cycles as soon as any `ReactPromise` is revisited and while
still bounding the amount of work we do for deep acyclic chains via
`cycleProtection`.
## How did you test this change?
- Ran the existing test suite for the server renderer:
```bash
yarn test react-server
yarn test --prod react-server
yarn flow dom-node
yarn linc
```
---------
Co-authored-by: Hendrik Liebau <mail@hendrik-liebau.de>
DiffTrain build for [b731fe2](facebook@b731fe2)1 parent 6ef883c commit 3d76fe9
File tree
21 files changed
+94
-158
lines changed- compiled-rn
- facebook-fbsource/xplat/js
- RKJSModules/vendor/react
- react-dom/cjs
- react-test-renderer/cjs
- react/cjs
- react-native-github/Libraries/Renderer
- implementations
- tools/eslint-plugin-react-hooks
21 files changed
+94
-158
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | | - | |
| 1 | + | |
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
410 | 410 | | |
411 | 411 | | |
412 | 412 | | |
413 | | - | |
| 413 | + | |
414 | 414 | | |
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
209 | 209 | | |
210 | 210 | | |
211 | 211 | | |
212 | | - | |
| 212 | + | |
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
209 | 209 | | |
210 | 210 | | |
211 | 211 | | |
212 | | - | |
| 212 | + | |
Lines changed: 17 additions & 49 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
21417 | 21417 | | |
21418 | 21418 | | |
21419 | 21419 | | |
21420 | | - | |
21421 | | - | |
21422 | | - | |
21423 | | - | |
21424 | | - | |
21425 | | - | |
21426 | | - | |
21427 | | - | |
21428 | | - | |
21429 | | - | |
21430 | | - | |
21431 | | - | |
21432 | | - | |
21433 | | - | |
21434 | | - | |
21435 | | - | |
21436 | 21420 | | |
21437 | 21421 | | |
21438 | 21422 | | |
21439 | 21423 | | |
21440 | 21424 | | |
21441 | 21425 | | |
21442 | | - | |
21443 | | - | |
21444 | | - | |
21445 | | - | |
21446 | | - | |
21447 | | - | |
21448 | | - | |
21449 | | - | |
21450 | | - | |
21451 | | - | |
21452 | | - | |
21453 | | - | |
21454 | | - | |
| 21426 | + | |
| 21427 | + | |
| 21428 | + | |
| 21429 | + | |
21455 | 21430 | | |
21456 | 21431 | | |
21457 | 21432 | | |
| |||
22758 | 22733 | | |
22759 | 22734 | | |
22760 | 22735 | | |
22761 | | - | |
22762 | | - | |
22763 | | - | |
22764 | | - | |
22765 | | - | |
22766 | | - | |
22767 | | - | |
22768 | | - | |
22769 | | - | |
22770 | | - | |
| 22736 | + | |
| 22737 | + | |
| 22738 | + | |
| 22739 | + | |
| 22740 | + | |
| 22741 | + | |
22771 | 22742 | | |
22772 | 22743 | | |
22773 | 22744 | | |
| |||
22817 | 22788 | | |
22818 | 22789 | | |
22819 | 22790 | | |
22820 | | - | |
22821 | | - | |
22822 | | - | |
22823 | | - | |
| 22791 | + | |
22824 | 22792 | | |
22825 | 22793 | | |
22826 | 22794 | | |
| |||
30276 | 30244 | | |
30277 | 30245 | | |
30278 | 30246 | | |
30279 | | - | |
| 30247 | + | |
30280 | 30248 | | |
30281 | 30249 | | |
30282 | 30250 | | |
30283 | | - | |
| 30251 | + | |
30284 | 30252 | | |
30285 | 30253 | | |
30286 | 30254 | | |
| |||
30317 | 30285 | | |
30318 | 30286 | | |
30319 | 30287 | | |
30320 | | - | |
| 30288 | + | |
30321 | 30289 | | |
30322 | 30290 | | |
30323 | | - | |
| 30291 | + | |
30324 | 30292 | | |
30325 | 30293 | | |
30326 | 30294 | | |
| |||
30470 | 30438 | | |
30471 | 30439 | | |
30472 | 30440 | | |
30473 | | - | |
| 30441 | + | |
30474 | 30442 | | |
Lines changed: 6 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
17707 | 17707 | | |
17708 | 17708 | | |
17709 | 17709 | | |
17710 | | - | |
| 17710 | + | |
17711 | 17711 | | |
17712 | 17712 | | |
17713 | 17713 | | |
17714 | 17714 | | |
17715 | 17715 | | |
17716 | 17716 | | |
17717 | | - | |
| 17717 | + | |
17718 | 17718 | | |
17719 | 17719 | | |
17720 | 17720 | | |
| |||
17736 | 17736 | | |
17737 | 17737 | | |
17738 | 17738 | | |
17739 | | - | |
| 17739 | + | |
17740 | 17740 | | |
17741 | 17741 | | |
17742 | | - | |
| 17742 | + | |
17743 | 17743 | | |
17744 | 17744 | | |
17745 | 17745 | | |
| |||
17846 | 17846 | | |
17847 | 17847 | | |
17848 | 17848 | | |
17849 | | - | |
| 17849 | + | |
Lines changed: 6 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
19833 | 19833 | | |
19834 | 19834 | | |
19835 | 19835 | | |
19836 | | - | |
| 19836 | + | |
19837 | 19837 | | |
19838 | 19838 | | |
19839 | 19839 | | |
19840 | 19840 | | |
19841 | 19841 | | |
19842 | 19842 | | |
19843 | | - | |
| 19843 | + | |
19844 | 19844 | | |
19845 | 19845 | | |
19846 | 19846 | | |
| |||
19862 | 19862 | | |
19863 | 19863 | | |
19864 | 19864 | | |
19865 | | - | |
| 19865 | + | |
19866 | 19866 | | |
19867 | 19867 | | |
19868 | | - | |
| 19868 | + | |
19869 | 19869 | | |
19870 | 19870 | | |
19871 | 19871 | | |
| |||
19988 | 19988 | | |
19989 | 19989 | | |
19990 | 19990 | | |
19991 | | - | |
| 19991 | + | |
Lines changed: 17 additions & 49 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| |||
21425 | 21425 | | |
21426 | 21426 | | |
21427 | 21427 | | |
21428 | | - | |
21429 | | - | |
21430 | | - | |
21431 | | - | |
21432 | | - | |
21433 | | - | |
21434 | | - | |
21435 | | - | |
21436 | | - | |
21437 | | - | |
21438 | | - | |
21439 | | - | |
21440 | | - | |
21441 | | - | |
21442 | | - | |
21443 | | - | |
21444 | 21428 | | |
21445 | 21429 | | |
21446 | 21430 | | |
21447 | 21431 | | |
21448 | 21432 | | |
21449 | 21433 | | |
21450 | | - | |
21451 | | - | |
21452 | | - | |
21453 | | - | |
21454 | | - | |
21455 | | - | |
21456 | | - | |
21457 | | - | |
21458 | | - | |
21459 | | - | |
21460 | | - | |
21461 | | - | |
21462 | | - | |
| 21434 | + | |
| 21435 | + | |
| 21436 | + | |
| 21437 | + | |
21463 | 21438 | | |
21464 | 21439 | | |
21465 | 21440 | | |
| |||
22766 | 22741 | | |
22767 | 22742 | | |
22768 | 22743 | | |
22769 | | - | |
22770 | | - | |
22771 | | - | |
22772 | | - | |
22773 | | - | |
22774 | | - | |
22775 | | - | |
22776 | | - | |
22777 | | - | |
22778 | | - | |
| 22744 | + | |
| 22745 | + | |
| 22746 | + | |
| 22747 | + | |
| 22748 | + | |
| 22749 | + | |
22779 | 22750 | | |
22780 | 22751 | | |
22781 | 22752 | | |
| |||
22825 | 22796 | | |
22826 | 22797 | | |
22827 | 22798 | | |
22828 | | - | |
22829 | | - | |
22830 | | - | |
22831 | | - | |
| 22799 | + | |
22832 | 22800 | | |
22833 | 22801 | | |
22834 | 22802 | | |
| |||
30338 | 30306 | | |
30339 | 30307 | | |
30340 | 30308 | | |
30341 | | - | |
| 30309 | + | |
30342 | 30310 | | |
30343 | 30311 | | |
30344 | 30312 | | |
30345 | | - | |
| 30313 | + | |
30346 | 30314 | | |
30347 | 30315 | | |
30348 | 30316 | | |
| |||
30379 | 30347 | | |
30380 | 30348 | | |
30381 | 30349 | | |
30382 | | - | |
| 30350 | + | |
30383 | 30351 | | |
30384 | 30352 | | |
30385 | | - | |
| 30353 | + | |
30386 | 30354 | | |
30387 | 30355 | | |
30388 | 30356 | | |
| |||
30848 | 30816 | | |
30849 | 30817 | | |
30850 | 30818 | | |
30851 | | - | |
| 30819 | + | |
30852 | 30820 | | |
30853 | 30821 | | |
30854 | 30822 | | |
| |||
0 commit comments