Build:
  1. 0
2026-01-27 19:22.41: New job: test sihl-type.0.2.0 with mirage-runtime.4.10.0, 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.10.0 4.10.0
RUN opam reinstall mirage-runtime.4.10.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" != 'mirage-runtime.4.10.0' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1
RUN opam reinstall sihl-type.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-type.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-type.0.2.0) || true
RUN opam reinstall --with-test --verbose sihl-type.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-type.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:22.41: Using cache hint "ocaml/opam:debian-13-ocaml-4.14@sha256:b77f64f7a162903a6fb8a0d50071a7eb7a4a9bc4421699c19d2ab9050981c012-mirage-runtime.4.10.0-sihl-type.0.2.0-bec96dd4b29b0e3eb148af9966895e70442e68e2"
2026-01-27 19:22.41: 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.10.0 4.10.0"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall mirage-runtime.4.10.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\" != 'mirage-runtime.4.10.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 (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall sihl-type.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-type.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-type.0.2.0) || true"))
 (run (shell  "opam reinstall --with-test --verbose sihl-type.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-type.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:22.41: Waiting for resource in pool OCluster
2026-01-27 21:05.46: Waiting for worker…
2026-01-27 21:27.43: Got resource from pool OCluster
Building on clete
All commits already cached
Updating files:  68% (13193/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)
2026-01-27 21:27.51 ---> 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-27 21:27.51 ---> 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.

Continue? [Y/n] y
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.

Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-01-27 21:27.51 ---> 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-27 21:27.51 ---> 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-27 21:27.51 ---> using "7a36498140d9470d1651f2f43060608bb30c70da80a143f96ae11f513ef0d2f1" from cache

/home/opam: (copy (src .) (dst opam-repository/))
2026-01-27 21:27.53 ---> using "c9c281874add8ec6f824059ed6bc4b1cfa517948ec5e9031033d3104a09c31cb" from cache

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-01-27 21:27.53 ---> 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 (755 kB/s)
- Reading package lists...
- 
2026-01-27 21:27.53 ---> using "fd9c746d3f7a0ef758e388fb04e10d9013e6617bfbced5cd67effbd293bab80d" from cache

/home/opam: (run (shell "opam pin add -k version -yn mirage-runtime.4.10.0 4.10.0"))
mirage-runtime is now pinned to version 4.10.0
2026-01-27 21:27.53 ---> using "3195f1cae4eb2899135326933414219ac5b4256ad4863150c1eb7dcc6920d920" from cache

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall mirage-runtime.4.10.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\" != 'mirage-runtime.4.10.0' && 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.10.0 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 16 packages
  - install base-bytes        base            [required by ocplib-endian]
  - install cmdliner          2.1.0           [required by mirage-runtime]
  - 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 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.10.0 (pinned)
  - install ocamlbuild        0.16.1          [required by logs]
  - install ocamlfind         1.9.8           [required by logs]
  - install ocplib-endian     1.2             [required by lwt]
  - install topkg             1.1.1           [required by logs]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved cmdliner.2.1.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 ipaddr.5.6.1, macaddr.5.6.1  (cached)
-> retrieved logs.0.10.0  (cached)
-> retrieved lwt.5.9.2  (cached)
-> installed cmdliner.2.1.0
-> retrieved mirage-runtime.4.10.0  (cached)
-> 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 dune.3.21.0
-> installed csexp.1.5.2
-> installed cppo.1.8.0
-> installed domain-name.0.5.0
-> 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.10.0
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-27 21:27.53 ---> using "fb7d9011e1a8f60a66df5f2fc9b25e802ca858ddbbb85afd3b1d92af796a681f" from cache

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall sihl-type.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-type.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-type.0.2.0 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== downgrade 1 package
  - downgrade cmdliner            2.1.0 to 1.3.0     [required by opium, alcotest, uuidm]
=== recompile 3 packages
  - recompile logs                0.10.0             [uses cmdliner]
  - recompile lwt                 5.9.2              [uses conf-libev]
  - recompile mirage-runtime      4.10.0 (pinned)    [uses cmdliner]
=== install 75 packages
  - install   alcotest            1.9.1              [required by sihl-type]
  - install   angstrom            0.16.1             [required by caqti]
  - 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 opium]
  - install   bigstringaf         0.10.0             [required by caqti, rock]
  - install   caqti               1.9.0              [required by caqti-lwt, sihl-core]
  - install   caqti-lwt           1.9.0              [required by sihl-type]
  - 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 tsort]
  - install   cstruct             6.2.0              [required by mirage-crypto, tls]
  - install   digestif            1.3.0              [required by jwto]
  - install   duration            0.2.1              [required by mirage-crypto-rng]
  - install   either              1.0.0              [required by containers]
  - install   eqaf                0.9                [required by mirage-crypto]
  - 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   fmt                 0.11.0             [required by opium, alcotest, sihl-core]
  - 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   httpaf              0.7.1              [required by httpaf-lwt-unix, rock]
  - install   httpaf-lwt-unix     0.7.1              [required by opium]
  - install   jwto                0.4.0              [required by sihl-core]
  - 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 opium]
  - install   mirage-crypto       0.11.3             [required by 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   mtime               2.1.0              [required by opium]
  - install   multipart-form-data 0.3.0              [required by sihl-type]
  - 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]
  - install   opium               0.20.0             [required by sihl-type]
  - install   parsexp             v0.16.0            [required by sexplib]
  - install   pbkdf               1.2.0              [required by x509]
  - install   ppx_derivers        1.2.1              [required by ppxlib, 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]
  - install   ppxlib              0.35.0             [required by ppx_fields_conv, lwt_ppx, ppx_deriving_yojson, ppx_sexp_conv]
  - install   ptime               1.2.0              [required by opium]
  - install   re                  1.14.0             [required by alcotest, opium]
  - install   result              1.5                [required by httpaf]
  - install   rock                0.20.0             [required by opium]
  - install   safepass            3.1                [required by sihl-core]
  - install   seq                 base               [required by tyxml]
  - install   sexplib             v0.16.0            [required by sihl-core]
  - install   sexplib0            v0.16.0            [required by ppx_sexp_conv, rock, sexplib]
  - install   sihl-core           0.2.0              [required by sihl-type]
  - install   sihl-type           0.2.0
  - 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]
  - install   tls                 0.17.5             [required by sihl-core]
  - install   tsort               2.0.0              [required by sihl-core]
  - install   tyxml               4.6.0              [required by opium]
  - install   uri                 4.4.0              [required by opium]
  - install   uuidm               0.9.10             [required by sihl-type]
  - install   uutf                1.0.4              [required by alcotest]
  - install   x509                0.16.5             [required by tls]
  - install   yojson              3.0.0              [required by opium, sihl-core]
  - 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 caqti.1.9.0, caqti-lwt.1.9.0  (cached)
