Build:
  1. 0
2026-01-27 19:29.07: New job: test sihl.0.2.0 with mirage-runtime.4.0.0~beta3, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/29297/head (bec96dd4b29b0e3eb148af9966895e70442e68e2)
                              on debian-13-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/29297/head" && git reset --hard bec96dd4
git fetch origin master
git merge --no-edit 88150787b3c9df767fd8dadf5d416641f8ee58f8
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-13-ocaml-4.14@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012
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 mirage-runtime.4.0.0~beta3 4.0.0~beta3
RUN opam reinstall mirage-runtime.4.0.0~beta3; \
    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" != 'mirage-runtime.4.0.0~beta3' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1
RUN opam reinstall sihl.0.2.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 "\"debian-13\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'sihl.0.2.0' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1
RUN (opam reinstall --with-test sihl.0.2.0) || true
RUN opam reinstall --with-test --verbose sihl.0.2.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 "\"debian-13\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'sihl.0.2.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-27 19:29.07: Using cache hint "ocaml/opam:debian-13-ocaml-4.14@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012-mirage-runtime.4.0.0~beta3-sihl.0.2.0-bec96dd4b29b0e3eb148af9966895e70442e68e2"
2026-01-27 19:29.07: Using OBuilder spec:
((from ocaml/opam:debian-13-ocaml-4.14@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012)
 (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 mirage-runtime.4.0.0~beta3 4.0.0~beta3"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall mirage-runtime.4.0.0~beta3;\
             \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\" != 'mirage-runtime.4.0.0~beta3' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall sihl.0.2.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 \"\\\"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\" != 'sihl.0.2.0' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
 (run (network host)
      (shell "(opam reinstall --with-test sihl.0.2.0) || true"))
 (run (shell  "opam reinstall --with-test --verbose sihl.0.2.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 \"\\\"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\" != 'sihl.0.2.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-27 19:29.07: Waiting for resource in pool OCluster
2026-01-28 03:48.36: Waiting for worker…
2026-01-28 03:54.34: Got resource from pool OCluster
Building on toxis.caelum.ci.dev
All commits already cached
Updating files:  61% (11873/19285)
Updating files:  62% (11957/19285)
Updating files:  63% (12150/19285)
Updating files:  64% (12343/19285)
Updating files:  65% (12536/19285)
Updating files:  66% (12729/19285)
Updating files:  67% (12921/19285)
Updating files:  68% (13114/19285)
Updating files:  69% (13307/19285)
Updating files:  70% (13500/19285)
Updating files:  71% (13693/19285)
Updating files:  72% (13886/19285)
Updating files:  73% (14079/19285)
Updating files:  74% (14271/19285)
Updating files:  75% (14464/19285)
Updating files:  76% (14657/19285)
Updating files:  77% (14850/19285)
Updating files:  78% (15043/19285)
Updating files:  79% (15236/19285)
Updating files:  80% (15428/19285)
Updating files:  81% (15621/19285)
Updating files:  82% (15814/19285)
Updating files:  83% (16007/19285)
Updating files:  84% (16200/19285)
Updating files:  85% (16393/19285)
Updating files:  86% (16586/19285)
Updating files:  87% (16778/19285)
Updating files:  88% (16971/19285)
Updating files:  89% (17164/19285)
Updating files:  90% (17357/19285)
Updating files:  91% (17550/19285)
Updating files:  92% (17743/19285)
Updating files:  93% (17936/19285)
Updating files:  94% (18128/19285)
Updating files:  95% (18321/19285)
Updating files:  96% (18514/19285)
Updating files:  97% (18707/19285)
Updating files:  98% (18900/19285)
Updating files:  99% (19093/19285)
Updating files: 100% (19285/19285)
Updating files: 100% (19285/19285), done.
HEAD is now at 88150787b3 Merge pull request #29287 from dinosaure/release-git-kv-v0.2.1
Merge made by the 'ort' strategy.
 packages/mirage-runtime/mirage-runtime.4.0.0/opam       | 2 +-
 packages/mirage-runtime/mirage-runtime.4.0.0~beta3/opam | 2 +-
 packages/mirage-runtime/mirage-runtime.4.10.0/opam      | 2 +-
 packages/mirage-runtime/mirage-runtime.4.10.1/opam      | 2 +-
 packages/mirage-runtime/mirage-runtime.4.10.2/opam      | 2 +-
 packages/mirage-runtime/mirage-runtime.4.10.3/opam      | 2 +-
 packages/mirage-runtime/mirage-runtime.4.10.4/opam      | 2 +-
 packages/mirage-runtime/mirage-runtime.4.7.0/opam       | 2 +-
 packages/mirage-runtime/mirage-runtime.4.9.0/opam       | 2 +-
 9 files changed, 9 insertions(+), 9 deletions(-)

(from ocaml/opam:debian-13-ocaml-4.14@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012)
Unable to find image 'ocaml/opam:debian-13-ocaml-4.14@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012' locally
docker.io/ocaml/opam@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012: Pulling from ocaml/opam
32ef12fa09dd: Already exists
Digest: sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012
Status: Downloaded newer image for ocaml/opam@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012
2026-01-28 03:54.50 ---> using "3fd264bad5105e854dbd96d70e0cfc1d39526afdd30eb5071f64946db0e5017f" 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-01-28 03:54.50 ---> using "c3cd77d504ddaf309a58ec97d6990fbd674dfde7b2abb842e8428debfcc0578e" 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
Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-01-28 03:54.50 ---> using "465a85423ed866bf442b5d4ea44e6d67ced29e9b9e842e1931d4e6d88019fbd3" 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=x86_64 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                 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-28 03:54.50 ---> using "600a99cbfa8eb664d95037ff02fc36b5d64190bc45ec2fd4792c21267b01f885" 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-01-28 03:54.50 ---> using "7a36498140d9470d1651f2f43060608bb30c70da80a143f96ae11f513ef0d2f1" from cache

/home/opam: (copy (src .) (dst opam-repository/))
2026-01-28 03:54.52 ---> using "c9c281874add8ec6f824059ed6bc4b1cfa517948ec5e9031033d3104a09c31cb" from cache

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-01-28 03:54.52 ---> using "53502e89c855ed9f94e21d4f7bd4f9f40b749d1356523774f70e07d214514475" from cache

/home/opam: (run (network host)
                 (shell "opam update --depexts || true"))
+ /usr/bin/sudo "apt-get" "update"
- Hit:1 http://deb.debian.org/debian trixie InRelease
- 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-security trixie-security/main amd64 Packages [97.9 kB]
- Fetched 189 kB in 0s (660 kB/s)
- Reading package lists...
- 
2026-01-28 03:54.52 ---> using "fd9c746d3f7a0ef758e388fb04e10d9013e6617bfbced5cd67effbd293bab80d" from cache

/home/opam: (run (shell "opam pin add -k version -yn mirage-runtime.4.0.0~beta3 4.0.0~beta3"))
mirage-runtime is now pinned to version 4.0.0~beta3
2026-01-28 03:54.52 ---> using "2c2d125654c113d7883485938bcc695bf99879091f9176200acd6bf749b34860" from cache

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall mirage-runtime.4.0.0~beta3;\
                        \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\" != 'mirage-runtime.4.0.0~beta3' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
mirage-runtime.4.0.0~beta3 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 18 packages
  - install base-bytes        base                 [required by ocplib-endian]
  - install cmdliner          1.3.0                [required by functoria-runtime, fmt, logs]
  - install cppo              1.8.0                [required by lwt]
  - install csexp             1.5.2                [required by dune-configurator]
  - install domain-name       0.5.0                [required by ipaddr]
  - install dune              3.21.0               [required by mirage-runtime]
  - install dune-configurator 3.21.0               [required by lwt]
  - install fmt               0.11.0               [required by mirage-runtime]
  - install functoria-runtime 4.0.0~beta3          [required by mirage-runtime]
  - install ipaddr            5.6.1                [required by mirage-runtime]
  - install logs              0.10.0               [required by mirage-runtime]
  - install lwt               5.9.2                [required by mirage-runtime]
  - install macaddr           5.6.1                [required by ipaddr]
  - install mirage-runtime    4.0.0~beta3 (pinned)
  - install ocamlbuild        0.16.1               [required by fmt, logs]
  - install ocamlfind         1.9.8                [required by fmt, logs]
  - install ocplib-endian     1.2                  [required by lwt]
  - install topkg             1.1.1                [required by fmt, logs]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved cmdliner.1.3.0  (cached)
-> retrieved cppo.1.8.0  (cached)
-> retrieved csexp.1.5.2  (cached)
-> retrieved domain-name.0.5.0  (cached)
-> retrieved dune.3.21.0, dune-configurator.3.21.0  (cached)
-> retrieved fmt.0.11.0  (cached)
-> retrieved functoria-runtime.4.0.0~beta3, mirage-runtime.4.0.0~beta3  (cached)
-> retrieved ipaddr.5.6.1, macaddr.5.6.1  (cached)
-> retrieved logs.0.10.0  (cached)
-> retrieved lwt.5.9.2  (cached)
-> installed cmdliner.1.3.0
-> retrieved ocamlbuild.0.16.1  (cached)
-> retrieved ocamlfind.1.9.8  (cached)
-> retrieved ocplib-endian.1.2  (cached)
-> retrieved topkg.1.1.1  (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed ocamlbuild.0.16.1
-> installed topkg.1.1.1
-> installed fmt.0.11.0
-> installed dune.3.21.0
-> installed csexp.1.5.2
-> installed cppo.1.8.0
-> installed domain-name.0.5.0
-> installed functoria-runtime.4.0.0~beta3
-> installed macaddr.5.6.1
-> installed ocplib-endian.1.2
-> installed ipaddr.5.6.1
-> installed dune-configurator.3.21.0
-> installed lwt.5.9.2
-> installed logs.0.10.0
-> installed mirage-runtime.4.0.0~beta3
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-28 03:54.52 ---> using "f451013c053d764570dc25ba85ffafd7729dc083fb4de6efc764e3ef9f71f9e9" from cache

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall sihl.0.2.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 \"\\\"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\" != 'sihl.0.2.0' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
sihl.0.2.0 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== recompile 3 packages
  - recompile logs                  0.10.0               [uses lwt]
  - recompile lwt                   5.9.2                [uses conf-libev]
  - recompile mirage-runtime        4.0.0~beta3 (pinned) [uses lwt]
=== install 111 packages
  - install   alcotest              1.9.1                [required by sihl-type]
  - install   angstrom              0.16.1               [required by colombe, caqti, mrmime]
  - install   asn1-combinators      0.2.6                [required by x509]
  - install   astring               0.8.5                [required by alcotest, opium]
  - install   base                  v0.16.4              [required by ppx_fields_conv, ppx_sexp_conv]
  - install   base64                3.5.2                [required by mrmime, opium, jwto, etc.]
  - install   bigstringaf           0.10.0               [required by caqti, sendmail]
  - install   bos                   0.2.1                [required by ca-certs]
  - install   bstr                  0.0.4                [required by mrmime]
  - install   ca-certs              0.2.3                [required by letters]
  - install   caqti                 1.9.0                [required by sihl-core, sihl-persistence]
  - install   caqti-lwt             1.9.0                [required by sihl-type, sihl-persistence]
  - install   cohttp                6.0.0                [required by cohttp-lwt-unix]
  - install   cohttp-lwt            6.0.0                [required by cohttp-lwt-unix]
  - install   cohttp-lwt-unix       6.0.0                [required by sihl-email]
  - install   coin                  0.1.5                [required by rosetta]
  - install   colombe               0.8.1                [required by letters]
  - install   conduit               6.2.3                [required by conduit-lwt]
  - install   conduit-lwt           6.2.3                [required by cohttp-lwt-unix]
  - install   conduit-lwt-unix      6.2.3                [required by cohttp-lwt-unix]
  - install   conf-gmp              5                    [required by conf-gmp-powm-sec, zarith]
  - install   conf-gmp-powm-sec     4                    [required by mirage-crypto-pk]
  - install   conf-libev            4-13                 [required by opium]
  - install   conf-libssl           4                    [required by ssl]
  - install   conf-pkg-config       4                    [required by conf-libssl, zarith]
  - install   conformist            0.2.1                [required by sihl-core]
  - install   containers            3.17                 [required by sihl]
  - install   cstruct               6.2.0                [required by tls, sendmail]
  - install   digestif              1.3.0                [required by jwto]
  - install   duration              0.2.1                [required by mirage-crypto-rng, mirage-crypto-rng-lwt]
  - install   either                1.0.0                [required by containers]
  - install   emile                 1.1                  [required by colombe, mrmime]
  - install   eqaf                  0.9                  [required by mirage-crypto-ec, digestif, mirage-crypto-pk]
  - install   faraday               0.8.2                [required by httpaf]
  - install   faraday-lwt           0.8.2                [required by faraday-lwt-unix]
  - install   faraday-lwt-unix      0.8.2                [required by httpaf-lwt-unix]
  - install   fieldslib             v0.16.0              [required by ppx_fields_conv]
  - install   fpath                 0.7.3                [required by letters]
  - install   gmap                  0.3.0                [required by x509]
  - install   hkdf                  1.0.4 (deprecated)   [required by tls]
  - install   hmap                  0.8.1                [required by rock]
  - install   http                  6.0.0                [required by cohttp-lwt-unix]
  - install   httpaf                0.7.1                [required by httpaf-lwt-unix, rock]
  - install   httpaf-lwt-unix       0.7.1                [required by opium]
  - install   ipaddr-sexp           5.6.1                [required by conduit-lwt-unix]
  - install   jwto                  0.4.0                [required by sihl-core]
  - install   ke                    0.6                  [required by mrmime, sendmail]
  - install   letters               0.3.3                [required by sihl-email]
  - install   lwt_ppx               5.9.1                [required by multipart-form-data]
  - install   lwt_ssl               1.2.0                [required by sihl-core]
  - install   magic-mime            1.3.1                [required by cohttp-lwt-unix]
  - install   mirage-crypto         0.11.3               [required by tls, opium]
  - install   mirage-crypto-ec      0.11.3               [required by tls]
  - install   mirage-crypto-pk      0.11.3               [required by tls]
  - install   mirage-crypto-rng     0.11.3               [required by tls]
  - install   mirage-crypto-rng-lwt 0.11.3               [required by tls-lwt]
  - install   mrmime                0.7.1                [required by letters]
  - install   mtime                 2.1.0                [required by opium]
  - install   multipart-form-data   0.3.0                [required by sihl-web]
  - install   num                   1.6                  [required by sexplib]
  - install   ocaml-compiler-libs   v0.12.4              [required by ppxlib]
  - install   ocaml-syntax-shims    1.0.0                [required by alcotest, colombe]
  - install   opium                 0.20.0               [required by sihl-web]
  - install   parsexp               v0.16.0              [required by sexplib]
  - install   pbkdf                 1.2.0                [required by x509]
  - install   pecu                  0.7                  [required by mrmime]
  - install   ppx_derivers          1.2.1                [required by ppx_deriving]
  - install   ppx_deriving          6.0.3                [required by jwto, ppx_deriving_yojson]
  - install   ppx_deriving_yojson   3.9.1                [required by sihl-core]
  - install   ppx_fields_conv       v0.16.0              [required by sihl-core]
  - install   ppx_sexp_conv         v0.16.0              [required by sihl-core, cohttp-lwt-unix]
  - install   ppxlib                0.35.0               [required by ppx_fields_conv, ppx_deriving_yojson, ppx_sexp_conv]
  - install   prettym               0.0.4                [required by mrmime]
  - install   ptime                 1.2.0                [required by letters]
  - install   re                    1.14.0               [required by opium, jwto, alcotest, cohttp]
  - install   result                1.5                  [required by httpaf]
  - install   rock                  0.20.0               [required by opium]
  - install   rosetta               0.4.0                [required by mrmime]
  - install   rresult               0.7.0                [required by letters]
  - install   safepass              3.1                  [required by sihl-core]
  - install   sendmail              0.8.1                [required by letters]
  - install   seq                   base                 [required by tyxml]
  - install   sexplib               v0.16.0              [required by sihl-core]
  - install   sexplib0              v0.16.0              [required by cohttp, ppx_sexp_conv, sexplib, cohttp-lwt]
  - install   sihl                  0.2.0
  - install   sihl-contract         0.2.0                [required by sihl]
  - install   sihl-core             0.2.0                [required by sihl]
  - install   sihl-email            0.2.0                [required by sihl]
  - install   sihl-persistence      0.2.0                [required by sihl]
  - install   sihl-queue            0.2.0                [required by sihl]
  - install   sihl-storage          0.2.0                [required by sihl]
  - install   sihl-type             0.2.0                [required by sihl]
  - install   sihl-user             0.2.0                [required by sihl]
  - install   sihl-web              0.2.0                [required by sihl]
  - install   ssl                   0.7.0                [required by sihl-core]
  - install   stdlib-shims          0.3.0                [required by alcotest]
  - install   stringext             1.6.0                [required by multipart-form-data, cohttp]
  - install   tls                   0.17.5               [required by sihl-core, letters]
  - install   tls-lwt               0.17.5               [required by letters]
  - install   tsort                 2.0.0                [required by sihl-core]
  - install   tyxml                 4.6.0                [required by opium]
  - install   unstrctrd             0.4                  [required by mrmime]
  - install   uri                   4.4.0                [required by cohttp-lwt, opium, caqti, etc.]
  - install   uri-sexp              4.4.0                [required by cohttp]
  - install   uuidm                 0.9.10               [required by sihl-type]
  - install   uutf                  1.0.4                [required by alcotest, mrmime]
  - install   uuuu                  0.4.0                [required by rosetta]
  - install   x509                  0.16.5               [required by letters]
  - install   yojson                3.0.0                [required by sihl-core]
  - install   yuscii                0.3.0                [required by rosetta]
  - install   zarith                1.14                 [required by mirage-crypto-pk]

The following system packages will first need to be installed:
    libev-dev libgmp-dev libssl-dev pkg-config

<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>

opam believes some required external dependencies are missing. opam can:
> 1. Run apt-get to install them (may need root/sudo access)
  2. Display the recommended apt-get command and wait while you run it manually (e.g. in another terminal)
  3. Continue anyway, and, upon success, permanently register that this external dependency is present, but not detectable
  4. Abort the installation

[1/2/3/4] 1

+ /usr/bin/sudo "apt-get" "install" "-qq" "-yy" "libev-dev" "libgmp-dev" "libssl-dev" "pkg-config"
- Selecting previously unselected package libev4t64:amd64.
- (Reading database ... 
(Reading database ... 5%
(Reading database ... 10%
(Reading database ... 15%
(Reading database ... 20%
(Reading database ... 25%
(Reading database ... 30%
(Reading database ... 35%
(Reading database ... 40%
(Reading database ... 45%
(Reading database ... 50%
(Reading database ... 55%
(Reading database ... 60%
(Reading database ... 65%
(Reading database ... 70%
(Reading database ... 75%
(Reading database ... 80%
(Reading database ... 85%
(Reading database ... 90%
(Reading database ... 95%
(Reading database ... 100%
(Reading database ... 20623 files and directories currently installed.)
- Preparing to unpack .../0-libev4t64_1%3a4.33-2.1+b1_amd64.deb ...
- Unpacking libev4t64:amd64 (1:4.33-2.1+b1) ...
- Selecting previously unselected package libev-dev:amd64.
- Preparing to unpack .../1-libev-dev_1%3a4.33-2.1+b1_amd64.deb ...
- Unpacking libev-dev:amd64 (1:4.33-2.1+b1) ...
- Selecting previously unselected package libgmpxx4ldbl:amd64.
- Preparing to unpack .../2-libgmpxx4ldbl_2%3a6.3.0+dfsg-3_amd64.deb ...
- Unpacking libgmpxx4ldbl:amd64 (2:6.3.0+dfsg-3) ...
- Selecting previously unselected package libgmp-dev:amd64.
- Preparing to unpack .../3-libgmp-dev_2%3a6.3.0+dfsg-3_amd64.deb ...
- Unpacking libgmp-dev:amd64 (2:6.3.0+dfsg-3) ...
- Selecting previously unselected package libpkgconf3:amd64.
- Preparing to unpack .../4-libpkgconf3_1.8.1-4_amd64.deb ...
- Unpacking libpkgconf3:amd64 (1.8.1-4) ...
- Selecting previously unselected package libssl-dev:amd64.
- Preparing to unpack .../5-libssl-dev_3.5.4-1~deb13u1_amd64.deb ...
- Unpacking libssl-dev:amd64 (3.5.4-1~deb13u1) ...
- Selecting previously unselected package pkgconf-bin.
- Preparing to unpack .../6-pkgconf-bin_1.8.1-4_amd64.deb ...
- Unpacking pkgconf-bin (1.8.1-4) ...
- Selecting previously unselected package pkgconf:amd64.
- Preparing to unpack .../7-pkgconf_1.8.1-4_amd64.deb ...
- Unpacking pkgconf:amd64 (1.8.1-4) ...
- Selecting previously unselected package pkg-config:amd64.
- Preparing to unpack .../8-pkg-config_1.8.1-4_amd64.deb ...
- Unpacking pkg-config:amd64 (1.8.1-4) ...
- Setting up libev4t64:amd64 (1:4.33-2.1+b1) ...
- Setting up libpkgconf3:amd64 (1.8.1-4) ...
- Setting up libgmpxx4ldbl:amd64 (2:6.3.0+dfsg-3) ...
- Setting up libssl-dev:amd64 (3.5.4-1~deb13u1) ...
- Setting up pkgconf-bin (1.8.1-4) ...
- Setting up libev-dev:amd64 (1:4.33-2.1+b1) ...
- Setting up libgmp-dev:amd64 (2:6.3.0+dfsg-3) ...
- Setting up pkgconf:amd64 (1.8.1-4) ...
- Setting up pkg-config:amd64 (1.8.1-4) ...
- Processing triggers for libc-bin (2.41-12+deb13u1) ...

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved alcotest.1.9.1  (cached)
-> retrieved angstrom.0.16.1  (cached)
-> retrieved asn1-combinators.0.2.6  (cached)
-> retrieved astring.0.8.5  (cached)
-> retrieved base.v0.16.4  (cached)
-> retrieved base64.3.5.2  (cached)
-> retrieved bigstringaf.0.10.0  (cached)
-> retrieved bos.0.2.1  (cached)
-> retrieved bstr.0.0.4  (cached)
-> retrieved ca-certs.0.2.3  (cached)
-> retrieved caqti.1.9.0, caqti-lwt.1.9.0  (cached)
-> retrieved cohttp.6.0.0, cohttp-lwt.6.0.0, cohttp-lwt-unix.6.0.0, http.6.0.0  (cached)
-> installed base64.3.5.2
-> retrieved coin.0.1.5  (cached)
-> installed bstr.0.0.4
-> retrieved colombe.0.8.1, sendmail.0.8.1  (cached)
-> retrieved conduit.6.2.3, conduit-lwt.6.2.3, conduit-lwt-unix.6.2.3  (cached)
-> retrieved conf-gmp.5  (cached)
-> retrieved conf-gmp-powm-sec.4  (cached)
-> retrieved conf-libev.4-13  (cached)
-> retrieved conf-libssl.4  (cached)
-> installed bigstringaf.0.10.0
-> retrieved conformist.0.2.1  (cached)
-> installed conf-gmp.5
-> installed conf-pkg-config.4
-> installed conf-gmp-powm-sec.4
-> installed conf-libssl.4
-> retrieved containers.3.17  (cached)
-> retrieved cstruct.6.2.0  (cached)
-> installed http.6.0.0
-> installed conformist.0.2.1
-> installed conf-libev.4-13
-> installed coin.0.1.5
-> installed astring.0.8.5
-> installed cstruct.6.2.0
-> retrieved digestif.1.3.0  (cached)
-> retrieved duration.0.2.1  (cached)
-> retrieved either.1.0.0  (cached)
-> retrieved emile.1.1  (cached)
-> retrieved eqaf.0.9  (cached)
-> retrieved faraday.0.8.2, faraday-lwt.0.8.2, faraday-lwt-unix.0.8.2  (cached)
-> retrieved fieldslib.v0.16.0  (cached)
-> retrieved fpath.0.7.3  (cached)
-> retrieved gmap.0.3.0  (cached)
-> retrieved hkdf.1.0.4  (cached)
-> retrieved hmap.0.8.1  (cached)
-> retrieved httpaf.0.7.1, httpaf-lwt-unix.0.7.1  (cached)
-> retrieved ipaddr-sexp.5.6.1  (cached)
-> retrieved jwto.0.4.0  (cached)
-> retrieved ke.0.6  (cached)
-> retrieved letters.0.3.3  (cached)
-> retrieved logs.0.10.0  (cached)
-> installed duration.0.2.1
-> retrieved lwt.5.9.2  (cached)
-> installed faraday.0.8.2
-> retrieved lwt_ppx.5.9.1  (cached)
-> installed either.1.0.0
-> installed gmap.0.3.0
-> retrieved lwt_ssl.1.2.0  (cached)
-> retrieved magic-mime.1.3.1  (cached)
-> installed hmap.0.8.1
-> installed eqaf.0.9
-> installed ke.0.6
-> installed fpath.0.7.3
-> retrieved mirage-crypto.0.11.3, mirage-crypto-ec.0.11.3, mirage-crypto-pk.0.11.3, mirage-crypto-rng.0.11.3, mirage-crypto-rng-lwt.0.11.3  (cached)
-> removed   mirage-runtime.4.0.0~beta3
-> removed   logs.0.10.0
-> removed   lwt.5.9.2
-> installed magic-mime.1.3.1
-> installed digestif.1.3.0
-> retrieved mrmime.0.7.1  (cached)
-> retrieved mtime.2.1.0  (cached)
-> retrieved multipart-form-data.0.3.0  (cached)
-> retrieved num.1.6  (cached)
-> retrieved ocaml-compiler-libs.v0.12.4  (cached)
-> retrieved ocaml-syntax-shims.1.0.0  (cached)
-> retrieved opium.0.20.0, rock.0.20.0  (cached)
-> retrieved parsexp.v0.16.0  (cached)
-> retrieved pbkdf.1.2.0  (cached)
-> retrieved pecu.0.7  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved ppx_deriving.6.0.3  (cached)
-> retrieved ppx_deriving_yojson.3.9.1  (cached)
-> retrieved ppx_fields_conv.v0.16.0  (cached)
-> retrieved ppx_sexp_conv.v0.16.0  (cached)
-> retrieved ppxlib.0.35.0  (cached)
-> installed ppx_derivers.1.2.1
-> retrieved prettym.0.0.4  (cached)
-> retrieved ptime.1.2.0  (cached)
-> retrieved re.1.14.0  (cached)
-> retrieved result.1.5  (cached)
-> retrieved rosetta.0.4.0  (cached)
-> retrieved rresult.0.7.0  (cached)
-> retrieved safepass.3.1  (cached)
-> retrieved seq.base  (cached)
-> installed seq.base
-> installed pecu.0.7
-> retrieved sexplib.v0.16.0  (cached)
-> installed containers.3.17
-> installed ocaml-syntax-shims.1.0.0
-> installed ocaml-compiler-libs.v0.12.4
-> installed prettym.0.0.4
-> installed result.1.5
-> installed rresult.0.7.0
-> retrieved sexplib0.v0.16.0  (cached)
-> installed mtime.2.1.0
-> retrieved sihl.0.2.0, sihl-contract.0.2.0, sihl-core.0.2.0, sihl-email.0.2.0, sihl-persistence.0.2.0, sihl-queue.0.2.0, sihl-storage.0.2.0, sihl-type.0.2.0, sihl-user.0.2.0, sihl-web.0.2.0  (cached)
-> installed lwt.5.9.2
-> retrieved ssl.0.7.0  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> installed re.1.14.0
-> retrieved stringext.1.6.0  (cached)
-> installed faraday-lwt.0.8.2
-> retrieved tls.0.17.5, tls-lwt.0.17.5  (cached)
-> retrieved tsort.2.0.0  (cached)
-> retrieved tyxml.4.6.0  (cached)
-> retrieved unstrctrd.0.4  (cached)
-> installed angstrom.0.16.1
-> installed ptime.1.2.0
-> installed stdlib-shims.0.3.0
-> installed stringext.1.6.0
-> installed faraday-lwt-unix.0.8.2
-> retrieved uri.4.4.0, uri-sexp.4.4.0  (cached)
-> installed tsort.2.0.0
-> installed sexplib0.v0.16.0
-> installed num.1.6
-> retrieved uuidm.0.9.10  (cached)
-> retrieved uutf.1.0.4  (cached)
-> retrieved uuuu.0.4.0  (cached)
-> retrieved x509.0.16.5  (cached)
-> retrieved yojson.3.0.0  (cached)
-> installed safepass.3.1
-> retrieved yuscii.0.3.0  (cached)
-> retrieved zarith.1.14  (cached)
-> installed logs.0.10.0
-> installed mirage-crypto.0.11.3
-> installed httpaf.0.7.1
-> installed yuscii.0.3.0
-> installed uuuu.0.4.0
-> installed hkdf.1.0.4
-> installed pbkdf.1.2.0
-> installed mirage-runtime.4.0.0~beta3
-> installed httpaf-lwt-unix.0.7.1
-> installed uuidm.0.9.10
-> installed rosetta.0.4.0
-> installed ssl.0.7.0
-> installed mirage-crypto-rng.0.11.3
-> installed rock.0.20.0
-> installed parsexp.v0.16.0
-> installed lwt_ssl.1.2.0
-> installed mirage-crypto-rng-lwt.0.11.3
-> installed uri.4.4.0
-> installed uutf.1.0.4
-> installed yojson.3.0.0
-> installed unstrctrd.0.4
-> installed sexplib.v0.16.0
-> installed caqti.1.9.0
-> installed emile.1.1
-> installed alcotest.1.9.1
-> installed caqti-lwt.1.9.0
-> installed bos.0.2.1
-> installed colombe.0.8.1
-> installed mrmime.0.7.1
-> installed zarith.1.14
-> installed tyxml.4.6.0
-> installed mirage-crypto-pk.0.11.3
-> installed asn1-combinators.0.2.6
-> installed mirage-crypto-ec.0.11.3
-> installed base.v0.16.4
-> installed fieldslib.v0.16.0
-> installed x509.0.16.5
-> installed ca-certs.0.2.3
-> installed tls.0.17.5
-> installed tls-lwt.0.17.5
-> installed sendmail.0.8.1
-> installed letters.0.3.3
-> installed ppxlib.0.35.0
-> installed ppx_fields_conv.v0.16.0
-> installed lwt_ppx.5.9.1
-> installed ppx_sexp_conv.v0.16.0
-> installed ppx_deriving.6.0.3
-> installed multipart-form-data.0.3.0
-> installed uri-sexp.4.4.0
-> installed ipaddr-sexp.5.6.1
-> installed jwto.0.4.0
-> installed opium.0.20.0
-> installed ppx_deriving_yojson.3.9.1
-> installed conduit.6.2.3
-> installed cohttp.6.0.0
-> installed sihl-core.0.2.0
-> installed conduit-lwt.6.2.3
-> installed cohttp-lwt.6.0.0
-> installed conduit-lwt-unix.6.2.3
-> installed sihl-type.0.2.0
-> installed cohttp-lwt-unix.6.0.0
-> installed sihl-contract.0.2.0
-> installed sihl-persistence.0.2.0
-> installed sihl-storage.0.2.0
-> installed sihl-queue.0.2.0
-> installed sihl-email.0.2.0
-> installed sihl-web.0.2.0
-> installed sihl-user.0.2.0
-> installed sihl.0.2.0
Done.

<><> hkdf.1.0.4 installed successfully ><><><><><><><><><><><><><><><><><><><><>
=> Note: This package is deprecated.
# To update the current shell environment, run: eval $(opam env)
2026-01-28 03:57.11 ---> saved as "a28cf3be00043d56f175dac2a4f9ad139c75f91f1705d7404f44bd12f865dbae"

/home/opam: (run (network host)
                 (shell "(opam reinstall --with-test sihl.0.2.0) || true"))
The following actions will be performed:
=== downgrade 3 packages
  - downgrade cohttp          6.0.0 to 5.3.1 [required by cohttp-lwt]
  - downgrade cohttp-lwt      6.0.0 to 5.3.0 [required by cohttp-lwt-unix]
  - downgrade cohttp-lwt-unix 6.0.0 to 5.3.0 [required by sihl]
=== recompile 2 packages
  - recompile sihl            0.2.0
  - recompile sihl-email      0.2.0          [uses cohttp-lwt-unix]
=== upgrade 1 package
  - upgrade   http            6.0.0 to 6.2.1
=== install 2 packages
  - install   alcotest-lwt    1.9.1          [required by sihl]
  - install   jsonm           1.0.2          [required by cohttp]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved alcotest-lwt.1.9.1  (https://opam.ocaml.org/cache)
-> retrieved cohttp.5.3.1  (https://opam.ocaml.org/cache)
-> retrieved cohttp-lwt.5.3.0, cohttp-lwt-unix.5.3.0  (https://opam.ocaml.org/cache)
-> installed alcotest-lwt.1.9.1
-> retrieved http.6.2.1  (https://opam.ocaml.org/cache)
-> retrieved jsonm.1.0.2  (https://opam.ocaml.org/cache)
-> retrieved sihl.0.2.0, sihl-email.0.2.0  (https://opam.ocaml.org/cache)
-> removed   sihl.0.2.0
-> removed   sihl-email.0.2.0
-> removed   cohttp-lwt-unix.6.0.0
-> removed   cohttp-lwt.6.0.0
-> removed   cohttp.6.0.0
-> removed   http.6.0.0
-> installed http.6.2.1
-> installed jsonm.1.0.2
-> installed cohttp.5.3.1
-> installed cohttp-lwt.5.3.0
-> installed cohttp-lwt-unix.5.3.0
-> installed sihl-email.0.2.0
-> installed sihl.0.2.0
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-28 03:57.30 ---> saved as "a3b2d90b330cfe9d109417399d80a90139f9643b39dc32feca6d93abe791961c"

/home/opam: (run (shell  "opam reinstall --with-test --verbose sihl.0.2.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 \"\\\"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\" != 'sihl.0.2.0' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
The following actions will be performed:
=== recompile 1 package
  - recompile sihl 0.2.0

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing  1/4: [sihl.0.2.0: extract]
-> retrieved sihl.0.2.0  (cached)
Processing  2/4: [sihl: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "sihl" "-j" "71" "@install" "@runtest" (CWD=/home/opam/.opam/4.14/.opam-switch/build/sihl.0.2.0)
-> compiled  sihl.0.2.0
-> removed   sihl.0.2.0
-> installed sihl.0.2.0
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-28 03:57.39 ---> saved as "ccbd70954ba821d1eeff185eb246ed06fa706c949a57bdcca13b9192b23f1fc6"
Job succeeded
2026-01-28 03:59.14: Job succeeded