Skip to content
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

Allow setting variables when using system packages #795

Merged
merged 6 commits into from
Oct 3, 2023

Conversation

TimoWilken
Copy link
Contributor

This would allow us to put setup code (e.g. finding the right python executable, etc) in one place in python.sh.

@TimoWilken TimoWilken requested a review from ktf June 12, 2023 15:50
@TimoWilken TimoWilken force-pushed the system-pkg-overrides branch from a970a8e to 1f036ac Compare June 12, 2023 15:53
@ktf
Copy link
Member

ktf commented Jun 13, 2023

Is this what we discussed yesterday afternoon?

@TimoWilken
Copy link
Contributor Author

Yes, it is @ktf!

@ktf
Copy link
Member

ktf commented Jun 13, 2023

Could you add a testcase for this, so that e.g. it always pick up a different version than the one specified?

@TimoWilken
Copy link
Contributor Author

Will do!

@ktf
Copy link
Member

ktf commented Jun 14, 2023

I was thinking again about this, and I am back to the idea that having a single prefer_system_check which prints out a string which can be used to retrieve the customisations is better. With the current approach you are deemed to start one docker instance / shell per check, every time we run, which is expensive enough to be annoying / slowing down builds.

Moreover, having a single command will remain compatible with older versions of aliBuild (which will simply ignore the additional environment).

So my suggestion goes back to:

prefer_system: <architecture matching>
prefer_system_check: | something which tests for the presence and optionally prints out "alibuild_system_override: <my override version>"
overrides:
  - name: <my override version>
    version: <my override version>
    env:
         ...
  - name: <another override>

@TimoWilken
Copy link
Contributor Author

@ktf: I've prototyped this in the latest commit.

alibuild_helpers/utilities.py Outdated Show resolved Hide resolved
@ktf
Copy link
Member

ktf commented Jun 15, 2023

@TimoWilken I experimented a bit with this in alisw/alidist#5040, but there is a couple of things which probably we should change:

At the moment we rely on SOMETHING_REVISION to decide wether or not something was built using alibuild, however this results in it being set also for the new system packages. Either we drop such variable, or we must allow overriding the recipe as well, e.g. to create a dummy modulefile which integrates with the system detected version of a package. This might actually be a good idea for the cases were we want to detect a specific version of python not available as default yet still installed. E.g. you have both python3.9 and python3.11 and you want to use the former.

Another thing I do not like is that I end up repeating the customization stanzas:

 "Python36+":
    version: "3.6.0"
  "Python311+":
    version: "3.11.0"

maybe the key could be regexp to match on the alibuild_system_override value and it could be used for substitution:

prefer_system_replacement_specs:
  "Python([0-9]*)[.]([0-9]*)":
    version: "system-$1.$2"
    append_path:
       PATH: `brew --prefix python$1.$2`
    recipe: |
       ...create the modulefile...
prefer_system_check: |
  python3 - <<EOF
  import sys; import sqlite3
  if sys.version_info < (3, 5):
    exit(1)
  print("alibuild_system_replace:{}.{}", *sys.version_info)
  EOF
  python3 -m pip --help > /dev/null && printf '#include "pyconfig.h"' | cc -c $(python3-config --includes) -xc -o /dev/null -;
  if [ $? -ne 0 ]; then 
    cat <<EOF
  Python, the Python development packages, and pip must be installed on your system.
  Usually those packages are called python, python-devel (or python-dev) and python-pip.
  EOF
    exit 1;
  fi

This would allow us to put setup code (e.g. finding the right python
executable, etc) in one place in python.sh.
...and parse its output to find a line selecting the replacement spec to use.
System packages can now specify replacement recipes, in which case they aren't
really "system" packages, since we still run the potentially-expensive recipe.
Report this to the user.
This tests the getPackageList function, since only that was changed.
@TimoWilken TimoWilken force-pushed the system-pkg-overrides branch from ed11939 to 0763e33 Compare July 11, 2023 08:52
@TimoWilken TimoWilken marked this pull request as ready for review July 27, 2023 09:29
@ktf ktf merged commit 066bb09 into alisw:master Oct 3, 2023
@ktf
Copy link
Member

ktf commented Oct 3, 2023

Merging this, since it's long due. Let's wait for the end of the HI run before we tag this, though.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants