Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Poll inner connection until EOF after gzip decoder is complete #2484

Merged

Conversation

Andrey36652
Copy link
Contributor

Fix for #2381

@Andrey36652
Copy link
Contributor Author

Should I expand the fix on all other decompression methods?

@seanmonstar
Copy link
Owner

If they all have the same characteristic, namely that they know they ended before reading EOF, then they probably all suffer from the same thing.

@Andrey36652
Copy link
Contributor Author

Should I add tests for all other decompression methods?

@seanmonstar
Copy link
Owner

You can. If so, I'd do with a for loop, or some pattern to reduce the duplicate parts.

@Andrey36652
Copy link
Contributor Author

Can reqwest deal with such cases (multiple compression algorithms)?

// Multiple, in the order in which they were applied
Content-Encoding: deflate, gzip

https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Encoding

@seanmonstar
Copy link
Owner

I don't think it can, but not a single person has filed saying they needed it. So I suspect that is more of a theoretical part of the spec, and not something that servers ever actually do.

So I wouldn't bother supporting it for now, it'd make things complicated and we don't seem to need it.

@Andrey36652
Copy link
Contributor Author

I don't know why it fails style check, cargo fmt -- --check locallly shows no errors.

@seanmonstar
Copy link
Owner

Some code doesn't get formatted automatically because of conditional #[cfg] flags leaving some files out. You can run cargo fmt -- $(find . -name '*.rs' -print) to get all of them.

Copy link
Owner

@seanmonstar seanmonstar left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Excellent, excellent, excellent work. Thanks so much for cleaning this up! <3

@seanmonstar seanmonstar merged commit d36c0f5 into seanmonstar:master Dec 3, 2024
36 checks passed
kodiakhq bot pushed a commit to pdylanross/fatigue that referenced this pull request Dec 27, 2024
Bumps reqwest from 0.12.9 to 0.12.10.

Release notes
Sourced from reqwest's releases.

v0.12.10
What's Changed

Add ClientBuilder::connector_layer() to allow customizing the connector stack. by @​jlizen in seanmonstar/reqwest#2496
Add ClientBuilder::http2_max_header_list_size() option by @​DSharifi in seanmonstar/reqwest#2465
Fix decompression of chunked bodies so the connections can be reused more often by @​Andrey36652 in seanmonstar/reqwest#2484
Fix propagating body size hint (content-length) information when wrapping bodies by @​seanmonstar in seanmonstar/reqwest#2503

New Contributors

@​DSharifi made their first contribution in seanmonstar/reqwest#2465
@​gretchenfrage made their first contribution in seanmonstar/reqwest#2464
@​hsivonen made their first contribution in seanmonstar/reqwest#2470
@​ovnicraft made their first contribution in seanmonstar/reqwest#2469
@​Nuhvi made their first contribution in seanmonstar/reqwest#2473
@​caojen made their first contribution in seanmonstar/reqwest#2488
@​Andrey36652 made their first contribution in seanmonstar/reqwest#2484
@​jlizen made their first contribution in seanmonstar/reqwest#2499

Thanks

@​seanmonstar
@​nyurik

Full Changelog: seanmonstar/reqwest@v0.12.9...v0.12.10



Changelog
Sourced from reqwest's changelog.

v0.12.10

Add ClientBuilder::connector_layer() to allow customizing the connector stack.
Add ClientBuilder::http2_max_header_list_size() option.
Fix propagating body size hint (content-length) information when wrapping bodies.
Fix decompression of chunked bodies so the connections can be reused more often.




Commits

409cff3 v0.12.10
ea48da7 docs: fix a few spelling issues (#2478)
3ce98b5 fix: propagate Body::size_hint when wrapping bodies (#2503)
44ca5ee remove Clone from connect::Unnameable for now (#2502)
2a7c1b6 feat: allow pluggable tower layers in connector service stack (#2496)
8a2174f chore: in README, update requirements to mention rustls along with vendored o...
d36c0f5 perf: fix decoder streams to make pooled connections reusable (#2484)
4367d30 ci: pin hashbrown for msrv job (#2488)
e2d4b14 docs: document using non-zero ports in resolved addresses (#2473)
6e21413 chore: fix a number of newer clippy lints (#2469)
Additional commits viewable in compare view




Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


Dependabot commands and options

You can trigger Dependabot actions by commenting on this PR:

@dependabot rebase will rebase this PR
@dependabot recreate will recreate this PR, overwriting any edits that have been made to it
@dependabot merge will merge this PR after your CI passes on it
@dependabot squash and merge will squash and merge this PR after your CI passes on it
@dependabot cancel merge will cancel a previously requested merge and block automerging
@dependabot reopen will reopen this PR if it is closed
@dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
@dependabot show <dependency name> ignore conditions will show all of the ignore conditions of the specified dependency
@dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
@dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
@dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
AaronDewes pushed a commit to AaronDewes/reqwest-no-rustls that referenced this pull request Jan 4, 2025
…nstar#2484)

When a response body is being decompressed, and the length wasn't known, but was using chunked transfer-encoding, the remaining `0\r\n\r\n` was not consumed. That would leave the connection in a state that could be not be reused, and so the pool had to discard it.

This fix makes sure the remaining end chunk is consumed, improving the amount of pooled connections that can be reused.

Closes seanmonstar#2381
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants