-
Notifications
You must be signed in to change notification settings - Fork 320
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
Configure Pyolite to pre-install packages #811
Conversation
I have just added the commit 'Make matplotlib optional but included by default'. Currently, there is hard-coded pre-installation of matplotlib. When we introduce an option to configure what packages will be pre-installed, it makes sense to let matplotlib be configurable. The reason to include this change in this PR is backward compatibility: this change is backwards compatible now, but will not be backwards compatible later. In other words, we should decide now will we instruct those who use Update I have to revert the commit 'Make matplotlib optional but included by default' since pyolite package depends on matplotlib and pillow (pyolite patches matplotlib and PIL modules) |
Thanks @vasiljevic for opening this PR. Although there are good reasons for not encouraging code to be run silently (as discussed in jupyterlite/pyodide-kernel#60), the new config option looks simple enough and opt-in. This would allow site deployers the ability to configure it if they want to. But it could indeed make it more difficult to troubleshoot in case something goes wrong during the kernel initialization. If things move forward, it would be interesting to check how to unify this with what xeus-python offers: https://xeus-python-kernel.readthedocs.io/en/latest/configuration.html#pre-installed-packages @bollwyvl what is your opinion on this? Maybe something that could be more easily iterated on once Pyolite is moved to its own repo (#386). |
I'll say it again, If stuff breaks at this level, it leaves the kernel in an unrecoverable statte, and you can never get out. I don't want this repo to have to field support for those kinds of failures. We can leave more hooks open to allow these things with additional extensions, but it should not be in core. |
Thank you @jtpio, I have overlooked that pyolite package depends on matplotlib and pillow since since pyolite need to patch matplotlib and PIL modules. I have reverted the commit 'Make matplotlib optional but included by default' and tests have passed now. BTW, how can I access images and videos from UI test report on GitHub? I this particular case I could not reproduce the error since it is race condition related and tests had not failed in my local environment. |
This feature is why I like xeus-python. But xeus-python do package installation in build time by using empack as opposed to Pyodide. It would be nice if there was an easy way to create a custom Pyodide distribution and integrate it into pyolite build, just like it works for xeus-python. Before Pyodide offers an easy build of custom distributions, we can achieve similar behavior to |
I fully understand your concerns, but I just have not found better way to run package pre-installation. The major constraint is that pre-installation must happen before anything is executed in kernel. During the Pyolite kernel initialization a pending execution may occur and stay awaiting at the beginning of the PyoliteRemoteKernel.execute() method. The last statement in the Pyolite kernel initialization is We can put such configurable staff just before |
With my deployer hat on, this is the absolute one single feature that means I must use XPython now for end users to have a decent experience, even if that means I've to spend a bunch of time adding packages to |
Maybe a good compromise would indeed be to leave some hooks. Something that could be done after #854 |
Our site's build pulls some tricks to pre-install wheels - in short, at build time we boot up a pyodide interpreter with node, install the packages we need with piplite, and then call
I'm interested in working on this - are hooks for a third-party "pre-installer addon" still the way you all envision supporting this feature? |
Thanks all for the discussion. Support for @vasiljevic if you would like to continue exploring and discussing this in https://github.com/jupyterlite/pyodide-kernel, please feel free to open an issue or comment in jupyterlite/pyodide-kernel#40. Thanks! |
References
This is proposed solution for jupyterlite/pyodide-kernel#60
Code changes
The central code change is in the
PyoliteRemoteKernel.initKernel()
method. Those lines are added:The idea is to install configurable packages in the same way as some other packages are already pre-installed (in the same method above the added lines).
New option
pipliteRequiredPackages
may be configured in jupyter-lite.json like:All other changes implement propagation of the new option from the runtime configuration to the
options
parameter of theinitKernel()
method.Documentation is also added in
docs/howto/python/packages.md
.User-facing changes
A user who build JupyterLite website may configure packages to be pre-installed. Then a who access the JupyterLite website does not need to do
piplite.install
for those packages and may just import them.Backwards-incompatible changes
No backwards-incompatible changes