-
Notifications
You must be signed in to change notification settings - Fork 106
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
CPU autodetect failing due to failing pip install reframe-hpc==4.3.3
#3023
Comments
Which is the default system Python version? Maybe upgrading pip in the generated script is not a bad idea. |
Just as a thought, since I think it might be hard to come up with something that works everywhere, all the time: you could make an optional configuration item that overwrites what is done to bootstrap the ReFrame installation in the CPU autodetection.
The definition of that config item would be that users should list whatever commands are needed to make ReFrame available on the target node of the remote CPU autodetection. On some systems, that could even be as simple as loading a module (e.g. for us, a bootstrap is not needed: we have a ReFrame module specifically installed for the architecture of the target batch node). On others, it could be installing a virtualenv, with or without upgrading pip. Note that you would still have a sensible default (your current, potentially with the addition of upgrading pip), so in that sense it doesn't break anything for current users. |
Maybe both fixing this to work out-of-the-box + allowing to modify the detection makes sense. There is also #2292 that asks this. Allowing modifications of the reframe self-installation script makes sense. I will try to reproduce this on a Python 3.6 system as I believe it's Python 3.6-specific problem. |
Actually, we do upgrade pip in Line 114 in b1c8970
|
I couldn't reproduce it on a Centos 7 container with Python 3.6.8 and pip 9.0.3. But we could add the pip upgrade as an enhancement. |
Eventually, I reproduced it on an actual Centos system :-) |
After your message I realized for us it only happens on the |
I agree with @casparvl here that there should be a way to instruct ReFrame how set the environment environment for running the CPU autodetect. With the current approach, we're sort of stuck to get started with the EESSI test suite with the current version of ReFrame, since the CPU autodetect is broken (cfr. http://www.eessi.io/docs/test-suite/installation-configuration/#cpu-auto-detection). |
@boegel I think that's #2979 and maybe #2292. This particular one is fixed on Actually, the "pip path" for remote auto-detection can also be improved like we did for the |
This way, we won't rely on any system-specific pip installation. All we need from the system is to be able to create a virtual environment without pip: |
If this is due to this issue, it will be solved in 4.4.1, which we will release today or tomorrow. |
I'm (again) having some issues with CPU autodetect. Full output:
I'm having this only on some nodes (ARM) in our virtual cluster, probably because the
libxml2
andlibxslt
are not in that image. However, as was pointed out to me by someone else: "you would not need libxml2 in the image if pip was up to date as lxml wheel is available for aarch64 in PyPI"Interactively trying
indeed failed with the same error, while
completes just fine.
Now, I'm not sure what the right approach is here. One option would be if you injected a
pip install --upgrade pip
in the CPU detection script. On the other hand, I can imagine you might be reluctant to do it: it might cause other issues (though I would expect fewer). Another option is to somehow offer more customizeability to the user of what the CPU autodetection script should look like. I've addressed that topic before, although note that the suggested option of some form ofprerun_cmds
there wouldn't have helped in this case.Any suggestions? Sure, you could argue "simply install those system packages", but I simply don't always have that kind of power or possibility everywhere.
The text was updated successfully, but these errors were encountered: