-
Notifications
You must be signed in to change notification settings - Fork 30
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
Add --platform option to facilitate installing wheels for platforms other than the host system #123
base: main
Are you sure you want to change the base?
Add --platform option to facilitate installing wheels for platforms other than the host system #123
Conversation
I think I am open to this feature. Even if parts of the implementation feel a bit hacky, the good thing is that it is well encapsulated and will not influence users who do not use the feature. Maybe, we should call the feature "experimental" in its description and the readme?
What will happen for sdist only releases with extensions? Will installation fail? WIll the extension be built for the wrong platform and installed without an error so that you only will notice that your environment is broken when using it?
Sounds good.
At first, I thought introducing a public method does not make sense and it would be better to have a subclass of
I do not know of any such library either. Some explicit unit tests for the |
Thanks for the response. I will investigate the questions and report back. I'll also include some |
# Conflicts: # tests/bundlers/test_venv_bundler.py
@radoering, this is ready for your (re)review! I believe I've addressed all of your prior feedback comments. Please let me know if you need more or want to see something different. Regarding your questions:
I tried to elaborate on this in the README. See what you think. But to answer your questions directly:
Yes, if the host system doesn't have the prerequisites to build it. Otherwise, no, it will build it like "normal" and that output is what is installed.
Yes, assuming the build succeeds and the host system is the wrong platform. The --platform option here has no effect. |
The motivation for this PR is to add a new flag
--platform
that achieves the same effect as the pip option of the same name which is to facilitate the installation of wheels that are compatible with the platform specified.The primary use case is in CI/CD operations to produce a deployable asset, such as a ZIP file for AWS Lambda and other such cloud providers. It is common for the runtimes of these target environments to be different enough from the CI/CD's runner host such that the binary wheels selected using the host's criteria are not compatible with the target system's.
Notes:
env._supported_tags
assignment that you will see in this code is not ideal, and I welcome any input for a better way. Since the Poetry code does not provide a public method for mutating this value, I resorted to mutating this pseudo-private field.packaging
module, but I did have to reinvent the wheel for some things due to that module being hard-coded to call out to the host system to query certain values, which we are specifically trying to avoid here. In my research, I noted that the pip code effectively does the same thing. Should such a reusable module exist for producing the Tags combinations that are compatible with the specified platform, it would be much better to use that. I was not successful in finding such a library.