-
Notifications
You must be signed in to change notification settings - Fork 37
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
Hermeticity bug: Package setup can find host libraries (leading to import failures) #31
Comments
It is assumed that the system has |
That isn't the case. You can try that out on the docker image by running The underlying issue is that the runtime environment is hermetic but the setup environment is leaky - as far as I can tell, vpip is given access to system libraries, so any setup process that searches for available resources in the path that it has access to is prone to creating dependencies that aren't be available at runtime. |
Yes, that's a well-known Bazel sandboxing hole: bazelbuild/bazel#7313 |
This being the case, I'm wondering two things:
|
We use a We avoid the hermeticity problem by building everything with a minimal sandbox root fs. bazelbuild/bazel#6994 (comment) |
The upstream issue has been resolved, can this be closed? |
When trying to install numpy, I found that it failed to import because it depended on libraries that it could not access - CBLAS and LAPACK - resulting in
undefined symbol
errors (sometimescblas_dot
, sometimessaxpy_
, sometimes_gfortran_concat_string
, depending on what you have installed, and what you have tried to provide via Bazel dependencies). The numpy wheel comes bundled with the necessary libraries but bypasses their installation if it finds implementations on the host system - allowing users to utilise alternative implementations suited to their needs.A minimal reproduction in a docker image showed no problem - numpy worked fine - so the same code worked or borked depending on the host - indicative of a hermeticity issue. To verify, I installed openblas to the docker image before the numpy package is installed, and this gives it
undefined symbol
errors when trying to import numpy.I've attached a MWE. Inside is a simple project that simply imports numpy, prints hello world, and outputs a simple mean to demonstrate numpy doing something. This is done within a docker environment to isolate the build from the host machine.
There are two dockerfiles:
working.Dockerfile
andbroken.Dockerfile
. The only difference between the two is thatbroken.Dockerfile
installslibopenblas-dev
before runningbazel build
.To reproduce, download dbx_build_tools_bug.tar.gz and:
Running the working docker image outputs:
And running the 'broken' docker image outputs:
The text was updated successfully, but these errors were encountered: