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

Fix collecting deps for all extras in multiple input packages #1981

Merged
merged 5 commits into from
Feb 21, 2024

Conversation

dragly
Copy link
Contributor

@dragly dragly commented Sep 4, 2023

Previously, an error would always be thrown when running compile with --all-extras on multiple source files containing extras. The reason was that the first iteration over the first source file would fill the extras variable, which in the second iteration would trigger an error since both all_extras and extras would be set.

This change moves the check outside the loop and early in the script to avoid unnecessary processing before throwing the error.

Further, only moving the check outside the loop would currently leave us with only the extras from the last src_file in the iteration over src_files.

This change also ensures all extras are in fact collected from all packages when --all-extras is passed as an argument.

This fixes #1980

Contributor checklist
  • Included tests for the changes. (Happy to add a test, but not sure which type is preferred).
  • PR title is short, clear, and ready to be included in the user-facing changelog.
Maintainer checklist
  • Verified one of these labels is present: backwards incompatible, feature, enhancement, deprecation, bug, dependency, docs or skip-changelog as they determine changelog listing.
  • Assign the PR to an existing or new milestone for the target version (following Semantic Versioning).

Copy link
Member

@atugushev atugushev left a comment

Choose a reason for hiding this comment

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

Thanks for the fix! Could you please add a test that confirms the bug?

@dragly
Copy link
Contributor Author

dragly commented Sep 26, 2023

Thanks for the fix! Could you please add a test that confirms the bug?

Yes 👍

How do you prefer the test to be implemented? I already have an example setup that fails when invoking from the command line. Should I add a test that runs from the command line or rather implement an internal test?

@atugushev
Copy link
Member

@dragly I'd prefer a test in test_cli_compile.py. Use test_cli_compile_strip_extras as a reference.

@dragly
Copy link
Contributor Author

dragly commented Oct 4, 2023

I have added a test in a fixup commit now. The succeeds now and will fail if you revert the first commit.

By the way, I struggled a bit while developing this test because pytest consumed all output written to stdout and stderr. The usual pytest -s and pytest -rx flags did not work. How do you usually debug any errors when working on the tests?

@dragly
Copy link
Contributor Author

dragly commented Oct 4, 2023

I also see that there is a merge conflict now with tests/test_cli_compile.py. I can resolve that. Do you prefer that I do it in a merge commit or that I rebase this branch on main right away?

@chrysle
Copy link
Contributor

chrysle commented Oct 10, 2023

By the way, I struggled a bit while developing this test because pytest consumed all output written to stdout and stderr. The usual pytest -s and pytest -rx flags did not work. How do you usually debug any errors when working on the tests?

pytest --verbose doesn't work?

I also see that there is a merge conflict now with tests/test_cli_compile.py. I can resolve that. Do you prefer that I do it in a merge commit or that I rebase this branch on main right away?

I guess that's unimportant.

tests/test_cli_compile.py Outdated Show resolved Hide resolved
tests/test_cli_compile.py Outdated Show resolved Hide resolved
@chrysle chrysle mentioned this pull request Oct 11, 2023
@chrysle chrysle added the bug Something is not working label Oct 12, 2023
@dragly dragly force-pushed the fix-all-extras branch 2 times, most recently from 4ae48d6 to 5f43741 Compare November 10, 2023 14:45
@dragly
Copy link
Contributor Author

dragly commented Nov 10, 2023

By the way, I struggled a bit while developing this test because pytest consumed all output written to stdout and stderr. The usual pytest -s and pytest -rx flags did not work. How do you usually debug any errors when working on the tests?

pytest --verbose doesn't work?

Weirdly enough I see the output now. Not sure why it did not work earlier 🤔

@chrysle chrysle added the awaiting response Awaiting response from a contributor label Jan 2, 2024
@chrysle chrysle added extras Handling optional dependencies and removed awaiting response Awaiting response from a contributor labels Jan 22, 2024
@chrysle chrysle enabled auto-merge January 22, 2024 11:47
tests/test_cli_compile.py Outdated Show resolved Hide resolved
@dragly dragly changed the title Move check for --extra and --all-extras outside loop Move check for extras outside loop and handle multiple packages with extras Jan 29, 2024
auto-merge was automatically disabled January 29, 2024 10:58

Head branch was pushed to by a user without write access

@webknjaz webknjaz changed the title Move check for extras outside loop and handle multiple packages with extras 🐛 Fix collecting deps for all extras in multiple input packages Jan 29, 2024
@webknjaz
Copy link
Member

