(for PR #28262)
2026-01-12 13:21.32: New job: build libbpf.0.1.0, using opam dev
from https://github.com/ocaml/opam-repository.git#refs/pull/28262/head (27b93b8d254212c1249540d74f600850023faef7)
on opensuse-16.0-ocaml-4.14/amd64
To reproduce locally:
cd $(mktemp -d)
git clone --recursive "https://github.com/ocaml/opam-repository.git" && cd "opam-repository" && git fetch origin "refs/pull/28262/head" && git reset --hard 27b93b8d
git fetch origin master
git merge --no-edit 2bf2bf6ea0c8867eede5e26c1c591999dd5a9ee1
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:opensuse-16.0-ocaml-4.14@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd
USER 1000:1000
WORKDIR /home/opam
RUN sudo ln -f /usr/bin/opam-dev /usr/bin/opam
RUN opam init --reinit -ni
RUN opam option solver=builtin-0install && opam config report
ENV OPAMDOWNLOADJOBS="1"
ENV OPAMERRLOGLEN="0"
ENV OPAMPRECISETRACKING="1"
ENV CI="true"
ENV OPAM_REPO_CI="true"
RUN rm -rf opam-repository/
COPY --chown=1000:1000 . opam-repository/
RUN opam repository set-url --strict default opam-repository/
RUN opam update --depexts || true
RUN opam pin add -k version -yn libbpf.0.1.0 0.1.0
RUN opam reinstall libbpf.0.1.0; \
res=$?; \
test "$res" != 31 && exit "$res"; \
export OPAMCLI=2.0; \
build_dir=$(opam var prefix)/.opam-switch/build; \
failed=$(ls "$build_dir"); \
partial_fails=""; \
for pkg in $failed; do \
if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"opensuse-16.0\""; then \
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
fi; \
test "$pkg" != 'libbpf.0.1.0' && partial_fails="$partial_fails $pkg"; \
done; \
test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
exit 1
END-OF-DOCKERFILE
docker build -f ../Dockerfile .
2026-01-12 13:21.32: Using cache hint "ocaml/opam:opensuse-16.0-ocaml-4.14@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd-libbpf.0.1.0-27b93b8d254212c1249540d74f600850023faef7"
2026-01-12 13:21.32: Using OBuilder spec:
((from ocaml/opam:opensuse-16.0-ocaml-4.14@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd)
(user (uid 1000) (gid 1000))
(workdir /home/opam)
(run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
(run (network host)
(shell "opam init --reinit --config .opamrc-sandbox -ni"))
(run (shell "opam option solver=builtin-0install && opam config report"))
(env OPAMDOWNLOADJOBS 1)
(env OPAMERRLOGLEN 0)
(env OPAMPRECISETRACKING 1)
(env CI true)
(env OPAM_REPO_CI true)
(run (shell "rm -rf opam-repository/"))
(copy (src .) (dst opam-repository/))
(run (shell "opam repository set-url --strict default opam-repository/"))
(run (network host)
(shell "opam update --depexts || true"))
(run (shell "opam pin add -k version -yn libbpf.0.1.0 0.1.0"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam reinstall libbpf.0.1.0;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"opensuse-16.0\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'libbpf.0.1.0' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
)
2026-01-12 13:21.32: Connecting to build cluster…
2026-01-12 13:21.32: Waiting for resource in pool OCluster
2026-01-12 13:21.32: Waiting for worker…
2026-01-12 13:21.33: Got resource from pool OCluster
Building on clete
All commits already cached
HEAD is now at 2bf2bf6ea0 Merge pull request #29204 from jserot/opam-publish-rfsm.2.3
Merge made by the 'ort' strategy.
packages/conf-bpftool/conf-bpftool.0.1.0/opam | 4 +++-
packages/libbpf/libbpf.0.1.0/opam | 11 ++++++-----
2 files changed, 9 insertions(+), 6 deletions(-)
(from ocaml/opam:opensuse-16.0-ocaml-4.14@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd)
Unable to find image 'ocaml/opam:opensuse-16.0-ocaml-4.14@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd' locally
docker.io/ocaml/opam@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd: Pulling from ocaml/opam
64cfa2a65095: Already exists
1edcfb1efe19: Pulling fs layer
3ddbff1fae48: Pulling fs layer
6f97b42e121d: Pulling fs layer
35edc2941e66: Pulling fs layer
664494e6aa3b: Pulling fs layer
6e72e374834b: Pulling fs layer
9897d53e41d9: Pulling fs layer
5955f0d634c5: Pulling fs layer
39569ccf3df4: Pulling fs layer
35edc2941e66: Waiting
3835c4318084: Pulling fs layer
664494e6aa3b: Waiting
549825d0ab03: Pulling fs layer
6e7368d99114: Pulling fs layer
6e72e374834b: Waiting
cb6191f3eef1: Pulling fs layer
9897d53e41d9: Waiting
5955f0d634c5: Waiting
39569ccf3df4: Waiting
188d98a9d457: Pulling fs layer
d034bf0e16e1: Pulling fs layer
3835c4318084: Waiting
8cb90b8f1fc2: Pulling fs layer
549825d0ab03: Waiting
5fad6a4c52b5: Pulling fs layer
debd84a910b3: Pulling fs layer
6e7368d99114: Waiting
4f4fb700ef54: Pulling fs layer
d034bf0e16e1: Waiting
cb6191f3eef1: Waiting
152a68323944: Pulling fs layer
1f7f98a5f0d2: Pulling fs layer
8cb90b8f1fc2: Waiting
5fad6a4c52b5: Waiting
debd84a910b3: Waiting
667866023596: Pulling fs layer
4f4fb700ef54: Waiting
474d64aaa83a: Pulling fs layer
152a68323944: Waiting
1f7f98a5f0d2: Waiting
667866023596: Waiting
81e9448f8d7d: Pulling fs layer
8f7471ae6f30: Pulling fs layer
ba1c9d522099: Pulling fs layer
847d9b38068d: Pulling fs layer
8f7471ae6f30: Waiting
6c1cb3b3dd7c: Pulling fs layer
ba1c9d522099: Waiting
30a81ee5e9b7: Pulling fs layer
847d9b38068d: Waiting
6c1cb3b3dd7c: Waiting
b395d300d073: Pulling fs layer
689e54a1bb6f: Pulling fs layer
b395d300d073: Waiting
474d64aaa83a: Waiting
cfba20ff1fbb: Pulling fs layer
d6503c133859: Pulling fs layer
cfba20ff1fbb: Waiting
689e54a1bb6f: Waiting
30a81ee5e9b7: Waiting
3dcf084af38f: Pulling fs layer
d6503c133859: Waiting
22043404df4c: Pulling fs layer
780f53a6c5cb: Pulling fs layer
81e9448f8d7d: Waiting
38b848127537: Pulling fs layer
780f53a6c5cb: Waiting
4e0623b05f54: Pulling fs layer
38b848127537: Waiting
df63855aa3ab: Pulling fs layer
6e452b8c8ddd: Pulling fs layer
f71bd4b816cb: Pulling fs layer
4e0623b05f54: Waiting
6e452b8c8ddd: Waiting
22043404df4c: Waiting
f71bd4b816cb: Waiting
df63855aa3ab: Waiting
1edcfb1efe19: Download complete
1edcfb1efe19: Pull complete
35edc2941e66: Verifying Checksum
35edc2941e66: Download complete
664494e6aa3b: Verifying Checksum
664494e6aa3b: Download complete
3ddbff1fae48: Verifying Checksum
3ddbff1fae48: Download complete
9897d53e41d9: Verifying Checksum
9897d53e41d9: Download complete
5955f0d634c5: Download complete
39569ccf3df4: Verifying Checksum
39569ccf3df4: Download complete
3ddbff1fae48: Pull complete
6f97b42e121d: Verifying Checksum
6f97b42e121d: Download complete
3835c4318084: Verifying Checksum
3835c4318084: Download complete
549825d0ab03: Verifying Checksum
549825d0ab03: Download complete
cb6191f3eef1: Verifying Checksum
cb6191f3eef1: Download complete
6e7368d99114: Verifying Checksum
6e7368d99114: Download complete
d034bf0e16e1: Verifying Checksum
d034bf0e16e1: Download complete
188d98a9d457: Verifying Checksum
188d98a9d457: Download complete
8cb90b8f1fc2: Verifying Checksum
8cb90b8f1fc2: Download complete
5fad6a4c52b5: Verifying Checksum
5fad6a4c52b5: Download complete
debd84a910b3: Verifying Checksum
debd84a910b3: Download complete
4f4fb700ef54: Verifying Checksum
4f4fb700ef54: Download complete
152a68323944: Download complete
1f7f98a5f0d2: Download complete
474d64aaa83a: Download complete
667866023596: Download complete
6e72e374834b: Verifying Checksum
6e72e374834b: Download complete
81e9448f8d7d: Download complete
847d9b38068d: Download complete
ba1c9d522099: Verifying Checksum
ba1c9d522099: Download complete
8f7471ae6f30: Download complete
30a81ee5e9b7: Verifying Checksum
30a81ee5e9b7: Download complete
6c1cb3b3dd7c: Download complete
689e54a1bb6f: Verifying Checksum
689e54a1bb6f: Download complete
b395d300d073: Download complete
d6503c133859: Verifying Checksum
d6503c133859: Download complete
22043404df4c: Verifying Checksum
22043404df4c: Download complete
780f53a6c5cb: Download complete
6f97b42e121d: Pull complete
35edc2941e66: Pull complete
664494e6aa3b: Pull complete
38b848127537: Verifying Checksum
38b848127537: Download complete
6e72e374834b: Pull complete
9897d53e41d9: Pull complete
cfba20ff1fbb: Verifying Checksum
cfba20ff1fbb: Download complete
df63855aa3ab: Verifying Checksum
df63855aa3ab: Download complete
5955f0d634c5: Pull complete
6e452b8c8ddd: Download complete
39569ccf3df4: Pull complete
f71bd4b816cb: Download complete
3835c4318084: Pull complete
549825d0ab03: Pull complete
6e7368d99114: Pull complete
cb6191f3eef1: Pull complete
188d98a9d457: Pull complete
d034bf0e16e1: Pull complete
8cb90b8f1fc2: Pull complete
5fad6a4c52b5: Pull complete
debd84a910b3: Pull complete
4f4fb700ef54: Pull complete
152a68323944: Pull complete
1f7f98a5f0d2: Pull complete
667866023596: Pull complete
474d64aaa83a: Pull complete
81e9448f8d7d: Pull complete
8f7471ae6f30: Pull complete
ba1c9d522099: Pull complete
847d9b38068d: Pull complete
6c1cb3b3dd7c: Pull complete
30a81ee5e9b7: Pull complete
b395d300d073: Pull complete
689e54a1bb6f: Pull complete
3dcf084af38f: Verifying Checksum
3dcf084af38f: Download complete
4e0623b05f54: Verifying Checksum
4e0623b05f54: Download complete
cfba20ff1fbb: Pull complete
d6503c133859: Pull complete
3dcf084af38f: Pull complete
22043404df4c: Pull complete
780f53a6c5cb: Pull complete
38b848127537: Pull complete
4e0623b05f54: Pull complete
df63855aa3ab: Pull complete
6e452b8c8ddd: Pull complete
f71bd4b816cb: Pull complete
Digest: sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd
Status: Downloaded newer image for ocaml/opam@sha256:7ca1e149b2dfd03031ce683ab8da6c9e04bdc22f617456e4aa0110e90afaf4fd
2026-01-12 13:23.51 ---> saved as "d0093190c362815ce5c7f927a02f954353e12682064e7df32709340dd601134a"
/: (user (uid 1000) (gid 1000))
/: (workdir /home/opam)
/home/opam: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2026-01-12 13:23.51 ---> saved as "9d50255901b8a23c75cddd26cf759e6f8e26213f0ef949938eef9615b19ada4a"
/home/opam: (run (network host)
(shell "opam init --reinit --config .opamrc-sandbox -ni"))
Configuring from /home/opam/.opamrc-sandbox, then /home/opam/.opamrc, and finally from built-in defaults.
Checking for available remotes: rsync and local, git.
- you won't be able to use mercurial repositories unless you install the hg command on your system.
- you won't be able to use darcs repositories unless you install the darcs command on your system.
This version of opam requires an update to the layout of /home/opam/.opam from version 2.0 to version 2.2, which can't be reverted.
You may want to back it up before going further.
[NOTE] The 'jobs' option was reset, its value was 255 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using:
opam option jobs=255 --global
Continue? [Y/n] y
Format upgrade done.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-01-12 13:24.18 ---> saved as "4e185f321fb3c2f5983cccd9eb63df42ac5fb89b6068ae8e9df7cc7e7888ef33"
/home/opam: (run (shell "opam option solver=builtin-0install && opam config report"))
Set to 'builtin-0install' the field solver in global configuration
# opam config report
# opam-version 2.5.0
# self-upgrade no
# system arch=x86_64 os=linux os-distribution=opensuse-leap os-version=16.0
# solver builtin-0install
# install-criteria -changed,-count[avoid-version,solution]
# upgrade-criteria -count[avoid-version,solution]
# jobs 71
# repositories 1 (version-controlled)
# pinned 1 (version)
# current-switch 4.14
# invariant ["ocaml-base-compiler" {= "4.14.2"}]
# compiler-packages ocaml-base-compiler.4.14.2, ocaml-options-vanilla.1
# ocaml:native true
# ocaml:native-tools true
# ocaml:native-dynlink true
# ocaml:stubsdir /home/opam/.opam/4.14/lib/ocaml/stublibs:/home/opam/.opam/4.14/lib/ocaml
# ocaml:preinstalled false
# ocaml:compiler 4.14.2
2026-01-12 13:24.19 ---> saved as "77a39ca4793b2d4f2e627b7ace45614218749fdfe3059c504796a8067af5e708"
/home/opam: (env OPAMDOWNLOADJOBS 1)
/home/opam: (env OPAMERRLOGLEN 0)
/home/opam: (env OPAMPRECISETRACKING 1)
/home/opam: (env CI true)
/home/opam: (env OPAM_REPO_CI true)
/home/opam: (run (shell "rm -rf opam-repository/"))
2026-01-12 13:24.34 ---> saved as "84c29b3827d2e053e0f3603a252fa36ab5cfed8e20a964066335c48613ccd072"
/home/opam: (copy (src .) (dst opam-repository/))
2026-01-12 13:25.46 ---> saved as "4596adf3095dfe97da5e4cefc4f650c14ecca68c953eea746659ed03b9152f8b"
/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-01-12 13:26.31 ---> saved as "4e035727499b0e302a1cb47cc4560c3ee96f40f3868e6be5ce5faf1a9c79987a"
/home/opam: (run (network host)
(shell "opam update --depexts || true"))
+ /usr/bin/sudo "zypper" "--non-interactive" "refresh"
- Repository 'repo-openh264 (16.0)' is up to date.
- Repository 'repo-oss (16.0)' is up to date.
- All repositories have been refreshed.
2026-01-12 13:26.33 ---> saved as "0b05594c7e3f8b0949276fbf30a0b402f7f21f8089da03e32dd956d6585342d1"
/home/opam: (run (shell "opam pin add -k version -yn libbpf.0.1.0 0.1.0"))
libbpf is now pinned to version 0.1.0
2026-01-12 13:26.35 ---> saved as "7808a74f405546267b62cfdf81f1a3244e16e5563fdc9526a188c9bb7b539db4"
/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam reinstall libbpf.0.1.0;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"opensuse-16.0\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'libbpf.0.1.0' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
[ERROR] libbpf = 0.1.0: unmet availability conditions: 'os = "linux" & (os-distribution = "debian" & os-version >= "12" | os-distribution = "ubuntu" & os-version >= "23.04" | os-family = "fedora" & os-version >= "38" | os-distribution = "nixos" & os-version >= "23.05" | os-distribution = "alpine" & os-version >= "3.18")'
"/usr/bin/env" "bash" "-c" "opam reinstall libbpf.0.1.0;
res=$?;
test "$res" != 31 && exit "$res";
export OPAMCLI=2.0;
build_dir=$(opam var prefix)/.opam-switch/build;
failed=$(ls "$build_dir");
partial_fails="";
for pkg in $failed; do
if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"opensuse-16.0\""; then
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.";
fi;
test "$pkg" != 'libbpf.0.1.0' && partial_fails="$partial_fails $pkg";
done;
test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}";
exit 1" failed with exit status 5
2026-01-12 13:26.50: Job failed: Failed: Build failed
2026-01-12 13:26.50: Log analysis:
2026-01-12 13:26.50: >>>
[ERROR] libbpf = 0.1.0: unmet availability conditions: 'os = "linux" & (os-distribution = "debian" & os-version >= "12" | os-distribution = "ubuntu" & os-version >= "23.04" | os-family = "fedora" & os-version >= "38" | os-distribution = "nixos" & os-version >= "23.05" | os-distribution = "alpine" & os-version >= "3.18")'
(score = 100)
2026-01-12 13:26.50: [SKIP] Package not available