-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
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 Poetry instructions #11152
Fix Poetry instructions #11152
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This solution seems to work fine. I'm happy to merge it.
I did a test at https://beta.readthedocs.org/projects/test-builds/builds/23561155/ and the documentation built properly.
This is a tricky one. Changing all Python builds on Read the Docs behavior is risky and it will have unexpected behaviors for sure. We have experience doing such kind of changes and it usually breaks a good amount of projects. So, I can't guarantee we will be performing this change, unfortunately. However, I'm happy we have a solution for Poetry that's compatible with its latest version 💯
I don't have a strong preference here, but I think it's not needed. |
Co-authored-by: Manuel Kaufmann <[email protected]>
Yeah, I understand, that's exactly why I asked. So does this means the PR would be better by removing the comment entirely ? If we don't really expect this to change, better not state for all eternity that it will ? |
I don't have a particular preference here. @ericholscher, what do you think? |
I don't think adding this env var should conflict with how we are executing commands, it feels likely safe for us to add. However, it would also be fairly easy for us to test. I don't think it will affect things much otherwise, as we are explicit about the command path while executing. |
I'm pretty sure we don't want to set a new ENV var that has impact on downstream tools if we can avoid it at all. It will definitely break stuff. However, I'm 💯 on adding this approach to our docs. |
I think it's worth a test as we can't say with any certainty that this will break something otherwise. I hold out hope it's safe, as Having a fix in our docs is a fine first step though. |
I'm not reading any clear answer as to whether the comment: # VIRTUAL_ENV needs to be set manually for now.
# See https://github.com/readthedocs/readthedocs.org/pull/11152/ should appear in the doc or not. It looks like everyone agrees the rest is fine, my question is mainly on this comment :) |
OK, I will merge this PR as-is since it solves the actual problem and unblock users wanting to use poetry for their dependencies. We can continue discussing the rest in another issue. @ewjoachim thanks for your contribution and help on this 👍🏼 |
This commit introduces the changes from readthedocs/readthedocs.org#11152.
This follows a change in RTD's user guide found at https://docs.readthedocs.io/en/stable/build-customization.html#install-dependencies-with-poetry, which they changed in readthedocs/readthedocs.org#11152 following a breaking change introduced by Poetry 1.8.
This follows a change in RTD's user guide found at https://docs.readthedocs.io/en/stable/build-customization.html#install-dependencies-with-poetry, which they changed in readthedocs/readthedocs.org#11152 following a breaking change introduced by Poetry 1.8.
This follows a change in RTD's user guide found at https://docs.readthedocs.io/en/stable/build-customization.html#install-dependencies-with-poetry, which they changed in readthedocs/readthedocs.org#11152 following a breaking change introduced by Poetry 1.8.
* RTD doesn't support uv at the same level as pip, but there are ways to still use it along with most of the infrastructure. Adopt the strategy provided in ReadTheDocs's 'Build process customization' section https://docs.readthedocs.io/en/latest/build-customization.html#install-dependencies-with-uv , from readthedocs/readthedocs.org#11152, but continue to monitor alternative faster methods such as those described in readthedocs/readthedocs.org#11289 .
RTD uses a mixture of poetry and pip to install packages in the build environment. In the past it was recommended to disable poetry from creating a fresh virtual environment. Instead, the expectation was that poetry would be able to detect it's current virtual environment and install the packages in the right place. This was recently updated to allow poetry to better allow dependcy management by poetry [1]. Remove this configuration and explicitly point Poetry to the virtual environment. [1] readthedocs/readthedocs.org#11152 Change-Id: I58e49ba6f6d122e70bbcf1dbb10220881a09faf3 Signed-off-by: Harrison Mutai <[email protected]>
RTD uses a mixture of poetry and pip to install packages in the build environment. In the past it was recommended to disable poetry from creating a fresh virtual environment. Instead, the expectation was that poetry would be able to detect it's current virtual environment and install the packages in the right place. This was recently updated to allow poetry to better allow dependcy management by poetry [1]. Remove this configuration and explicitly point Poetry to the virtual environment. [1] readthedocs/readthedocs.org#11152 Signed-off-by: J-Alves <[email protected]> Signed-off-by: Harrison Mutai <[email protected]> Change-Id: I64e75410a0f14ff5edd91ea526d85ad108cb1a13
Fixes #11150
I believe we will make the (Python) world a better place by setting
VIRTUAL_ENV
, but this change should be evaluated before breaking other people's build for moving too hastily, so I'm making a first fix.2 questions:
VIRTUAL_ENV
fix will happen. Is it right?📚 Documentation previews 📚
docs
): https://docs--11152.org.readthedocs.build/en/11152/dev
): https://dev--11152.org.readthedocs.build/en/11152/