@dragly I took a stab at updating the title — it should refer to one high-level effect, not the implementation details. The details/motivation are to be in the description if needed. Otherwise, it just looks like a non-atomic collection of loosely related changes being enumerated.

Do you think this is accurate enough?

@dragly
Copy link
Contributor Author

dragly commented Jan 30, 2024

@dragly I took a stab at updating the title — it should refer to one high-level effect, not the implementation details. The details/motivation are to be in the description if needed. Otherwise, it just looks like a non-atomic collection of loosely related changes being enumerated.

Do you think this is accurate enough?

Yes, that looks perfect! Thanks for updating it :) I agree with the rationale too 👍

@webknjaz
Copy link
Member

@dragly thanks! I noticed, there's a coverage drop in this PR. Could you check it out and compensate for the lost lines? Especially, pay attention to the indirect changes tab in Codecov: https://app.codecov.io/gh/jazzband/pip-tools/pull/1981/indirect-changes.

dragly and others added 4 commits January 30, 2024 15:57
Previously, an error would always be thrown when running `compile` with
`--all-extras` on multiple source files containing extras. The reason was
that the first iteration over the first source file would fill the
`extras` variable, which in the second iteration would trigger an error
since both `all_extras` and `extras` would be set.

This change moves the check outside the loop and early in the script to
avoid unnecessary processing before throwing the error.
@chrysle
Copy link
Contributor

chrysle commented Jan 30, 2024

Can't explain the test failure. It's about a missing PKG-INFO file in the build directory, which is obviously present:

  running install
  running install_egg_info
  running egg_info
  writing fake_with_deps.egg-info/PKG-INFO
  writing dependency_links to fake_with_deps.egg-info/dependency_links.txt
  writing requirements to fake_with_deps.egg-info/requires.txt
  writing top-level names to fake_with_deps.egg-info/top_level.txt
  reading manifest file 'fake_with_deps.egg-info/SOURCES.txt'
  writing manifest file 'fake_with_deps.egg-info/SOURCES.txt'
  Copying fake_with_deps.egg-info to build/bdist.linux-x86_64/wheel/fake_with_deps-0.1-py3.8.egg-info
  running install_scripts
  error: [Errno 2] No such file or directory: 'build/bdist.linux-x86_64/wheel/fake_with_deps-0.1-py3.8.egg-info/PKG-INFO'
  error: subprocess-exited-with-error

@webknjaz
Copy link
Member

Can't explain the test failure. It's about a missing PKG-INFO file in the build directory, which is obviously present:

Could be an incomplete build deps pin (as in setuptools updated). I suppose using what #1681 addresses in our own tests could make things more stable. Dogfooding FTW!

@dragly
Copy link
Contributor Author

dragly commented Jan 31, 2024

@dragly thanks! I noticed, there's a coverage drop in this PR. Could you check it out and compensate for the lost lines? Especially, pay attention to the indirect changes tab in Codecov: https://app.codecov.io/gh/jazzband/pip-tools/pull/1981/indirect-changes.

I will try, but have to admit I am not too familiar with reading Codecov reports.

I looked at the page you linked and the documentation for indirect changes. It seems like it is not hitting a few conditional imports based on Python version.

Is it possible that Python or pip versions change between this PR and the previous run that codecov compares to?

Do you have other pointers on how you typically dig into a codecov change like this?

@chrysle chrysle enabled auto-merge February 21, 2024 17:53
@chrysle chrysle added this pull request to the merge queue Feb 21, 2024
Merged via the queue into jazzband:main with commit a8beb7a Feb 21, 2024
36 checks passed
@chrysle
Copy link
Contributor

chrysle commented Feb 21, 2024

Thank you!

@webknjaz
Copy link
Member

Is it possible that Python or pip versions change between this PR and the previous run that codecov compares to?

Do you have other pointers on how you typically dig into a codecov change like this?

Sorry, this slipped my attention. If it's conditional imports, depending on the Python version, maybe some of the CI jobs failed to upload coverage (the codecov service can be flaky like that).

@atugushev atugushev changed the title 🐛 Fix collecting deps for all extras in multiple input packages Fix collecting deps for all extras in multiple input packages Mar 5, 2024
@atugushev atugushev added this to the 7.4.1 milestone Mar 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something is not working extras Handling optional dependencies
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Running pip-tools compile on multiple sources fails with --all-extras
4 participants