-
-
Notifications
You must be signed in to change notification settings - Fork 292
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
Select PEX runtime interpreter robustly. #1770
Conversation
Previously two proxies for interpreter applicability were used: 1. The shebang selected interpreter or the explicit interpreter used to invoke the PEX. 2. Any embedded interpreter constraints. This could lead to selecting an interpreter that was not actually able to resolve all required distributions from within the PEX, which is the only real criteria, and a failure to boot. Fix the runtime interpreter resolution process to test an interpreter can resolve the PEX before using it or re-execing to it. In the use case, the resolve test performed is cached work and leads to no extra overhead. In the re-exec case the resolve test can cost O(100ms), but at the benefit of ensuring either the selected interpreter will definitely work or no interpreters on the search path can work. Fixes pex-tool#1020
target=LocalInterpreter.create(interpreter), | ||
) | ||
try: | ||
pex_environment.resolve() |
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.
FYI: This resolve test right here was what indirectly caused the need for #1768 and killing pkg_resources use. That used a bunch of pkg_resources.Requirement.parse and pkg_resources.Distribution finding and loading code and led to the boot-time vendor meta_path importer clash with Pex said same.
target = target or targets.current() | ||
return cls(pex=pex, pex_info=pex_info, target=target) | ||
key = (pex_file, pex_hash, target) | ||
mounted = cls._CACHE.get(key) |
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 new mount
caching combines with the pre-existing instance-level resolve()
caching to avoid resolving twice in the happy path of the interpreter that tries to run a PEX 1st being a compatible one.
This change probably means shebang could be defaulted to |
Which use case? I'm not following. |
Yooze, not yoos. Languages are dumb. In the case where the tested interpreter is the current interpreter and no re-exec is needed, there is no introduced overhead. The In the case where the current interpreter is not used and we instead re-exec using the foreign tested interpreter, the test will be run a second time. |
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.
Amazing! I remember you talking about wanting to do this at lunch in Tempe 3 years ago but how much refactoring would be necessary.
--
What's the error message if you have only one interpreter in the IC range, but no valid dists for that interpreter?
The same as it's been for a while when no interpreter meets the criteria:
That's as opposed to before this change where the interpreter nominally met the critera, but failed:
Let me see how bad it it to get:
Be something like:
The full detail of the:
Error above is available for each and every interpreter that fails the resolve test, but that's > 6000 lines of error output to have to read through in this example. |
I'll follow-up here with the error message change since it's semi-significant. It won't go in the release notes but will go in the release. |
Hrm, not awesome:
|
The error message fix above is in: #1772 |
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.
Late to the party, but looks great!
Previously two proxies for interpreter applicability were used:
to invoke the PEX.
This could lead to selecting an interpreter that was not actually able
to resolve all required distributions from within the PEX, which is the
only real criteria, and a failure to boot.
Fix the runtime interpreter resolution process to test an interpreter
can resolve the PEX before using it or re-execing to it.
In the use case, the resolve test performed is cached work and leads to
no extra overhead. In the re-exec case the resolve test can cost
O(100ms), but at the benefit of ensuring either the selected interpreter
will definitely work or no interpreters on the search path can work.
Fixes #1020