(for PR #29582)

2026-03-25 08:40.02: New job: build ocaml-compiler.5.4.0~alpha1, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/29582/head (fa5fb3a6a806e832e4c7791145889a6bbe8b64ef)
                              on debian-13-ocaml-4.14/arm64

To reproduce locally:

cd $(mktemp -d)
git clone --recursive "https://github.com/ocaml/opam-repository.git" && cd "opam-repository" && git fetch origin "refs/pull/29582/head" && git reset --hard fa5fb3a6
git fetch origin master
git merge --no-edit 7216d2e0eb5d8d116434228a0b19a267b98e8510
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-13-ocaml-4.14@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada
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 ocaml-compiler.5.4.0~alpha1 5.4.0~alpha1
RUN opam reinstall --update-invariant ocaml-compiler.5.4.0~alpha1; \
    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 "\"debian-13\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'ocaml-compiler.5.4.0~alpha1' && 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-03-25 08:40.02: Using cache hint "ocaml/opam:debian-13-ocaml-4.14@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada-ocaml-compiler.5.4.0~alpha1-fa5fb3a6a806e832e4c7791145889a6bbe8b64ef"
2026-03-25 08:40.02: Using OBuilder spec:
((from ocaml/opam:debian-13-ocaml-4.14@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada)
 (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 ocaml-compiler.5.4.0~alpha1 5.4.0~alpha1"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall --update-invariant ocaml-compiler.5.4.0~alpha1;\
             \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 \"\\\"debian-13\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'ocaml-compiler.5.4.0~alpha1' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
)

2026-03-25 08:40.02: Waiting for resource in pool OCluster
2026-03-25 08:40.03: Waiting for worker…
2026-03-25 08:49.19: Got resource from pool OCluster
Building on ocaml-2.osuosl.ci.dev
All commits already cached
Updating files:  36% (6836/18517)
Updating files:  37% (6852/18517)
Updating files:  38% (7037/18517)
Updating files:  39% (7222/18517)
Updating files:  40% (7407/18517)
Updating files:  41% (7592/18517)
Updating files:  42% (7778/18517)
Updating files:  43% (7963/18517)
Updating files:  44% (8148/18517)
Updating files:  45% (8333/18517)
Updating files:  46% (8518/18517)
Updating files:  47% (8703/18517)
Updating files:  48% (8889/18517)
Updating files:  49% (9074/18517)
Updating files:  50% (9259/18517)
Updating files:  51% (9444/18517)
Updating files:  52% (9629/18517)
Updating files:  53% (9815/18517)
Updating files:  54% (10000/18517)
Updating files:  55% (10185/18517)
Updating files:  56% (10370/18517)
Updating files:  57% (10555/18517)
Updating files:  58% (10740/18517)
Updating files:  59% (10926/18517)
Updating files:  60% (11111/18517)
Updating files:  61% (11296/18517)
Updating files:  62% (11481/18517)
Updating files:  63% (11666/18517)
Updating files:  64% (11851/18517)
Updating files:  65% (12037/18517)
Updating files:  66% (12222/18517)
Updating files:  67% (12407/18517)
Updating files:  68% (12592/18517)
Updating files:  69% (12777/18517)
Updating files:  70% (12962/18517)
Updating files:  71% (13148/18517)
Updating files:  72% (13333/18517)
Updating files:  72% (13361/18517)
Updating files:  73% (13518/18517)
Updating files:  74% (13703/18517)
Updating files:  75% (13888/18517)
Updating files:  76% (14073/18517)
Updating files:  77% (14259/18517)
Updating files:  78% (14444/18517)
Updating files:  79% (14629/18517)
Updating files:  80% (14814/18517)
Updating files:  81% (14999/18517)
Updating files:  82% (15184/18517)
Updating files:  83% (15370/18517)
Updating files:  84% (15555/18517)
Updating files:  85% (15740/18517)
Updating files:  86% (15925/18517)
Updating files:  87% (16110/18517)
Updating files:  88% (16295/18517)
Updating files:  89% (16481/18517)
Updating files:  90% (16666/18517)
Updating files:  91% (16851/18517)
Updating files:  92% (17036/18517)
Updating files:  93% (17221/18517)
Updating files:  94% (17406/18517)
Updating files:  95% (17592/18517)
Updating files:  96% (17777/18517)
Updating files:  97% (17962/18517)
Updating files:  98% (18147/18517)
Updating files:  99% (18332/18517)
Updating files: 100% (18517/18517)
Updating files: 100% (18517/18517), done.
HEAD is now at 7216d2e0eb Merge pull request #29593 from arvidj/aj/avoid-passage-0-3-2-3
Merge made by the 'ort' strategy.
 packages/ocaml-compiler/ocaml-compiler.5.3.0/opam      |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.3/opam        |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.4.0/opam      |  5 ++++-
 .../ocaml-compiler/ocaml-compiler.5.4.0~alpha1/opam    |  5 ++++-
 .../ocaml-compiler/ocaml-compiler.5.4.0~beta1/opam     |  5 ++++-
 .../ocaml-compiler/ocaml-compiler.5.4.0~beta2/opam     |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.4.0~rc1/opam  |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.4.1/opam      |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.4/opam        |  5 ++++-
 .../ocaml-compiler/ocaml-compiler.5.5.0~alpha1/opam    |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.5/opam        |  5 ++++-
 packages/ocaml-compiler/ocaml-compiler.5.6/opam        |  5 ++++-
 packages/ocaml-option-llvm/ocaml-option-llvm.1/opam    | 18 ++++++++++++++++++
 .../ocaml-options-vanilla/ocaml-options-vanilla.1/opam |  1 +
 packages/ocaml-variants/ocaml-variants.5.2.0+msvc/opam |  2 ++
 15 files changed, 69 insertions(+), 12 deletions(-)
 create mode 100644 packages/ocaml-option-llvm/ocaml-option-llvm.1/opam

(from ocaml/opam:debian-13-ocaml-4.14@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada)
Unable to find image 'ocaml/opam:debian-13-ocaml-4.14@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada' locally
docker.io/ocaml/opam@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada: Pulling from ocaml/opam
ac9148dc57ca: Already exists
7888403f6ebd: Already exists
c624d8e138d3: Already exists
bae5329cb92a: Already exists
6228156e24ec: Already exists
d851fec6b77f: Already exists
45e3afcdcfef: Already exists
b3e7f2150c0a: Already exists
91048a8ba3a7: Already exists
26a15cffb83a: Already exists
3c2f2520de0f: Already exists
9f731cc5daa6: Already exists
0809377d5f3c: Already exists
ec4e42e8f98c: Already exists
065e3401ccf2: Already exists
bce3ceded749: Already exists
c4a4a6ab703b: Already exists
aa84bc2cf05b: Already exists
0fb96351134e: Already exists
a1735f92ccde: Already exists
dce836972d90: Already exists
8a0c641e2184: Already exists
4f4fb700ef54: Already exists
44a2b50d619a: Already exists
e27f63ab21e8: Already exists
826c3a0f7d41: Already exists
7fe544c7b3e6: Already exists
efa4af957d6d: Already exists
a2fa2f09a7e4: Already exists
3e0efbdba3cc: Already exists
4f299997ffd7: Already exists
f868b4e81e65: Already exists
87577251fd14: Already exists
5e9e2e42ec71: Already exists
99812197be51: Already exists
8b48f92b9c03: Already exists
6336fa3f0edf: Already exists
f03483f6ff47: Already exists
26c2642c44cf: Already exists
35e7bc3e512e: Already exists
fb2e4e264f0c: Already exists
0302ffbcdd6f: Pulling fs layer
b6103da63ef0: Pulling fs layer
c8238d08ec04: Pulling fs layer
84114018616a: Pulling fs layer
84114018616a: Waiting
b6103da63ef0: Verifying Checksum
b6103da63ef0: Download complete
c8238d08ec04: Verifying Checksum
c8238d08ec04: Download complete
84114018616a: Verifying Checksum
84114018616a: Download complete
0302ffbcdd6f: Verifying Checksum
0302ffbcdd6f: Download complete
0302ffbcdd6f: Pull complete
b6103da63ef0: Pull complete
c8238d08ec04: Pull complete
84114018616a: Pull complete
Digest: sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada
Status: Downloaded newer image for ocaml/opam@sha256:bb26bd0b395363e31dbb0c8f26276c80a9cf90d8cac4c622fa75bed398506ada
2026-03-25 08:49.23 ---> using "6c35a6891e911a30fdf28b8e523ebc9def3db09c3bfc8ca0847b476f0567f309" from cache

/: (user (uid 1000) (gid 1000))

/: (workdir /home/opam)

/home/opam: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2026-03-25 08:49.23 ---> using "cdfcd7fa622098995226516d1d774b09597b48510ea7ff34a013795cf372cc27" from cache

/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.

Continue? [Y/n] y
[NOTE] The 'jobs' option was reset, its value was 79 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=79 --global
Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-03-25 08:49.23 ---> using "ce28484b2df1e4628d9f1e15febafb617f2f7df1657c39c8d85c82919b28f02b" from cache

/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=arm64 os=linux os-distribution=debian os-version=13
# solver               builtin-0install
# install-criteria     -changed,-count[avoid-version,solution]
# upgrade-criteria     -count[avoid-version,solution]
# jobs                 15
# 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-03-25 08:49.23 ---> using "b4ae217df9b9762e5a42514a94bc70424d8075ea5a1c27b5e6bee745cbfe90ea" from cache

/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-03-25 08:49.23 ---> using "5a66b0d29229f49525270a38edb2db302c91f59ccd47d94268b56b6956c99dd7" from cache

/home/opam: (copy (src .) (dst opam-repository/))
2026-03-25 08:49.40 ---> saved as "a5ad0ba1f67a88db6437206e3587828a56ca06961cecc0a44a4e4653ab889bfc"

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-03-25 08:50.27 ---> saved as "206e1814c7b75ad8c1c4c3d730d2d489c0f3da5daa1a420be52d9897b49b8e8e"

/home/opam: (run (network host)
                 (shell "opam update --depexts || true"))
+ /usr/bin/sudo "apt-get" "update"
- Get:1 http://deb.debian.org/debian trixie InRelease [140 kB]
- Get:2 http://deb.debian.org/debian trixie-updates InRelease [47.3 kB]
- Get:3 http://deb.debian.org/debian-security trixie-security InRelease [43.4 kB]
- Get:4 http://deb.debian.org/debian trixie/main arm64 Packages [9607 kB]
- Get:5 http://deb.debian.org/debian-security trixie-security/main arm64 Packages [114 kB]
- Fetched 9952 kB in 1s (7859 kB/s)
- Reading package lists...
- 
2026-03-25 08:50.31 ---> saved as "e7e916df86779514c4633ee6831a22bec4b69a438b200c0daa352a4e0fd81e0b"

/home/opam: (run (shell "opam pin add -k version -yn ocaml-compiler.5.4.0~alpha1 5.4.0~alpha1"))
ocaml-compiler is now pinned to version 5.4.0~alpha1
2026-03-25 08:50.33 ---> saved as "cbf0e4a662f9606a7c610009131272676a5f9f45c0fdc5aee5eaf6aa747fd1d5"

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall --update-invariant ocaml-compiler.5.4.0~alpha1;\
                        \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 \"\\\"debian-13\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'ocaml-compiler.5.4.0~alpha1' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
ocaml-compiler.5.4.0~alpha1 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== remove 1 package
  - remove    ocaml-base-compiler 4.14.2 (pinned)       [conflicts with ocaml-variants]
=== recompile 1 package
  - recompile opam-depext         1.2.3                 [uses ocaml]
=== upgrade 2 packages
  - upgrade   ocaml               4.14.2 to 5.4.0       [uses ocaml-config]
  - upgrade   ocaml-config        2 to 3
=== install 5 packages
  - install   base-domains        base
  - install   base-effects        base
  - install   base-nnp            base
  - install   ocaml-compiler      5.4.0~alpha1 (pinned)
  - install   ocaml-variants      5.4.0~alpha1+options  [required by ocaml-config]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved ocaml-compiler.5.4.0~alpha1  (https://opam.ocaml.org/cache)
-> retrieved ocaml-config.3  (cached)
-> retrieved opam-depext.1.2.3  (cached)
-> removed   opam-depext.1.2.3
-> removed   ocaml.4.14.2
-> removed   ocaml-config.2
-> removed   ocaml-base-compiler.4.14.2
-> installed ocaml-compiler.5.4.0~alpha1
-> installed ocaml-variants.5.4.0~alpha1+options
-> installed ocaml-config.3
-> installed ocaml.5.4.0
-> installed base-domains.base
-> installed base-effects.base
-> installed base-nnp.base
-> installed opam-depext.1.2.3
[NOTE] Switch invariant was updated to ["ocaml-variants" {= "5.4.0~alpha1+options"}]
       Use `opam switch set-invariant' to change it.
Done.

<><> opam-depext.1.2.3 installed successfully <><><><><><><><><><><><><><><><><>
=> opam-depext is unnecessary when used with opam >= 2.1. Please use opam install directly instead
# To update the current shell environment, run: eval $(opam env)
2026-03-25 08:54.11 ---> saved as "32dfed1779d0450fc2ef9d77dbb27a36ca773af603a359717760a655ee54824a"
Job succeeded
2026-03-25 08:54.25: Job succeeded