Commit 80c123a
authored
fix: respect reconnect=false and clamp server-supplied retry: 0 (#135)
## Summary
Stacked on top of #134. Addresses three pre-existing reconnect-control
gaps surfaced during the multi-agent review of that PR.
1. **`retry: 0` collapses backoff to zero.** A server emitting `retry:
0` set `BackoffRetry::base_delay` to `Duration::ZERO`, after which every
reconnect path (`client.rs:474, 525, 547, 612` and the new parse-error
path) computed `next_delay() == 0` and reconnected immediately — a tight
loop. Clamps `change_base_delay` to a 1 ms floor.
2. **EOF arm ignored `reconnect_opts.reconnect`.** The body-exhausted
branch unconditionally scheduled `WaitingToReconnect` even when
reconnect was disabled. Now honors the flag and transitions to
`StreamClosed`, matching every other error path.
3. **Parse-error arm with `reconnect=false` left the parser poisoned.**
No state transition happened, so the next poll drained the broken body
to EOF — where (2) above papered over the bug. Now transitions to
`StreamClosed` so the documented \"do not use the stream after error\"
contract holds.
## Context
Stacked PR — base is the `rl/sdk-2345/parser-error-reconnect-state`
branch from #134, **not** main. Will retarget once #134 lands.
Tracked in
[SDK-2347](https://launchdarkly.atlassian.net/browse/SDK-2347).
Predecessor:
[SDK-2345](https://launchdarkly.atlassian.net/browse/SDK-2345) / #134.
Surfaced from the multi-agent review of #134 (findings 1, 2, and the
corresponding suggested follow-ups 4 and 5). All three were pre-existing
— #134 only made the parse-error path more visible.
## Test plan
- [x] `test_change_base_delay_clamps_to_minimum` (`retry.rs`) — pins the
1 ms floor against `change_base_delay(Duration::ZERO)` and a sub-floor
value.
- [x] `parser_error_closes_stream_when_reconnect_disabled` (`client.rs`)
— asserts the stream emits one `InvalidLine` then `None` when reconnect
is off.
- [x] `eof_closes_stream_when_reconnect_disabled` (`client.rs`) —
asserts the stream emits the event, `Eof`, then `None` when reconnect is
off.
- [x] Existing `parser_error_schedules_reconnect_immediately` from #134
still passes.
- [x] `cargo test` — 63 lib tests + 1 doc test pass.
- [x] `cargo fmt --check` clean.
[SDK-2347]:
https://launchdarkly.atlassian.net/browse/SDK-2347?atlOrigin=eyJpIjoiNWRkNTljNzYxNjVmNDY3MDlhMDU5Y2ZhYzA5YTRkZjUiLCJwIjoiZ2l0aHViLWNvbS1KU1cifQ1 parent 2ac2998 commit 80c123a
2 files changed
Lines changed: 173 additions & 12 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
506 | 506 | | |
507 | 507 | | |
508 | 508 | | |
509 | | - | |
510 | | - | |
| 509 | + | |
| 510 | + | |
| 511 | + | |
| 512 | + | |
511 | 513 | | |
512 | 514 | | |
513 | 515 | | |
| |||
517 | 519 | | |
518 | 520 | | |
519 | 521 | | |
| 522 | + | |
| 523 | + | |
520 | 524 | | |
521 | 525 | | |
522 | 526 | | |
| |||
547 | 551 | | |
548 | 552 | | |
549 | 553 | | |
550 | | - | |
551 | | - | |
552 | | - | |
553 | | - | |
554 | | - | |
555 | | - | |
556 | | - | |
557 | | - | |
558 | | - | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
| 565 | + | |
| 566 | + | |
559 | 567 | | |
560 | 568 | | |
561 | 569 | | |
| |||
799 | 807 | | |
800 | 808 | | |
801 | 809 | | |
| 810 | + | |
| 811 | + | |
| 812 | + | |
| 813 | + | |
| 814 | + | |
| 815 | + | |
| 816 | + | |
| 817 | + | |
| 818 | + | |
| 819 | + | |
| 820 | + | |
| 821 | + | |
| 822 | + | |
| 823 | + | |
| 824 | + | |
| 825 | + | |
| 826 | + | |
| 827 | + | |
| 828 | + | |
| 829 | + | |
| 830 | + | |
| 831 | + | |
| 832 | + | |
| 833 | + | |
| 834 | + | |
| 835 | + | |
| 836 | + | |
| 837 | + | |
| 838 | + | |
| 839 | + | |
| 840 | + | |
| 841 | + | |
| 842 | + | |
| 843 | + | |
| 844 | + | |
| 845 | + | |
| 846 | + | |
| 847 | + | |
| 848 | + | |
| 849 | + | |
| 850 | + | |
| 851 | + | |
| 852 | + | |
| 853 | + | |
| 854 | + | |
| 855 | + | |
| 856 | + | |
| 857 | + | |
| 858 | + | |
| 859 | + | |
| 860 | + | |
| 861 | + | |
| 862 | + | |
| 863 | + | |
| 864 | + | |
| 865 | + | |
| 866 | + | |
| 867 | + | |
| 868 | + | |
| 869 | + | |
| 870 | + | |
| 871 | + | |
| 872 | + | |
| 873 | + | |
| 874 | + | |
| 875 | + | |
| 876 | + | |
| 877 | + | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
| 881 | + | |
| 882 | + | |
| 883 | + | |
| 884 | + | |
| 885 | + | |
| 886 | + | |
| 887 | + | |
| 888 | + | |
| 889 | + | |
| 890 | + | |
| 891 | + | |
| 892 | + | |
| 893 | + | |
| 894 | + | |
| 895 | + | |
| 896 | + | |
| 897 | + | |
| 898 | + | |
| 899 | + | |
| 900 | + | |
| 901 | + | |
| 902 | + | |
| 903 | + | |
| 904 | + | |
| 905 | + | |
| 906 | + | |
| 907 | + | |
| 908 | + | |
| 909 | + | |
| 910 | + | |
| 911 | + | |
| 912 | + | |
| 913 | + | |
| 914 | + | |
| 915 | + | |
| 916 | + | |
| 917 | + | |
| 918 | + | |
| 919 | + | |
| 920 | + | |
| 921 | + | |
| 922 | + | |
| 923 | + | |
| 924 | + | |
| 925 | + | |
| 926 | + | |
| 927 | + | |
| 928 | + | |
| 929 | + | |
| 930 | + | |
| 931 | + | |
| 932 | + | |
| 933 | + | |
| 934 | + | |
| 935 | + | |
| 936 | + | |
| 937 | + | |
| 938 | + | |
| 939 | + | |
802 | 940 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
18 | 23 | | |
19 | 24 | | |
20 | 25 | | |
| |||
66 | 71 | | |
67 | 72 | | |
68 | 73 | | |
69 | | - | |
| 74 | + | |
70 | 75 | | |
71 | 76 | | |
72 | 77 | | |
| |||
111 | 116 | | |
112 | 117 | | |
113 | 118 | | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
114 | 137 | | |
115 | 138 | | |
116 | 139 | | |
| |||
0 commit comments