-> retrieved cmdliner.1.3.0  (cached)
-> retrieved conf-gmp.5  (cached)
-> retrieved conf-gmp-powm-sec.4  (cached)
-> retrieved conf-libev.4-13  (cached)
-> retrieved conf-libssl.4  (cached)
-> 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
-> installed base64.3.5.2
-> retrieved containers.3.17  (cached)
-> retrieved cstruct.6.2.0  (cached)
-> installed conf-libev.4-13
-> installed conformist.0.2.1
-> installed bigstringaf.0.10.0
-> retrieved digestif.1.3.0  (cached)
-> retrieved duration.0.2.1  (cached)
-> retrieved either.1.0.0  (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 fmt.0.11.0  (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 jwto.0.4.0  (cached)
-> retrieved logs.0.10.0  (cached)
-> retrieved lwt.5.9.2  (cached)
-> installed duration.0.2.1
-> installed gmap.0.3.0
-> installed either.1.0.0
-> installed faraday.0.8.2
-> retrieved lwt_ppx.5.9.1  (cached)
-> retrieved lwt_ssl.1.2.0  (cached)
-> retrieved magic-mime.1.3.1  (cached)
-> installed astring.0.8.5
-> installed hmap.0.8.1
-> retrieved mirage-crypto.0.11.3, mirage-crypto-ec.0.11.3, mirage-crypto-pk.0.11.3, mirage-crypto-rng.0.11.3  (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 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)
-> installed magic-mime.1.3.1
-> installed ppx_derivers.1.2.1
-> retrieved ppxlib.0.35.0  (cached)
-> retrieved ptime.1.2.0  (cached)
-> retrieved re.1.14.0  (cached)
-> retrieved result.1.5  (cached)
-> retrieved safepass.3.1  (cached)
-> retrieved seq.base  (cached)
-> installed seq.base
-> retrieved sexplib.v0.16.0  (cached)
-> removed   mirage-runtime.4.10.0
-> removed   logs.0.10.0
-> removed   cmdliner.2.1.0
-> removed   lwt.5.9.2
-> retrieved sexplib0.v0.16.0  (cached)
-> installed cmdliner.1.3.0
-> installed containers.3.17
-> installed lwt.5.9.2
-> installed mtime.2.1.0
-> installed num.1.6
-> installed ocaml-compiler-libs.v0.12.4
-> installed ocaml-syntax-shims.1.0.0
-> installed ptime.1.2.0
-> installed result.1.5
-> installed safepass.3.1
-> installed re.1.14.0
-> installed sexplib0.v0.16.0
-> retrieved sihl-core.0.2.0, sihl-type.0.2.0  (https://opam.ocaml.org/cache)
-> installed faraday-lwt.0.8.2
-> retrieved ssl.0.7.0  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> retrieved stringext.1.6.0  (cached)
-> retrieved tls.0.17.5  (cached)
-> retrieved tsort.2.0.0  (cached)
-> retrieved tyxml.4.6.0  (cached)
-> installed faraday-lwt-unix.0.8.2
-> installed stdlib-shims.0.3.0
-> installed angstrom.0.16.1
-> installed stringext.1.6.0
-> installed tsort.2.0.0
-> retrieved uri.4.4.0  (cached)
-> retrieved uuidm.0.9.10  (cached)
-> retrieved uutf.1.0.4  (cached)
-> retrieved x509.0.16.5  (cached)
-> retrieved yojson.3.0.0  (cached)
-> installed fmt.0.11.0
-> retrieved zarith.1.14  (cached)
-> installed httpaf.0.7.1
-> installed cstruct.6.2.0
-> installed uuidm.0.9.10
-> installed parsexp.v0.16.0
-> installed httpaf-lwt-unix.0.7.1
-> installed rock.0.20.0
-> installed uutf.1.0.4
-> installed ssl.0.7.0
-> installed logs.0.10.0
-> installed eqaf.0.9
-> installed lwt_ssl.1.2.0
-> installed yojson.3.0.0
-> installed mirage-runtime.4.10.0
-> installed sexplib.v0.16.0
-> installed uri.4.4.0
-> installed alcotest.1.9.1
-> installed digestif.1.3.0
-> installed caqti.1.9.0
-> installed caqti-lwt.1.9.0
-> installed mirage-crypto.0.11.3
-> installed hkdf.1.0.4
-> installed pbkdf.1.2.0
-> installed mirage-crypto-rng.0.11.3
-> installed zarith.1.14
-> installed base.v0.16.4
-> installed tyxml.4.6.0
-> installed mirage-crypto-pk.0.11.3
-> installed fieldslib.v0.16.0
-> installed asn1-combinators.0.2.6
-> installed mirage-crypto-ec.0.11.3
-> installed x509.0.16.5
-> installed tls.0.17.5
-> 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 jwto.0.4.0
-> installed ppx_deriving_yojson.3.9.1
-> installed opium.0.20.0
-> installed sihl-core.0.2.0
-> installed sihl-type.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-27 21:30.16 ---> saved as "c6713decdba750fe2cfb179f65571614aaf176d7ffd0f618e57b0b6d846d7fb3"

/home/opam: (run (network host)
                 (shell "(opam reinstall --with-test sihl-type.0.2.0) || true"))
The following actions will be performed:
=== recompile 1 package
  - recompile sihl-type    0.2.0
=== install 1 package
  - install   alcotest-lwt 1.9.1 [required by sihl-type]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved alcotest-lwt.1.9.1  (https://opam.ocaml.org/cache)
-> retrieved sihl-type.0.2.0  (https://opam.ocaml.org/cache)
-> removed   sihl-type.0.2.0
-> installed alcotest-lwt.1.9.1
-> installed sihl-type.0.2.0
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-27 21:30.36 ---> saved as "8fcb6ee50769989ad8d79b4e86e7c50c68ce84fd7d5a69fb602953482c9890dd"

/home/opam: (run (shell  "opam reinstall --with-test --verbose sihl-type.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-type.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-type 0.2.0

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing  1/4: [sihl-type.0.2.0: extract]
-> retrieved sihl-type.0.2.0  (cached)
Processing  2/4: [sihl-type: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "sihl-type" "-j" "71" "@install" "@runtest" (CWD=/home/opam/.opam/4.14/.opam-switch/build/sihl-type.0.2.0)
- (cd _build/default && /home/opam/.opam/4.14/bin/ocamlc.opt -w -40 -g -bin-annot -I sihl-type/src/.sihl_type.objs/byte -I /home/opam/.opam/4.14/lib/alcotest -I /home/opam/.opam/4.14/lib/alcotest/engine -I /home/opam/.opam/4.14/lib/alcotest/stdlib_ext -I /home/opam/.opam/4.14/lib/angstrom -I /home/opam/.opam/4.14/lib/astring -I /home/opam/.opam/4.14/lib/base -I /home/opam/.opam/4.14/lib/base/base_internalhash_types -I /home/opam/.opam/4.14/lib/base/caml -I /home/opam/.opam/4.14/lib/base/shadow_stdlib -I /home/opam/.opam/4.14/lib/base64 -I /home/opam/.opam/4.14/lib/bigstringaf -I /home/opam/.opam/4.14/lib/bytes -I /home/opam/.opam/4.14/lib/caqti -I /home/opam/.opam/4.14/lib/caqti-lwt -I /home/opam/.opam/4.14/lib/cmdliner -I /home/opam/.opam/4.14/lib/conformist -I /home/opam/.opam/4.14/lib/containers -I /home/opam/.opam/4.14/lib/containers/domain -I /home/opam/.opam/4.14/lib/containers/monomorphic -I /home/opam/.opam/4.14/lib/cstruct -I /home/opam/.opam/4.14/lib/digestif -I /home/opam/.opam/4.14/lib/either -I /home/opam/.opam/4.14/lib/eqaf -I /home/opam/.opam/4.14/lib/eqaf/bigstring -I /home/opam/.opam/4.14/lib/eqaf/cstruct -I /home/opam/.opam/4.14/lib/faraday -I /home/opam/.opam/4.14/lib/faraday-lwt -I /home/opam/.opam/4.14/lib/faraday-lwt-unix -I /home/opam/.opam/4.14/lib/fieldslib -I /home/opam/.opam/4.14/lib/fmt -I /home/opam/.opam/4.14/lib/fmt/cli -I /home/opam/.opam/4.14/lib/fmt/tty -I /home/opam/.opam/4.14/lib/hmap -I /home/opam/.opam/4.14/lib/httpaf -I /home/opam/.opam/4.14/lib/httpaf-lwt-unix -I /home/opam/.opam/4.14/lib/jwto -I /home/opam/.opam/4.14/lib/logs -I /home/opam/.opam/4.14/lib/logs/fmt -I /home/opam/.opam/4.14/lib/logs/lwt -I /home/opam/.opam/4.14/lib/lwt -I /home/opam/.opam/4.14/lib/lwt/unix -I /home/opam/.opam/4.14/lib/magic-mime -I /home/opam/.opam/4.14/lib/mirage-crypto -I /home/opam/.opam/4.14/lib/mtime -I /home/opam/.opam/4.14/lib/mtime/clock -I /home/opam/.opam/4.14/lib/multipart-form-data -I /home/opam/.opam/4.14/lib/ocaml-compiler-libs/common -I /home/opam/.opam/4.14/lib/ocaml-compiler-libs/shadow -I /home/opam/.opam/4.14/lib/ocaml/compiler-libs -I /home/opam/.opam/4.14/lib/ocaml/threads -I /home/opam/.opam/4.14/lib/ocplib-endian -I /home/opam/.opam/4.14/lib/ocplib-endian/bigstring -I /home/opam/.opam/4.14/lib/opium -I /home/opam/.opam/4.14/lib/parsexp -I /home/opam/.opam/4.14/lib/ppx_derivers -I /home/opam/.opam/4.14/lib/ppx_deriving/api -I /home/opam/.opam/4.14/lib/ppx_deriving/create -I /home/opam/.opam/4.14/lib/ppx_deriving/enum -I /home/opam/.opam/4.14/lib/ppx_deriving/eq -I /home/opam/.opam/4.14/lib/ppx_deriving/fold -I /home/opam/.opam/4.14/lib/ppx_deriving/iter -I /home/opam/.opam/4.14/lib/ppx_deriving/make -I /home/opam/.opam/4.14/lib/ppx_deriving/map -I /home/opam/.opam/4.14/lib/ppx_deriving/ord -I /home/opam/.opam/4.14/lib/ppx_deriving/runtime -I /home/opam/.opam/4.14/lib/ppx_deriving/show -I /home/opam/.opam/4.14/lib/ppx_deriving/std -I /home/opam/.opam/4.14/lib/ppx_deriving_yojson/runtime -I /home/opam/.opam/4.14/lib/ppx_sexp_conv/runtime-lib -I /home/opam/.opam/4.14/lib/ppxlib -I /home/opam/.opam/4.14/lib/ppxlib/ast -I /home/opam/.opam/4.14/lib/ppxlib/astlib -I /home/opam/.opam/4.14/lib/ppxlib/print_diff -I /home/opam/.opam/4.14/lib/ppxlib/stdppx -I /home/opam/.opam/4.14/lib/ppxlib/traverse_builtins -I /home/opam/.opam/4.14/lib/ptime -I /home/opam/.opam/4.14/lib/ptime/clock -I /home/opam/.opam/4.14/lib/re -I /home/opam/.opam/4.14/lib/re/str -I /home/opam/.opam/4.14/lib/result -I /home/opam/.opam/4.14/lib/rock -I /home/opam/.opam/4.14/lib/safepass -I /home/opam/.opam/4.14/lib/seq -I /home/opam/.opam/4.14/lib/sexplib -I /home/opam/.opam/4.14/lib/sexplib0 -I /home/opam/.opam/4.14/lib/sihl-core -I /home/opam/.opam/4.14/lib/stdlib-shims -I /home/opam/.opam/4.14/lib/stringext -I /home/opam/.opam/4.14/lib/tsort -I /home/opam/.opam/4.14/lib/tyxml -I /home/opam/.opam/4.14/lib/tyxml/functor -I /home/opam/.opam/4.14/lib/uri -I /home/opam/.opam/4.14/lib/uuidm -I /home/opam/.opam/4.14/lib/uutf -I /home/opam/.opam/4.14/lib/yojson -no-alias-deps -open Sihl_type -o sihl-type/src/.sihl_type.objs/byte/sihl_type__Database.cmo -c -impl sihl-type/src/database.pp.ml)
- File "sihl-type/src/database.ml", line 11, characters 18-25:
- 11 |   let random () = Uuidm.v `V4
-                        ^^^^^^^
- Alert deprecated: Uuidm.v
- Use the version specific Uuidm.v* functions.
- File "sihl-type/src/database.ml", line 27, characters 16-30:
- 27 |     id_bytes |> Uuidm.of_bytes |> Option.to_result ~none:msg
-                      ^^^^^^^^^^^^^^
- Alert deprecated: Uuidm.of_bytes
- Use Uuidm.of_binary_string instead
- File "sihl-type/src/database.ml", line 31, characters 20-34:
- 31 |   let to_bytes id = Uuidm.to_bytes id
-                          ^^^^^^^^^^^^^^
- Alert deprecated: Uuidm.to_bytes
- Use Uuidm.to_binary_string instead
- (cd _build/default && /home/opam/.opam/4.14/bin/ocamlopt.opt -w -40 -g -I sihl-type/src/.sihl_type.objs/byte -I sihl-type/src/.sihl_type.objs/native -I /home/opam/.opam/4.14/lib/alcotest -I /home/opam/.opam/4.14/lib/alcotest/engine -I /home/opam/.opam/4.14/lib/alcotest/stdlib_ext -I /home/opam/.opam/4.14/lib/angstrom -I /home/opam/.opam/4.14/lib/astring -I /home/opam/.opam/4.14/lib/base -I /home/opam/.opam/4.14/lib/base/base_internalhash_types -I /home/opam/.opam/4.14/lib/base/caml -I /home/opam/.opam/4.14/lib/base/shadow_stdlib -I /home/opam/.opam/4.14/lib/base64 -I /home/opam/.opam/4.14/lib/bigstringaf -I /home/opam/.opam/4.14/lib/bytes -I /home/opam/.opam/4.14/lib/caqti -I /home/opam/.opam/4.14/lib/caqti-lwt -I /home/opam/.opam/4.14/lib/cmdliner -I /home/opam/.opam/4.14/lib/conformist -I /home/opam/.opam/4.14/lib/containers -I /home/opam/.opam/4.14/lib/containers/domain -I /home/opam/.opam/4.14/lib/containers/monomorphic -I /home/opam/.opam/4.14/lib/cstruct -I /home/opam/.opam/4.14/lib/digestif -I /home/opam/.opam/4.14/lib/either -I /home/opam/.opam/4.14/lib/eqaf -I /home/opam/.opam/4.14/lib/eqaf/bigstring -I /home/opam/.opam/4.14/lib/eqaf/cstruct -I /home/opam/.opam/4.14/lib/faraday -I /home/opam/.opam/4.14/lib/faraday-lwt -I /home/opam/.opam/4.14/lib/faraday-lwt-unix -I /home/opam/.opam/4.14/lib/fieldslib -I /home/opam/.opam/4.14/lib/fmt -I /home/opam/.opam/4.14/lib/fmt/cli -I /home/opam/.opam/4.14/lib/fmt/tty -I /home/opam/.opam/4.14/lib/hmap -I /home/opam/.opam/4.14/lib/httpaf -I /home/opam/.opam/4.14/lib/httpaf-lwt-unix -I /home/opam/.opam/4.14/lib/jwto -I /home/opam/.opam/4.14/lib/logs -I /home/opam/.opam/4.14/lib/logs/fmt -I /home/opam/.opam/4.14/lib/logs/lwt -I /home/opam/.opam/4.14/lib/lwt -I /home/opam/.opam/4.14/lib/lwt/unix -I /home/opam/.opam/4.14/lib/magic-mime -I /home/opam/.opam/4.14/lib/mirage-crypto -I /home/opam/.opam/4.14/lib/mtime -I /home/opam/.opam/4.14/lib/mtime/clock -I /home/opam/.opam/4.14/lib/multipart-form-data -I /home/opam/.opam/4.14/lib/ocaml-compiler-libs/common -I /home/opam/.opam/4.14/lib/ocaml-compiler-libs/shadow -I /home/opam/.opam/4.14/lib/ocaml/compiler-libs -I /home/opam/.opam/4.14/lib/ocaml/threads -I /home/opam/.opam/4.14/lib/ocplib-endian -I /home/opam/.opam/4.14/lib/ocplib-endian/bigstring -I /home/opam/.opam/4.14/lib/opium -I /home/opam/.opam/4.14/lib/parsexp -I /home/opam/.opam/4.14/lib/ppx_derivers -I /home/opam/.opam/4.14/lib/ppx_deriving/api -I /home/opam/.opam/4.14/lib/ppx_deriving/create -I /home/opam/.opam/4.14/lib/ppx_deriving/enum -I /home/opam/.opam/4.14/lib/ppx_deriving/eq -I /home/opam/.opam/4.14/lib/ppx_deriving/fold -I /home/opam/.opam/4.14/lib/ppx_deriving/iter -I /home/opam/.opam/4.14/lib/ppx_deriving/make -I /home/opam/.opam/4.14/lib/ppx_deriving/map -I /home/opam/.opam/4.14/lib/ppx_deriving/ord -I /home/opam/.opam/4.14/lib/ppx_deriving/runtime -I /home/opam/.opam/4.14/lib/ppx_deriving/show -I /home/opam/.opam/4.14/lib/ppx_deriving/std -I /home/opam/.opam/4.14/lib/ppx_deriving_yojson/runtime -I /home/opam/.opam/4.14/lib/ppx_sexp_conv/runtime-lib -I /home/opam/.opam/4.14/lib/ppxlib -I /home/opam/.opam/4.14/lib/ppxlib/ast -I /home/opam/.opam/4.14/lib/ppxlib/astlib -I /home/opam/.opam/4.14/lib/ppxlib/print_diff -I /home/opam/.opam/4.14/lib/ppxlib/stdppx -I /home/opam/.opam/4.14/lib/ppxlib/traverse_builtins -I /home/opam/.opam/4.14/lib/ptime -I /home/opam/.opam/4.14/lib/ptime/clock -I /home/opam/.opam/4.14/lib/re -I /home/opam/.opam/4.14/lib/re/str -I /home/opam/.opam/4.14/lib/result -I /home/opam/.opam/4.14/lib/rock -I /home/opam/.opam/4.14/lib/safepass -I /home/opam/.opam/4.14/lib/seq -I /home/opam/.opam/4.14/lib/sexplib -I /home/opam/.opam/4.14/lib/sexplib0 -I /home/opam/.opam/4.14/lib/sihl-core -I /home/opam/.opam/4.14/lib/stdlib-shims -I /home/opam/.opam/4.14/lib/stringext -I /home/opam/.opam/4.14/lib/tsort -I /home/opam/.opam/4.14/lib/tyxml -I /home/opam/.opam/4.14/lib/tyxml/functor -I /home/opam/.opam/4.14/lib/uri -I /home/opam/.opam/4.14/lib/uuidm -I /home/opam/.opam/4.14/lib/uutf -I /home/opam/.opam/4.14/lib/yojson -intf-suffix .ml -no-alias-deps -open Sihl_type -o sihl-type/src/.sihl_type.objs/native/sihl_type__Database.cmx -c -impl sihl-type/src/database.pp.ml)
- File "sihl-type/src/database.ml", line 11, characters 18-25:
- 11 |   let random () = Uuidm.v `V4
-                        ^^^^^^^
- Alert deprecated: Uuidm.v
- Use the version specific Uuidm.v* functions.
- File "sihl-type/src/database.ml", line 27, characters 16-30:
- 27 |     id_bytes |> Uuidm.of_bytes |> Option.to_result ~none:msg
-                      ^^^^^^^^^^^^^^
- Alert deprecated: Uuidm.of_bytes
- Use Uuidm.of_binary_string instead
- File "sihl-type/src/database.ml", line 31, characters 20-34:
- 31 |   let to_bytes id = Uuidm.to_bytes id
-                          ^^^^^^^^^^^^^^
- Alert deprecated: Uuidm.to_bytes
- Use Uuidm.to_binary_string instead
- (cd _build/default/sihl-type/test && ./jwt.exe)
- Testing `jwt'.
- This run has ID `9Q2ZSN03'.
- 
-   [OK]          jwt          0   is not expired.
-   [OK]          jwt          1   is expired.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/jwt'.
- Test Successful in 0.001s. 2 tests run.
- (cd _build/default/sihl-type/test && ./regex.exe)
- Testing `regex'.
- This run has ID `1U82UY9R'.
- 
-   [OK]          regex          0   extract.
-   [OK]          regex          1   extract complex.
-   [OK]          regex          2   test 1.
-   [OK]          regex          3   test 2.
-   [OK]          regex          4   test 3.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/regex'.
- Test Successful in 0.001s. 5 tests run.
- (cd _build/default/sihl-type/test && ./utils.exe)
- Testing `utils'.
- This run has ID `V6GP8TZ2'.
- 
-   [OK]          utils          0   parse ptime.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/utils'.
- Test Successful in 0.000s. 1 test run.
- (cd _build/default/sihl-type/test && ./web.exe)
- Testing `web'.
- This run has ID `9UK806VG'.
- 
-   [OK]          web          0   prefix path.
-   [OK]          web          1   prefix route.
-   [OK]          web          2   prefix route trailing slash prefix.
-   [OK]          web          3   prefix route trailing slash.
-   [OK]          web          4   router prefix.
-   [OK]          web          5   router middleware.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/web'.
- Test Successful in 0.002s. 6 tests run.
- (cd _build/default/sihl-type/test && ./session.exe)
- Testing `session'.
- This run has ID `8WP2Q68K'.
- 
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/session'.
- Test Successful in 0.000s. 0 test run.
- (cd _build/default/sihl-type/test && ./queue.exe)
- Testing `queue'.
- This run has ID `JU3QCD0N'.
- 
-   [OK]          queue          0   should job run.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/queue'.
- Test Successful in 0.000s. 1 test run.
- (cd _build/default/sihl-type/test && ./user.exe)
- Testing `user'.
- This run has ID `6DRT8LNY'.
- 
-   [OK]          user          0   validate valid password.
-   [OK]          user          1   validate invalid password.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/user'.
- Test Successful in 0.000s. 2 tests run.
- (cd _build/default/sihl-type/test && ./email.exe)
- Testing `email'.
- This run has ID `180LK6DG'.
- 
-   [OK]          email          0   render email simple.
-   [OK]          email          1   render email complex.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/email'.
- Test Successful in 0.000s. 2 tests run.
- (cd _build/default/sihl-type/test && ./encryption.exe)
- Testing `encryption'.
- This run has ID `7UCCCPTC'.
- 
-   [OK]          encryption          0   xor empty.
-   [OK]          encryption          1   xor valid.
-   [OK]          encryption          2   xor length differs.
-   [OK]          encryption          3   decrypt with salt empty.
-   [OK]          encryption          4   decrypt with salt valid.
-   [OK]          encryption          5   decrypt with salt length differs.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/encryption'.
- Test Successful in 0.001s. 6 tests run.
- (cd _build/default/sihl-type/test && ./ql.exe)
- Testing `ql'.
- This run has ID `9HN848NL'.
- 
-   [OK]          query language          0   to string limit offset.
-   [OK]          query language          1   to string sort.
-   [OK]          query language          2   to string filter.
-   [OK]          query language          3   to string.
-   [OK]          query language          4   to sql limit offset.
-   [OK]          query language          5   to sql sort.
-   [OK]          query language          6   to sql filter.
-   [OK]          query language          7   to sql filter with partial whitel...
-   [OK]          query language          8   to sql.
-   [OK]          query language          9   to sql fragments.
-   [OK]          query language         10   of string empty sort.
-   [OK]          query language         11   of string limit offset.
-   [OK]          query language         12   of string sort.
-   [OK]          query language         13   of string filter.
-   [OK]          query language         14   of string.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/ql'.
- Test Successful in 0.002s. 15 tests run.
- (cd _build/default/sihl-type/test && ./http.exe)
- Testing `http'.
- This run has ID `9QTRGHWP'.
- 
-   [OK]          http          0   require url encoded body.
-   [OK]          http          1   require tuple url encoded body.
- 
- Full test results in `~/.opam/4.14/.opam-switch/build/sihl-type.0.2.0/_build/default/sihl-type/test/_build/_tests/http'.
- Test Successful in 0.000s. 2 tests run.
-> compiled  sihl-type.0.2.0
-> removed   sihl-type.0.2.0
-> installed sihl-type.0.2.0
Done.
# To update the current shell environment, run: eval $(opam env)
2026-01-27 21:30.55 ---> saved as "939cfc6e513e164e682003edfa084c2dea505d7cd0d481dd223936f7c53f499c"
Job succeeded
2026-01-27 21:31.06: Job succeeded