aiohttp
aiohttp copied to clipboard
Reduce code indent in ResponseHandler.data_received
What do these changes do?
Code cleanup only, no functional change
There were some else after returns that could be converted to guards to reduce code indent.
While looking at the full WebSockets path for https://github.com/aio-libs/aiohttp/discussions/8258 I noticed this could be improved a bit
Are there changes in behavior for the user?
no
Is it a substantial burden for the maintainers to support this?
no
Codecov Report
All modified and coverable lines are covered by tests :white_check_mark:
Project coverage is 98.75%. Comparing base (
2e369db) to head (b0338a3). Report is 373 commits behind head on master.
:white_check_mark: All tests successful. No failed tests found.
Additional details and impacted files
@@ Coverage Diff @@
## master #8699 +/- ##
==========================================
+ Coverage 98.73% 98.75% +0.01%
==========================================
Files 121 121
Lines 36750 36789 +39
Branches 4391 4395 +4
==========================================
+ Hits 36286 36330 +44
+ Misses 314 312 -2
+ Partials 150 147 -3
| Flag | Coverage Δ | |
|---|---|---|
| CI-GHA | 98.64% <100.00%> (+0.01%) |
:arrow_up: |
| OS-Linux | 98.33% <100.00%> (+0.01%) |
:arrow_up: |
| OS-Windows | 96.16% <97.05%> (+0.01%) |
:arrow_up: |
| OS-macOS | 97.43% <100.00%> (+0.02%) |
:arrow_up: |
| Py-3.10.11 | 97.27% <100.00%> (+0.01%) |
:arrow_up: |
| Py-3.10.15 | 97.87% <100.00%> (+0.01%) |
:arrow_up: |
| Py-3.11.10 | 97.86% <100.00%> (+0.01%) |
:arrow_up: |
| Py-3.11.9 | 97.33% <100.00%> (+0.02%) |
:arrow_up: |
| Py-3.12.7 | 98.39% <100.00%> (+<0.01%) |
:arrow_up: |
| Py-3.13.0 | 98.38% <100.00%> (+0.02%) |
:arrow_up: |
| Py-3.9.13 | 97.19% <100.00%> (+0.01%) |
:arrow_up: |
| Py-3.9.20 | 97.73% <100.00%> (+0.01%) |
:arrow_up: |
| Py-pypy7.3.16 | 97.35% <100.00%> (+0.02%) |
:arrow_up: |
| VM-macos | 97.43% <100.00%> (+0.02%) |
:arrow_up: |
| VM-ubuntu | 98.33% <100.00%> (+0.01%) |
:arrow_up: |
| VM-windows | 96.16% <97.05%> (+0.01%) |
:arrow_up: |
Flags with carried forward coverage won't be shown. Click here to find out more.
:umbrella: View full report in Codecov by Sentry.
:loudspeaker: Have feedback on the report? Share it here.
Looks like we are missing coverage for tail
I feel like that relates to https://github.com/aio-libs/aiohttp/pull/8597#issuecomment-2267101718 or one of my other parser changes. I'm not really sure if it's still possible to reach that code at all...
I'll dig through the code paths this weekend if flights cooperate.
Looks like websocket will never have a tail unless there is an exception
I spent a few hours digging at it, and I can't find a case or make a case where tail exists and upgraded is False
Then I reckon remove it, but also skip the 3.10 backport as a precaution.
Still having trouble getting comfortable with removing that code, need to spend a few more hours tracing
I wonder if it is possible and we don't have coverage for it.
We didn't have test coverage for split WebSocket payloads until #9649
CodSpeed Performance Report
Merging #8699 will not alter performance
Comparing else_after_return (b0338a3) with master (2e369db)
Summary
✅ 44 untouched benchmarks
Then I reckon remove it, but also skip the 3.10 backport as a precaution.
After discovering feed_data always return b"" if its not upgraded, I'm confident its truely unreachable so I removed it
https://github.com/aio-libs/aiohttp/blob/2e369db2d9abcbef41031592b4f044adf5f89f59/aiohttp/_http_parser.pyx#L574
Backport to 3.11: 💔 cherry-picking failed — conflicts found
❌ Failed to cleanly apply 11f0e7f0a9be7ab27036a49ff13e318ed03b769a on top of patchback/backports/3.11/11f0e7f0a9be7ab27036a49ff13e318ed03b769a/pr-8699
Backporting merged PR #8699 into master
- Ensure you have a local repo clone of your fork. Unless you cloned it
from the upstream, this would be your
originremote. - Make sure you have an upstream repo added as a remote too. In these
instructions you'll refer to it by the name
upstream. If you don't have it, here's how you can add it:$ git remote add upstream https://github.com/aio-libs/aiohttp.git - Ensure you have the latest copy of upstream and prepare a branch
that will hold the backported code:
$ git fetch upstream $ git checkout -b patchback/backports/3.11/11f0e7f0a9be7ab27036a49ff13e318ed03b769a/pr-8699 upstream/3.11 - Now, cherry-pick PR #8699 contents into that branch:
If it'll yell at you with something like$ git cherry-pick -x 11f0e7f0a9be7ab27036a49ff13e318ed03b769afatal: Commit 11f0e7f0a9be7ab27036a49ff13e318ed03b769a is a merge but no -m option was given., add-m 1as follows instead:$ git cherry-pick -m1 -x 11f0e7f0a9be7ab27036a49ff13e318ed03b769a - At this point, you'll probably encounter some merge conflicts. You must resolve them in to preserve the patch from PR #8699 as close to the original as possible.
- Push this branch to your fork on GitHub:
$ git push origin patchback/backports/3.11/11f0e7f0a9be7ab27036a49ff13e318ed03b769a/pr-8699 - Create a PR, ensure that the CI is green. If it's not — update it so that the tests and any other checks pass. This is it! Now relax and wait for the maintainers to process your pull request when they have some cycles to do reviews. Don't worry — they'll tell you if any improvements are necessary when the time comes!
🤖 @patchback I'm built with octomachinery and my source is open — https://github.com/sanitizers/patchback-github-app.
Backport to 3.12: 💔 cherry-picking failed — conflicts found
❌ Failed to cleanly apply 11f0e7f0a9be7ab27036a49ff13e318ed03b769a on top of patchback/backports/3.12/11f0e7f0a9be7ab27036a49ff13e318ed03b769a/pr-8699
Backporting merged PR #8699 into master
- Ensure you have a local repo clone of your fork. Unless you cloned it
from the upstream, this would be your
originremote. - Make sure you have an upstream repo added as a remote too. In these
instructions you'll refer to it by the name
upstream. If you don't have it, here's how you can add it:$ git remote add upstream https://github.com/aio-libs/aiohttp.git - Ensure you have the latest copy of upstream and prepare a branch
that will hold the backported code:
$ git fetch upstream $ git checkout -b patchback/backports/3.12/11f0e7f0a9be7ab27036a49ff13e318ed03b769a/pr-8699 upstream/3.12 - Now, cherry-pick PR #8699 contents into that branch:
If it'll yell at you with something like$ git cherry-pick -x 11f0e7f0a9be7ab27036a49ff13e318ed03b769afatal: Commit 11f0e7f0a9be7ab27036a49ff13e318ed03b769a is a merge but no -m option was given., add-m 1as follows instead:$ git cherry-pick -m1 -x 11f0e7f0a9be7ab27036a49ff13e318ed03b769a - At this point, you'll probably encounter some merge conflicts. You must resolve them in to preserve the patch from PR #8699 as close to the original as possible.
- Push this branch to your fork on GitHub:
$ git push origin patchback/backports/3.12/11f0e7f0a9be7ab27036a49ff13e318ed03b769a/pr-8699 - Create a PR, ensure that the CI is green. If it's not — update it so that the tests and any other checks pass. This is it! Now relax and wait for the maintainers to process your pull request when they have some cycles to do reviews. Don't worry — they'll tell you if any improvements are necessary when the time comes!
🤖 @patchback I'm built with octomachinery and my source is open — https://github.com/sanitizers/patchback-github-app.