(for PR #28521)

2026-04-27 07:45.26: New job: build lichess_api.1.0.2, lower-bounds, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/28521/head (d524ea6c8a2ed6050068c8cedb293e595330dc67)
                              on debian-13-ocaml-5.5-beta1/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/28521/head" && git reset --hard d524ea6c
git fetch origin master
git merge --no-edit d5058a91d400180e2118d7eeefa040cfcee45d2c
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-13-ocaml-5.5-beta1@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6
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 lichess_api.1.0.2 1.0.2
RUN opam reinstall lichess_api.1.0.2; \
    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" != 'lichess_api.1.0.2' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1
ENV OPAMCRITERIA="+removed,+count[version-lag,solution]"
ENV OPAMFIXUPCRITERIA="+removed,+count[version-lag,solution]"
ENV OPAMUPGRADECRITERIA="+removed,+count[version-lag,solution]"
RUN opam reinstall lichess_api.1.0.2; \
    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" != 'lichess_api.1.0.2' && 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-04-27 07:45.26: Using cache hint "ocaml/opam:debian-13-ocaml-5.5-beta1@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6-lichess_api.1.0.2-d524ea6c8a2ed6050068c8cedb293e595330dc67"
2026-04-27 07:45.26: Using OBuilder spec:
((from ocaml/opam:debian-13-ocaml-5.5-beta1@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6)
 (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 lichess_api.1.0.2 1.0.2"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall lichess_api.1.0.2;\
             \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\" != 'lichess_api.1.0.2' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
 (env OPAMCRITERIA +removed,+count[version-lag,solution])
 (env OPAMFIXUPCRITERIA +removed,+count[version-lag,solution])
 (env OPAMUPGRADECRITERIA +removed,+count[version-lag,solution])
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall lichess_api.1.0.2;\
             \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\" != 'lichess_api.1.0.2' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
)

2026-04-27 07:45.26: Connecting to build cluster…
2026-04-27 07:45.26: Waiting for resource in pool OCluster
2026-04-27 07:59.55: Waiting for worker…
2026-04-27 08:02.12: Got resource from pool OCluster
Building on eumache.caelum.ci.dev
All commits already cached
HEAD is now at d5058a91d4 Merge pull request #29801 from YuriyKrasilnikov/opam-publish-idna.0.4.0
Merge made by the 'ort' strategy.
 packages/chess_com_api/chess_com_api.1.0.2/opam | 45 ++++++++++++++++++++
 packages/lichess_api/lichess_api.1.0.2/opam     | 45 ++++++++++++++++++++
 packages/pgn_parser/pgn_parser.1.0.2/opam       | 55 +++++++++++++++++++++++++
 3 files changed, 145 insertions(+)
 create mode 100644 packages/chess_com_api/chess_com_api.1.0.2/opam
 create mode 100644 packages/lichess_api/lichess_api.1.0.2/opam
 create mode 100644 packages/pgn_parser/pgn_parser.1.0.2/opam

(from ocaml/opam:debian-13-ocaml-5.5-beta1@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6)
Unable to find image 'ocaml/opam:debian-13-ocaml-5.5-beta1@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6' locally
docker.io/ocaml/opam@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6: Pulling from ocaml/opam
3b32e3bb7338: Pulling fs layer
745aa02d649b: Pulling fs layer
bc737f5d3c43: Pulling fs layer
435aae15a5aa: Pulling fs layer
0c18c39f6bae: Pulling fs layer
eef74b82df23: Pulling fs layer
f7d9cf0406d8: Pulling fs layer
01a1dc37e798: Pulling fs layer
4960811e07ec: Pulling fs layer
be2894c36d5e: Pulling fs layer
b5a017ae191d: Pulling fs layer
3ba39ce4e9c9: Pulling fs layer
1db570dbe1c8: Pulling fs layer
435aae15a5aa: Waiting
753bb4b44994: Pulling fs layer
f7d9cf0406d8: Waiting
01a1dc37e798: Waiting
b5a1e811909d: Pulling fs layer
4960811e07ec: Waiting
6f3d83ba47b6: Pulling fs layer
002305272cbf: Pulling fs layer
249535cd82cd: Pulling fs layer
be2894c36d5e: Waiting
b5a1e811909d: Waiting
b5a017ae191d: Waiting
6f3d83ba47b6: Waiting
87fe8c2a0989: Pulling fs layer
3ba39ce4e9c9: Waiting
1db570dbe1c8: Waiting
0c18c39f6bae: Waiting
753bb4b44994: Waiting
b6932f04a343: Pulling fs layer
002305272cbf: Waiting
17b274223ca8: Pulling fs layer
87fe8c2a0989: Waiting
4f4fb700ef54: Pulling fs layer
249535cd82cd: Waiting
b6932f04a343: Waiting
17b274223ca8: Waiting
924952a8fbf8: Pulling fs layer
4f4fb700ef54: Waiting
17671b650f63: Pulling fs layer
924952a8fbf8: Waiting
9fe75d873195: Pulling fs layer
24216535046d: Pulling fs layer
17671b650f63: Waiting
9fe75d873195: Waiting
ac2e1c9e90df: Pulling fs layer
c2126be13b26: Pulling fs layer
24216535046d: Waiting
ac2e1c9e90df: Waiting
01ff22a5eb70: Pulling fs layer
50415235a68f: Pulling fs layer
c2126be13b26: Waiting
01ff22a5eb70: Waiting
deb6182b549b: Pulling fs layer
ad728fb9a18c: Pulling fs layer
50415235a68f: Waiting
deb6182b549b: Waiting
a36bcae85a3d: Pulling fs layer
1c746fdc6a3a: Pulling fs layer
ad728fb9a18c: Waiting
a36bcae85a3d: Waiting
4351b787b295: Pulling fs layer
380abb093977: Pulling fs layer
1c746fdc6a3a: Waiting
4351b787b295: Waiting
0fc1b10f3fd9: Pulling fs layer
966bc35978c3: Pulling fs layer
380abb093977: Waiting
0fc1b10f3fd9: Waiting
ae53b61ccb9e: Pulling fs layer
966bc35978c3: Waiting
d8ada9072f1a: Pulling fs layer
ae53b61ccb9e: Waiting
d8ada9072f1a: Waiting
6a1b081b98a3: Pulling fs layer
32a4a4edd914: Pulling fs layer
6a1b081b98a3: Waiting
51561b4147fc: Pulling fs layer
23328e1884b9: Pulling fs layer
120c50bc5d19: Pulling fs layer
628c53885d4c: Pulling fs layer
44ef7e84e1ef: Pulling fs layer
0ebf89ef9ee0: Pulling fs layer
32a4a4edd914: Waiting
51561b4147fc: Waiting
23328e1884b9: Waiting
120c50bc5d19: Waiting
628c53885d4c: Waiting
44ef7e84e1ef: Waiting
0ebf89ef9ee0: Waiting
745aa02d649b: Verifying Checksum
745aa02d649b: Download complete
bc737f5d3c43: Verifying Checksum
bc737f5d3c43: Download complete
0c18c39f6bae: Download complete
3b32e3bb7338: Verifying Checksum
3b32e3bb7338: Download complete
f7d9cf0406d8: Verifying Checksum
f7d9cf0406d8: Download complete
01a1dc37e798: Verifying Checksum
01a1dc37e798: Download complete
4960811e07ec: Verifying Checksum
4960811e07ec: Download complete
be2894c36d5e: Verifying Checksum
be2894c36d5e: Download complete
eef74b82df23: Download complete
3ba39ce4e9c9: Verifying Checksum
3ba39ce4e9c9: Download complete
b5a017ae191d: Verifying Checksum
b5a017ae191d: Download complete
1db570dbe1c8: Verifying Checksum
1db570dbe1c8: Download complete
753bb4b44994: Verifying Checksum
753bb4b44994: Download complete
b5a1e811909d: Verifying Checksum
b5a1e811909d: Download complete
6f3d83ba47b6: Verifying Checksum
6f3d83ba47b6: Download complete
435aae15a5aa: Verifying Checksum
435aae15a5aa: Download complete
002305272cbf: Verifying Checksum
002305272cbf: Download complete
3b32e3bb7338: Pull complete
745aa02d649b: Pull complete
bc737f5d3c43: Pull complete
249535cd82cd: Verifying Checksum
249535cd82cd: Download complete
87fe8c2a0989: Verifying Checksum
87fe8c2a0989: Download complete
b6932f04a343: Verifying Checksum
b6932f04a343: Download complete
17b274223ca8: Verifying Checksum
17b274223ca8: Download complete
4f4fb700ef54: Verifying Checksum
4f4fb700ef54: Download complete
924952a8fbf8: Verifying Checksum
924952a8fbf8: Download complete
17671b650f63: Verifying Checksum
17671b650f63: Download complete
9fe75d873195: Verifying Checksum
9fe75d873195: Download complete
435aae15a5aa: Pull complete
24216535046d: Verifying Checksum
24216535046d: Download complete
0c18c39f6bae: Pull complete
ac2e1c9e90df: Verifying Checksum
ac2e1c9e90df: Download complete
c2126be13b26: Verifying Checksum
c2126be13b26: Download complete
01ff22a5eb70: Verifying Checksum
01ff22a5eb70: Download complete
50415235a68f: Verifying Checksum
50415235a68f: Download complete
deb6182b549b: Verifying Checksum
deb6182b549b: Download complete
ad728fb9a18c: Verifying Checksum
ad728fb9a18c: Download complete
a36bcae85a3d: Verifying Checksum
a36bcae85a3d: Download complete
1c746fdc6a3a: Verifying Checksum
1c746fdc6a3a: Download complete
380abb093977: Download complete
966bc35978c3: Verifying Checksum
966bc35978c3: Download complete
ae53b61ccb9e: Download complete
d8ada9072f1a: Verifying Checksum
d8ada9072f1a: Download complete
6a1b081b98a3: Download complete
32a4a4edd914: Verifying Checksum
32a4a4edd914: Download complete
51561b4147fc: Verifying Checksum
51561b4147fc: Download complete
23328e1884b9: Verifying Checksum
23328e1884b9: Download complete
120c50bc5d19: Verifying Checksum
120c50bc5d19: Download complete
0fc1b10f3fd9: Verifying Checksum
0fc1b10f3fd9: Download complete
628c53885d4c: Download complete
44ef7e84e1ef: Download complete
0ebf89ef9ee0: Download complete
eef74b82df23: Pull complete
f7d9cf0406d8: Pull complete
01a1dc37e798: Pull complete
4960811e07ec: Pull complete
be2894c36d5e: Pull complete
b5a017ae191d: Pull complete
3ba39ce4e9c9: Pull complete
1db570dbe1c8: Pull complete
753bb4b44994: Pull complete
b5a1e811909d: Pull complete
6f3d83ba47b6: Pull complete
002305272cbf: Pull complete
249535cd82cd: Pull complete
87fe8c2a0989: Pull complete
b6932f04a343: Pull complete
17b274223ca8: Pull complete
4f4fb700ef54: Pull complete
924952a8fbf8: Pull complete
17671b650f63: Pull complete
9fe75d873195: Pull complete
24216535046d: Pull complete
ac2e1c9e90df: Pull complete
c2126be13b26: Pull complete
01ff22a5eb70: Pull complete
50415235a68f: Pull complete
deb6182b549b: Pull complete
ad728fb9a18c: Pull complete
a36bcae85a3d: Pull complete
1c746fdc6a3a: Pull complete
4351b787b295: Verifying Checksum
4351b787b295: Download complete
4351b787b295: Pull complete
380abb093977: Pull complete
0fc1b10f3fd9: Pull complete
966bc35978c3: Pull complete
ae53b61ccb9e: Pull complete
d8ada9072f1a: Pull complete
6a1b081b98a3: Pull complete
32a4a4edd914: Pull complete
51561b4147fc: Pull complete
23328e1884b9: Pull complete
120c50bc5d19: Pull complete
628c53885d4c: Pull complete
44ef7e84e1ef: Pull complete
0ebf89ef9ee0: Pull complete
Digest: sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6
Status: Downloaded newer image for ocaml/opam@sha256:2f03876e840edf3bcf2cd33a6b5b1e9ee40ad45e5d26f5be08f5d20a90f4bcf6
2026-04-27 08:02.18 ---> using "603f02c023a1426d4a02d87570a93b0933bb94d7f12e9f446094d14bd1f75796" 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-04-27 08:02.18 ---> using "8ce252bfd2c4cf43a63a513025094ad47f7fe6cf78104b2f6dc84d2ccba189d7" 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 ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[beta] no changes from git+https://github.com/ocaml/ocaml-beta-repository
[default] Initialised
2026-04-27 08:02.18 ---> using "65103e86f93946d6fffc139b5128a8f8f419133508ace1b49b5ca6c6bfb41888" 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.1
# 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         2 (version-controlled)
# pinned               1 (version)
# current-switch       5.5~beta1
# invariant            ["ocaml-base-compiler" {>= "5.5.0~beta1"}]
# compiler-packages    compiler-cloning.enabled, ocaml-base-compiler.5.5.0~beta1, ocaml-compiler.5.5.0~beta1, ocaml-options-vanilla.1
# ocaml:native         true
# ocaml:native-tools   true
# ocaml:native-dynlink true
# ocaml:stubsdir       /home/opam/.opam/5.5~beta1/lib/ocaml/../stublibs:/home/opam/.opam/5.5~beta1/lib/ocaml/stublibs:/home/opam/.opam/5.5~beta1/lib/ocaml
# ocaml:preinstalled   false
# ocaml:compiler       5.5.0~beta1
# ocaml-compiler:cloned false
# ocaml-compiler:clone-source 
# ocaml-compiler:clone-mechanism 
2026-04-27 08:02.18 ---> using "7163d9da28693b30b794bf44b1e4b9442e8bb15713526255cdecf572aba2ad74" 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-04-27 08:02.18 ---> using "16ab57e36a0ab7eab172ccff2678d7fbd1b69103081527d595051c8b3b2afe92" from cache

/home/opam: (copy (src .) (dst opam-repository/))
2026-04-27 08:02.23 ---> saved as "8c504bc8c5a1fced3a7a2fc2062f1e2d0c6d0877fc61bc0d0a09bc1f77611c3f"

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-04-27 08:02.45 ---> saved as "46075ed7387a3fcc72ee72ed1eeb271214bd3870d7594f430fd65542ba8c82dd"

/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]
- Fetched 90.7 kB in 0s (688 kB/s)
- Reading package lists...
- 
2026-04-27 08:02.46 ---> saved as "7025c6745338c5b76761c2e4780bd9e36c28a1452e931a900758fd02938d8b61"

/home/opam: (run (shell "opam pin add -k version -yn lichess_api.1.0.2 1.0.2"))
lichess_api is now pinned to version 1.0.2
2026-04-27 08:02.47 ---> saved as "f475bd9f3b590d25303a4761fb2c11a106065694bdba7ece1319fb9f1fb6f547"

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall lichess_api.1.0.2;\
                        \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\" != 'lichess_api.1.0.2' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
lichess_api.1.0.2 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 68 packages
  - install angstrom                0.16.1         [required by uri]
  - install asn1-combinators        0.3.2          [required by x509]
  - install astring                 0.8.5          [required by conduit]
  - install base                    v0.17.3        [required by ppx_sexp_conv]
  - install base-bytes              base           [required by ocplib-endian]
  - install base64                  3.5.2          [required by cohttp]
  - install bigstringaf             0.10.0         [required by angstrom]
  - install bos                     0.3.0          [required by ca-certs]
  - install ca-certs                1.0.1          [required by conduit-lwt-unix]
  - install cmdliner                2.1.1          [required by cohttp-lwt-unix]
  - install cohttp                  6.2.1          [required by cohttp-lwt-unix]
  - install cohttp-lwt              6.2.1          [required by cohttp-lwt-unix]
  - install cohttp-lwt-unix         6.2.1          [required by lichess_api]
  - install conduit                 8.0.0          [required by conduit-lwt]
  - install conduit-lwt             8.0.0          [required by cohttp-lwt-unix]
  - install conduit-lwt-unix        8.0.0          [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-pkg-config         4              [required by zarith]
  - install cppo                    1.8.0          [required by lwt]
  - install csexp                   1.5.2          [required by dune-configurator]
  - install digestif                1.3.0          [required by ca-certs]
  - install domain-name             0.5.0          [required by ipaddr]
  - install dune                    3.22.2         [required by lichess_api]
  - install dune-configurator       3.22.2         [required by base, lwt, mirage-crypto]
  - install duration                0.3.1          [required by mirage-crypto-rng]
  - install eqaf                    0.10           [required by digestif, mirage-crypto]
  - install fmt                     0.11.0         [required by cohttp-lwt-unix]
  - install fpath                   0.7.3          [required by ca-certs]
  - install gmap                    0.3.0          [required by x509]
  - install http                    6.2.1          [required by cohttp-lwt-unix]
  - install ipaddr                  5.6.2          [required by cohttp-lwt, cohttp, conduit-lwt-unix]
  - install ipaddr-sexp             5.6.2          [required by conduit-lwt-unix]
  - install kdf                     1.0.0          [required by x509]
  - install lichess_api             1.0.2 (pinned)
  - install logs                    0.10.0         [required by cohttp-lwt-unix]
  - install lwt                     6.1.1          [required by lichess_api]
  - install lwt_ppx                 6.1.0          [required by lichess_api]
  - install macaddr                 5.6.2          [required by ipaddr]
  - install magic-mime              1.3.1          [required by cohttp-lwt-unix]
  - install mirage-crypto           2.1.0          [required by ca-certs]
  - install mirage-crypto-ec        2.1.0          [required by x509]
  - install mirage-crypto-pk        2.1.0          [required by x509]
  - install mirage-crypto-rng       2.1.0          [required by x509]
  - install ocaml-compiler-libs     v0.17.0        [required by ppxlib]
  - install ocaml-syntax-shims      1.0.0          [required by angstrom]
  - install ocaml_intrinsics_kernel v0.17.1        [required by base]
  - 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 ohex                    0.2.0          [required by ca-certs]
  - install pgn_parser              1.0.2          [required by lichess_api]
  - install ppx_derivers            1.2.1          [required by ppxlib]
  - install ppx_sexp_conv           v0.17.1        [required by cohttp-lwt-unix]
  - install ppxlib                  0.38.0         [required by lwt_ppx]
  - install ppxlib_jane             v0.17.4        [required by ppx_sexp_conv]
  - install ptime                   1.2.0          [required by ca-certs]
  - install re                      1.14.0         [required by cohttp]
  - install rresult                 0.7.0          [required by bos]
  - install sexplib0                v0.17.0        [required by cohttp-lwt, cohttp, conduit-lwt]
  - install stdlib-shims            0.3.0          [required by ppxlib]
  - install stringext               1.6.0          [required by cohttp]
  - install topkg                   1.1.1          [required by logs]
  - install uri                     4.4.0          [required by cohttp-lwt, cohttp, conduit-lwt-unix]
  - install uri-sexp                4.4.0          [required by cohttp]
  - install x509                    1.0.6          [required by ca-certs]
  - install yojson                  3.0.0          [required by lichess_api]
  - install zarith                  1.14           [required by mirage-crypto-pk]

The following system packages will first need to be installed:
    libgmp-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" "libgmp-dev" "pkg-config"
- Selecting previously unselected package libgmpxx4ldbl: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 ... 20654 files and directories currently installed.)
- Preparing to unpack .../0-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 .../1-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 .../2-libpkgconf3_1.8.1-4_amd64.deb ...
- Unpacking libpkgconf3:amd64 (1.8.1-4) ...
- Selecting previously unselected package pkgconf-bin.
- Preparing to unpack .../3-pkgconf-bin_1.8.1-4_amd64.deb ...
- Unpacking pkgconf-bin (1.8.1-4) ...
- Selecting previously unselected package pkgconf:amd64.
- Preparing to unpack .../4-pkgconf_1.8.1-4_amd64.deb ...
- Unpacking pkgconf:amd64 (1.8.1-4) ...
- Selecting previously unselected package pkg-config:amd64.
- Preparing to unpack .../5-pkg-config_1.8.1-4_amd64.deb ...
- Unpacking pkg-config:amd64 (1.8.1-4) ...
- Setting up libpkgconf3:amd64 (1.8.1-4) ...
- Setting up libgmpxx4ldbl:amd64 (2:6.3.0+dfsg-3) ...
- Setting up pkgconf-bin (1.8.1-4) ...
- 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+deb13u2) ...

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved angstrom.0.16.1  (cached)
-> retrieved asn1-combinators.0.3.2  (cached)
-> retrieved astring.0.8.5  (cached)
-> retrieved base.v0.17.3  (cached)
-> retrieved base64.3.5.2  (cached)
-> retrieved bigstringaf.0.10.0  (cached)
-> retrieved bos.0.3.0  (cached)
-> retrieved ca-certs.1.0.1  (cached)
-> retrieved cmdliner.2.1.1  (cached)
-> retrieved cohttp.6.2.1, cohttp-lwt.6.2.1, cohttp-lwt-unix.6.2.1, http.6.2.1  (cached)
-> retrieved conduit.8.0.0, conduit-lwt.8.0.0, conduit-lwt-unix.8.0.0  (cached)
-> retrieved conf-gmp.5  (cached)
-> retrieved conf-gmp-powm-sec.4  (cached)
-> retrieved cppo.1.8.0  (cached)
-> retrieved csexp.1.5.2  (cached)
-> installed conf-gmp.5
-> installed conf-pkg-config.4
-> installed conf-gmp-powm-sec.4
-> retrieved digestif.1.3.0  (cached)
-> retrieved domain-name.0.5.0  (cached)
-> retrieved dune.3.22.2, dune-configurator.3.22.2  (cached)
-> retrieved duration.0.3.1  (cached)
-> retrieved eqaf.0.10  (cached)
-> retrieved fmt.0.11.0  (cached)
-> retrieved fpath.0.7.3  (cached)
-> retrieved gmap.0.3.0  (cached)
-> retrieved ipaddr.5.6.2, ipaddr-sexp.5.6.2, macaddr.5.6.2  (cached)
-> retrieved kdf.1.0.0  (cached)
-> installed cmdliner.2.1.1
-> retrieved lichess_api.1.0.2, pgn_parser.1.0.2  (https://github.com/Ckaf/pgn_parser/archive/v1.0.2.tar.gz)
-> retrieved logs.0.10.0  (cached)
-> retrieved lwt.6.1.1  (cached)
-> retrieved lwt_ppx.6.1.0  (cached)
-> retrieved magic-mime.1.3.1  (cached)
-> retrieved mirage-crypto.2.1.0, mirage-crypto-ec.2.1.0, mirage-crypto-pk.2.1.0, mirage-crypto-rng.2.1.0  (cached)
-> retrieved ocaml-compiler-libs.v0.17.0  (cached)
-> retrieved ocaml-syntax-shims.1.0.0  (cached)
-> retrieved ocaml_intrinsics_kernel.v0.17.1  (cached)
-> retrieved ocamlbuild.0.16.1  (cached)
-> retrieved ocamlfind.1.9.8  (cached)
-> retrieved ocplib-endian.1.2  (cached)
-> retrieved ohex.0.2.0  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved ppx_sexp_conv.v0.17.1  (cached)
-> retrieved ppxlib.0.38.0  (cached)
-> retrieved ppxlib_jane.v0.17.4  (cached)
-> retrieved ptime.1.2.0  (cached)
-> retrieved re.1.14.0  (cached)
-> retrieved rresult.0.7.0  (cached)
-> retrieved sexplib0.v0.17.0  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> retrieved stringext.1.6.0  (cached)
-> retrieved topkg.1.1.1  (cached)
-> retrieved uri.4.4.0, uri-sexp.4.4.0  (cached)
-> retrieved x509.1.0.6  (cached)
-> retrieved yojson.3.0.0  (cached)
-> retrieved zarith.1.14  (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed ocamlbuild.0.16.1
-> installed zarith.1.14
-> installed topkg.1.1.1
-> installed rresult.0.7.0
-> installed fmt.0.11.0
-> installed ptime.1.2.0
-> installed astring.0.8.5
-> installed fpath.0.7.3
-> installed dune.3.22.2
-> installed duration.0.3.1
-> installed gmap.0.3.0
-> installed base64.3.5.2
-> installed csexp.1.5.2
-> installed asn1-combinators.0.3.2
-> installed cppo.1.8.0
-> installed domain-name.0.5.0
-> installed eqaf.0.10
-> installed http.6.2.1
-> installed macaddr.5.6.2
-> installed magic-mime.1.3.1
-> installed ocaml-compiler-libs.v0.17.0
-> installed ocaml-syntax-shims.1.0.0
-> installed ocaml_intrinsics_kernel.v0.17.1
-> installed ohex.0.2.0
-> installed ppx_derivers.1.2.1
-> installed re.1.14.0
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.3.0
-> installed stringext.1.6.0
-> installed yojson.3.0.0
-> installed ocplib-endian.1.2
-> installed ipaddr.5.6.2
-> installed digestif.1.3.0
-> installed dune-configurator.3.22.2
-> installed bigstringaf.0.10.0
-> installed angstrom.0.16.1
-> installed mirage-crypto.2.1.0
-> installed kdf.1.0.0
-> installed lwt.6.1.1
-> installed uri.4.4.0
-> installed logs.0.10.0
-> installed mirage-crypto-rng.2.1.0
-> installed mirage-crypto-pk.2.1.0
-> installed base.v0.17.3
-> installed bos.0.3.0
-> installed mirage-crypto-ec.2.1.0
-> installed x509.1.0.6
-> installed ca-certs.1.0.1
-> installed ppxlib.0.38.0
-> installed ppxlib_jane.v0.17.4
-> installed lwt_ppx.6.1.0
-> installed ppx_sexp_conv.v0.17.1
-> installed uri-sexp.4.4.0
-> installed ipaddr-sexp.5.6.2
-> installed conduit.8.0.0
-> installed cohttp.6.2.1
-> installed conduit-lwt.8.0.0
-> installed cohttp-lwt.6.2.1
-> installed conduit-lwt-unix.8.0.0
-> installed cohttp-lwt-unix.6.2.1
-> installed pgn_parser.1.0.2
-> installed lichess_api.1.0.2
Done.
# To update the current shell environment, run: eval $(opam env)
2026-04-27 08:04.17 ---> saved as "77d338186864ee30be02a4e117285c0146984649d958f7ead717dd610ca94dd9"

/home/opam: (env OPAMCRITERIA +removed,+count[version-lag,solution])

/home/opam: (env OPAMFIXUPCRITERIA +removed,+count[version-lag,solution])

/home/opam: (env OPAMUPGRADECRITERIA +removed,+count[version-lag,solution])

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall lichess_api.1.0.2;\
                        \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\" != 'lichess_api.1.0.2' && 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:
=== remove 6 packages
  - remove    digestif                1.3.0                       [conflicts with dune]
  - remove    http                    6.2.1                       [conflicts with dune]
  - remove    kdf                     1.0.0                       [conflicts with dune]
  - remove    mirage-crypto-ec        2.1.0                       [conflicts with dune]
  - remove    ocaml-syntax-shims      1.0.0                       [conflicts with dune]
  - remove    ohex                    0.2.0                       [conflicts with dune]
=== downgrade 46 packages
  - downgrade angstrom                0.16.1 to 0.14.0            [uses dune]
  - downgrade asn1-combinators        0.3.2 to 0.2.6              [uses zarith]
  - downgrade base                    v0.17.3 to v0.17.0          [uses dune]
  - downgrade base64                  3.5.2 to 3.1.0              [upstream or system changes]
  - downgrade bigstringaf             0.10.0 to 0.5.0             [uses dune]
  - downgrade bos                     0.3.0 to 0.2.1              [uses fmt]
  - downgrade ca-certs                1.0.1 to 0.2.0              [uses bos]
  - downgrade cmdliner                2.1.1 to 1.0.4              [required by cohttp-lwt-unix]
  - downgrade cohttp                  6.2.1 to 5.1.0              [upstream or system changes]
  - downgrade cohttp-lwt              6.2.1 to 5.1.0              [required by cohttp-lwt-unix]
  - downgrade cohttp-lwt-unix         6.2.1 to 5.1.0              [required by lichess_api]
  - downgrade conduit                 8.0.0 to 6.1.0              [uses logs]
  - downgrade conduit-lwt             8.0.0 to 6.1.0              [required by cohttp-lwt-unix]
  - downgrade conduit-lwt-unix        8.0.0 to 6.1.0              [required by cohttp-lwt-unix]
  - downgrade conf-pkg-config         4 to 1.0                    [required by mirage-crypto]
  - downgrade cppo                    1.8.0 to 1.6.7              [uses dune]
  - downgrade csexp                   1.5.2 to 1.3.1              [uses dune]
  - downgrade domain-name             0.5.0 to 0.3.0              [uses fmt]
  - downgrade dune                    3.22.2 to 3.19.0            [required by lichess_api]
  - downgrade dune-configurator       3.22.2 to 2.9.3             [uses dune]
  - downgrade duration                0.3.1 to 0.2.1              [uses dune]
  - downgrade eqaf                    0.10 to 0.9                 [uses dune]
  - downgrade fmt                     0.11.0 to 0.9.0             [required by cohttp-lwt-unix]
  - downgrade ipaddr                  5.6.2 to 5.6.0              [uses dune]
  - downgrade ipaddr-sexp             5.6.2 to 5.6.0              [uses dune]
  - downgrade logs                    0.10.0 to 0.7.0             [required by cohttp-lwt-unix]
  - downgrade lwt_ppx                 6.1.0 to 6.0.0              [required by lichess_api]
  - downgrade macaddr                 5.6.2 to 5.6.0              [uses dune]
  - downgrade magic-mime              1.3.1 to 1.1.2              [required by cohttp-lwt-unix]
  - downgrade mirage-crypto           2.1.0 to 0.10.7             [uses dune]
  - downgrade mirage-crypto-pk        2.1.0 to 0.10.7             [uses zarith]
  - downgrade mirage-crypto-rng       2.1.0 to 0.10.7             [uses logs]
  - downgrade ocaml_intrinsics_kernel v0.17.1 to v0.17.0          [uses dune]
  - downgrade ocamlbuild              0.16.1 to 0.14.3            [required by fmt]
  - downgrade ocamlfind               1.9.8 to 1.9.6              [required by fmt]
  - downgrade ocplib-endian           1.2 to 1.1                  [upstream or system changes]
  - downgrade pgn_parser              1.0.2 to 1.0.0              [required by lichess_api]
  - downgrade ppxlib                  0.38.0 to 0.38.0~5.5preview [uses dune]
  - downgrade re                      1.14.0 to 1.9.0             [uses dune]
  - downgrade stdlib-shims            0.3.0 to 0.1.0              [uses dune]
  - downgrade topkg                   1.1.1 to 1.0.8              [required by fmt]
  - downgrade uri                     4.4.0 to 4.0.0              [uses dune]
  - downgrade uri-sexp                4.4.0 to 4.0.0              [uses dune]
  - downgrade x509                    1.0.6 to 0.11.2             [uses fmt]
  - downgrade yojson                  3.0.0 to 1.7.0              [required by lichess_api]
  - downgrade zarith                  1.14 to 1.7-1               [uses ocamlfind]
=== recompile 10 packages
  - recompile base-bytes              base                        [uses ocamlfind]
  - recompile gmap                    0.3.0                       [uses dune]
  - recompile lichess_api             1.0.2 (pinned)
  - recompile lwt                     6.1.1                       [uses dune]
  - recompile ocaml-compiler-libs     v0.17.0                     [uses dune]
  - recompile ppx_derivers            1.2.1                       [uses dune]
  - recompile ppx_sexp_conv           v0.17.1                     [uses dune]
  - recompile ppxlib_jane             v0.17.4                     [uses dune]
  - recompile sexplib0                v0.17.0                     [uses dune]
  - recompile stringext               1.6.0                       [uses dune]
=== install 20 packages
  - install   bigarray-compat         1.1.0                       [required by cstruct]
  - install   biniou                  1.2.2                       [required by yojson]
  - install   camlp-streams           5.0.1                       [required by biniou]
  - install   conf-perl               1                           [required by zarith]
  - install   cstruct                 6.0.0                       [required by asn1-combinators]
  - install   easy-format             1.3.3                       [required by yojson]
  - install   jsonm                   1.0.2                       [required by cohttp]
  - install   mirage-no-solo5         1 (deprecated)              [required by mirage-crypto-pk]
  - install   mirage-no-xen           1 (deprecated)              [required by mirage-crypto-pk]
  - install   mtime                   1.3.0                       [required by mirage-crypto-rng]
  - install   num                     1.6                         [required by sexplib]
  - install   ounit2                  2.2.6                       [required by qcheck-ounit]
  - install   parsexp                 v0.17.0                     [required by sexplib]
  - install   qcheck                  0.25                        [required by pgn_parser]
  - install   qcheck-core             0.25                        [required by qcheck]
  - install   qcheck-ounit            0.25                        [required by qcheck]
  - install   result                  1.5                         [required by dune-configurator]
  - install   seq                     0.3                         [required by re, ounit2]
  - install   sexplib                 v0.17.0                     [required by conduit]
  - install   uutf                    1.0.3                       [required by jsonm]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved angstrom.0.14.0  (cached)
-> retrieved asn1-combinators.0.2.6  (cached)
-> retrieved base.v0.17.0  (cached)
-> retrieved base64.3.1.0  (cached)
-> retrieved bigarray-compat.1.1.0  (cached)
-> retrieved bigstringaf.0.5.0  (cached)
-> retrieved biniou.1.2.2  (cached)
-> retrieved bos.0.2.1  (cached)
-> retrieved ca-certs.0.2.0  (cached)
-> retrieved camlp-streams.5.0.1  (cached)
-> retrieved cmdliner.1.0.4  (cached)
-> retrieved cohttp.5.1.0, cohttp-lwt.5.1.0, cohttp-lwt-unix.5.1.0  (cached)
-> retrieved conduit.6.1.0, conduit-lwt.6.1.0, conduit-lwt-unix.6.1.0  (cached)
-> retrieved cppo.1.6.7  (cached)
-> retrieved csexp.1.3.1  (cached)
-> installed conf-perl.1
-> retrieved cstruct.6.0.0  (cached)
-> retrieved domain-name.0.3.0  (cached)
-> retrieved dune.3.19.0  (cached)
-> retrieved dune-configurator.2.9.3  (cached)
-> retrieved duration.0.2.1  (cached)
-> retrieved easy-format.1.3.3  (cached)
-> retrieved eqaf.0.9  (cached)
-> retrieved fmt.0.9.0  (cached)
-> retrieved gmap.0.3.0  (cached)
-> retrieved ipaddr.5.6.0, ipaddr-sexp.5.6.0, macaddr.5.6.0  (cached)
-> retrieved jsonm.1.0.2  (cached)
-> retrieved logs.0.7.0  (cached)
-> retrieved lwt.6.1.1  (cached)
-> retrieved lwt_ppx.6.0.0  (cached)
-> retrieved magic-mime.1.1.2  (cached)
-> retrieved mirage-crypto.0.10.7, mirage-crypto-pk.0.10.7, mirage-crypto-rng.0.10.7  (cached)
-> installed mirage-no-solo5.1
-> installed mirage-no-xen.1
-> retrieved mtime.1.3.0  (cached)
-> retrieved num.1.6  (cached)
-> retrieved ocaml-compiler-libs.v0.17.0  (cached)
-> retrieved ocaml_intrinsics_kernel.v0.17.0  (cached)
-> retrieved ocamlbuild.0.14.3  (cached)
-> retrieved ocamlfind.1.9.6  (cached)
-> retrieved ocplib-endian.1.1  (cached)
-> retrieved ounit2.2.2.6  (cached)
-> retrieved parsexp.v0.17.0  (cached)
-> retrieved pgn_parser.1.0.0  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved ppx_sexp_conv.v0.17.1  (cached)
-> retrieved ppxlib.0.38.0~5.5preview  (cached)
-> retrieved ppxlib_jane.v0.17.4  (cached)
-> retrieved qcheck.0.25, qcheck-core.0.25, qcheck-ounit.0.25  (cached)
-> retrieved re.1.9.0  (cached)
-> retrieved result.1.5  (cached)
-> retrieved seq.0.3  (cached)
-> retrieved sexplib.v0.17.0  (cached)
-> retrieved sexplib0.v0.17.0  (cached)
-> retrieved stdlib-shims.0.1.0  (cached)
-> retrieved stringext.1.6.0  (cached)
-> retrieved topkg.1.0.8  (cached)
-> retrieved uri.4.0.0, uri-sexp.4.0.0  (cached)
-> retrieved uutf.1.0.3  (cached)
-> retrieved x509.0.11.2  (cached)
-> retrieved yojson.1.7.0  (cached)
-> retrieved zarith.1.7-1  (cached)
-> installed num.1.6
-> removed   lichess_api.1.0.2
-> removed   pgn_parser.1.0.2
-> removed   cohttp-lwt-unix.6.2.1
-> removed   cohttp-lwt.6.2.1
-> removed   cohttp.6.2.1
-> removed   conduit-lwt-unix.8.0.0
-> removed   ca-certs.1.0.1
-> removed   bos.0.3.0
-> removed   conduit-lwt.8.0.0
-> removed   conduit.8.0.0
-> removed   http.6.2.1
-> removed   ipaddr-sexp.5.6.2
-> removed   lwt_ppx.6.1.0
-> removed   magic-mime.1.3.1
-> removed   re.1.14.0
-> removed   uri-sexp.4.4.0
-> removed   ppx_sexp_conv.v0.17.1
-> removed   base.v0.17.3
-> removed   ocaml_intrinsics_kernel.v0.17.1
-> removed   ppxlib_jane.v0.17.4
-> removed   ppxlib.0.38.0
-> removed   ocaml-compiler-libs.v0.17.0
-> removed   ppx_derivers.1.2.1
-> removed   sexplib0.v0.17.0
-> removed   stdlib-shims.0.3.0
-> removed   uri.4.4.0
-> removed   angstrom.0.16.1
-> removed   bigstringaf.0.10.0
-> removed   ocaml-syntax-shims.1.0.0
-> removed   stringext.1.6.0
-> removed   x509.1.0.6
-> removed   asn1-combinators.0.3.2
-> removed   base64.3.5.2
-> removed   gmap.0.3.0
-> removed   ipaddr.5.6.2
-> removed   domain-name.0.5.0
-> removed   kdf.1.0.0
-> removed   macaddr.5.6.2
-> removed   mirage-crypto-ec.2.1.0
-> removed   mirage-crypto-pk.2.1.0
-> removed   mirage-crypto-rng.2.1.0
-> removed   digestif.1.3.0
-> removed   duration.0.3.1
-> removed   logs.0.10.0
-> removed   fmt.0.11.0
-> removed   cmdliner.2.1.1
-> removed   lwt.6.1.1
-> removed   mirage-crypto.2.1.0
-> removed   dune-configurator.3.22.2
-> removed   csexp.1.5.2
-> removed   eqaf.0.10
-> removed   ocplib-endian.1.2
-> removed   base-bytes.base
-> removed   cppo.1.8.0
-> removed   ohex.0.2.0
-> removed   topkg.1.1.1
-> removed   ocamlbuild.0.16.1
-> removed   yojson.3.0.0
-> removed   dune.3.22.2
-> removed   zarith.1.14
-> removed   conf-pkg-config.4
-> removed   ocamlfind.1.9.8
-> installed conf-pkg-config.1.0
-> installed dune.3.19.0
-> installed ocamlbuild.0.14.3
-> installed ocamlfind.1.9.6
-> installed base-bytes.base
-> installed bigarray-compat.1.1.0
-> installed bigstringaf.0.5.0
-> installed camlp-streams.5.0.1
-> installed duration.0.2.1
-> installed easy-format.1.3.3
-> installed gmap.0.3.0
-> installed macaddr.5.6.0
-> installed magic-mime.1.1.2
-> installed ocaml_intrinsics_kernel.v0.17.0
-> installed ppx_derivers.1.2.1
-> installed result.1.5
-> installed seq.0.3
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.1.0
-> installed stringext.1.6.0
-> installed cppo.1.6.7
-> installed ocaml-compiler-libs.v0.17.0
-> installed csexp.1.3.1
-> installed qcheck-core.0.25
-> installed cstruct.6.0.0
-> installed biniou.1.2.2
-> installed angstrom.0.14.0
-> installed ocplib-endian.1.1
-> installed base64.3.1.0
-> installed re.1.9.0
-> installed ounit2.2.2.6
-> installed cmdliner.1.0.4
-> installed eqaf.0.9
-> installed parsexp.v0.17.0
-> installed qcheck-ounit.0.25
-> installed qcheck.0.25
-> installed dune-configurator.2.9.3
-> installed sexplib.v0.17.0
-> installed zarith.1.7-1
-> installed yojson.1.7.0
-> installed uri.4.0.0
-> installed asn1-combinators.0.2.6
-> installed mirage-crypto.0.10.7
-> installed topkg.1.0.8
-> installed lwt.6.1.1
-> installed uutf.1.0.3
-> installed mtime.1.3.0
-> installed fmt.0.9.0
-> installed domain-name.0.3.0
-> installed ipaddr.5.6.0
-> installed jsonm.1.0.2
-> installed logs.0.7.0
-> installed mirage-crypto-rng.0.10.7
-> installed base.v0.17.0
-> installed mirage-crypto-pk.0.10.7
-> installed x509.0.11.2
-> installed bos.0.2.1
-> installed ca-certs.0.2.0
-> installed ppxlib.0.38.0~5.5preview
-> installed ppxlib_jane.v0.17.4
-> installed lwt_ppx.6.0.0
-> installed ppx_sexp_conv.v0.17.1
-> installed ipaddr-sexp.5.6.0
-> installed uri-sexp.4.0.0
-> installed conduit.6.1.0
-> installed cohttp.5.1.0
-> installed conduit-lwt.6.1.0
-> installed cohttp-lwt.5.1.0
-> installed conduit-lwt-unix.6.1.0
-> installed cohttp-lwt-unix.5.1.0
-> installed pgn_parser.1.0.0
[ERROR] The compilation of lichess_api.1.0.2 failed at "dune build -p lichess_api -j 71 @install".

#=== ERROR while compiling lichess_api.1.0.2 ==================================#
# context              2.5.1 | linux/x86_64 | ocaml-base-compiler.5.5.0~beta1 | pinned(https://github.com/Ckaf/pgn_parser/archive/v1.0.2.tar.gz)
# path                 ~/.opam/5.5~beta1/.opam-switch/build/lichess_api.1.0.2
# command              ~/.opam/opam-init/hooks/sandbox.sh build dune build -p lichess_api -j 71 @install
# exit-code            1
# env-file             ~/.opam/log/lichess_api-7-dd731a.env
# output-file          ~/.opam/log/lichess_api-7-dd731a.out
### output ###
# File "test/dune", line 36, characters 12-22:
# 36 |  (libraries pgn_parser lichess_api)
#                  ^^^^^^^^^^
# Error: Library "pgn_parser" not found.
# -> required by _build/default/test/test_integration.exe
# -> required by _build/install/default/bin/test_integration
# -> required by _build/default/lichess_api.install
# -> required by alias install
# File "test/dune", line 24, characters 12-22:
# 24 |  (libraries pgn_parser lichess_api lwt lwt.unix)
#                  ^^^^^^^^^^
# Error: Library "pgn_parser" not found.
# -> required by _build/default/test/test_lichess_api.exe
# -> required by _build/install/default/bin/test_lichess_api
# -> required by _build/default/lichess_api.install
# -> required by alias install
# File "test/dune", line 30, characters 12-22:
# 30 |  (libraries pgn_parser lichess_api)
#                  ^^^^^^^^^^
# Error: Library "pgn_parser" not found.
# -> required by _build/default/test/test_lichess_api_offline.exe
# -> required by _build/install/default/bin/test_lichess_api_offline
# -> required by _build/default/lichess_api.install
# -> required by alias install
# (cd _build/default && /home/opam/.opam/5.5~beta1/bin/ocamlopt.opt -w -40 -warn-error -A -g -I lib/.lichess_api.objs/byte -I lib/.lichess_api.objs/native -I /home/opam/.opam/5.5~beta1/lib/angstrom -I /home/opam/.opam/5.5~beta1/lib/astring -I /home/opam/.opam/5.5~beta1/lib/base64 -I /home/opam/.opam/5.5~beta1/lib/bigstringaf -I /home/opam/.opam/5.5~beta1/lib/biniou -I /home/opam/.opam/5.5~beta1/lib/bytes -I /home/opam/.opam/5.5~beta1/lib/camlp-streams -I /home/opam/.opam/5.5~beta1/lib/cohttp -I /home/opam/.opam/5.5~beta1/lib/cohttp-lwt -I /home/opam/.opam/5.5~beta1/lib/cohttp-lwt-unix -I /home/opam/.opam/5.5~beta1/lib/conduit -I /home/opam/.opam/5.5~beta1/lib/conduit-lwt -I /home/opam/.opam/5.5~beta1/lib/conduit-lwt-unix -I /home/opam/.opam/5.5~beta1/lib/domain-name -I /home/opam/.opam/5.5~beta1/lib/easy-format -I /home/opam/.opam/5.5~beta1/lib/fmt -I /home/opam/.opam/5.5~beta1/lib/ipaddr -I /home/opam/.opam/5.5~beta1/lib/ipaddr-sexp -I /home/opam/.opam/5.5~beta1/lib/ipaddr/unix -I /home/opam/.opam/5.5~beta1/lib/logs -I /home/opam/.opam/5.5~beta1/lib/lwt -I /home/opam/.opam/5.5~beta1/lib/lwt/unix -I /home/opam/.opam/5.5~beta1/lib/macaddr -I /home/opam/.opam/5.5~beta1/lib/magic-mime -I /home/opam/.opam/5.5~beta1/lib/ocaml/threads -I /home/opam/.opam/5.5~beta1/lib/ocaml/unix -I /home/opam/.opam/5.5~beta1/lib/ocplib-endian -I /home/opam/.opam/5.5~beta1/lib/ocplib-endian/bigstring -I /home/opam/.opam/5.5~beta1/lib/parsexp -I /home/opam/.opam/5.5~beta1/lib/ppx_sexp_conv/runtime-lib -I /home/opam/.opam/5.5~beta1/lib/re -I /home/opam/.opam/5.5~beta1/lib/seq -I /home/opam/.opam/5.5~beta1/lib/sexplib -I /home/opam/.opam/5.5~beta1/lib/sexplib0 -I /home/opam/.opam/5.5~beta1/lib/stringext -I /home/opam/.opam/5.5~beta1/lib/uri -I /home/opam/.opam/5.5~beta1/lib/uri-sexp -I /home/opam/.opam/5.5~beta1/lib/uri/services -I /home/opam/.opam/5.5~beta1/lib/yojson -intf-suffix .ml -no-alias-deps -o lib/.lichess_api.objs/native/lichess_api.cmx -c -impl lib/lichess_api.ml)
# File "lib/lichess_api.ml", lines 336-339, characters 33-29:
# 336 | .................................match List.assoc_opt "white" fields with 
# 337 |              | Some (`Assoc white_fields) ->
# 338 |                  match List.assoc_opt "name" white_fields with Some (`String s) -> s | _ -> "Unknown"
# 339 |              | _ -> "Unknown"...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 340-343, characters 23-29:
# 340 | .......................match List.assoc_opt "black" fields with 
# 341 |              | Some (`Assoc black_fields) ->
# 342 |                  match List.assoc_opt "name" black_fields with Some (`String s) -> s | _ -> "Unknown"
# 343 |              | _ -> "Unknown"...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 346-350, characters 40-24:
# 346 | ........................................match List.assoc_opt "clock" fields with 
# 347 |              | Some (`Assoc clock_fields) ->
# 348 |                  match List.assoc_opt "initial" clock_fields with Some (`Int i) -> Some (string_of_int i)
# 349 |                  | _ -> None
# 350 |              | _ -> None...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 351-354, characters 30-24:
# 351 | ..............................match List.assoc_opt "white" fields with 
# 352 |              | Some (`Assoc white_fields) ->
# 353 |                  match List.assoc_opt "rating" white_fields with Some (`Int i) -> Some i | _ -> None
# 354 |              | _ -> None...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 355-358, characters 30-24:
# 355 | ..............................match List.assoc_opt "black" fields with 
# 356 |              | Some (`Assoc black_fields) ->
# 357 |                  match List.assoc_opt "rating" black_fields with Some (`Int i) -> Some i | _ -> None
# 358 |              | _ -> None...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 511-514, characters 43-23:
# 511 | ...........................................match List.assoc_opt "count" fields with 
# 512 |                | Some (`Assoc count_fields) ->
# 513 |                    match List.assoc_opt "all" count_fields with Some (`Int i) -> i | _ -> 0
# 514 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 516-519, characters 24-23:
# 516 | ........................match List.assoc_opt "count" fields with 
# 517 |                | Some (`Assoc count_fields) ->
# 518 |                    match List.assoc_opt "win" count_fields with Some (`Int i) -> i | _ -> 0
# 519 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 521-524, characters 26-23:
# 521 | ..........................match List.assoc_opt "count" fields with 
# 522 |                | Some (`Assoc count_fields) ->
# 523 |                    match List.assoc_opt "loss" count_fields with Some (`Int i) -> i | _ -> 0
# 524 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 526-529, characters 25-23:
# 526 | .........................match List.assoc_opt "count" fields with 
# 527 |                | Some (`Assoc count_fields) ->
# 528 |                    match List.assoc_opt "draw" count_fields with Some (`Int i) -> i | _ -> 0
# 529 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 535-544, characters 19-26:
# 535 | ...................match List.assoc_opt "classical" perfs_fields with 
# 536 |                      | Some (`Assoc classical_fields) ->
# 537 |                          match List.assoc_opt "games" classical_fields with Some (`Int games) ->
# 538 |                            if games > 0 then
# 539 |                              match List.assoc_opt "rating" classical_fields with Some (`Int rating) -> rating
# 540 |                              | _ -> 1500
# 541 |                            else 1500
# 542 |                          | _ -> 1500
# 543 |                      | _ -> 1500
# 544 |                | _ -> 1500...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 533-544, characters 46-26:
# 533 | ..............................................match List.assoc_opt "perfs" fields with 
# 534 |                | Some (`Assoc perfs_fields) ->
# 535 |                    match List.assoc_opt "classical" perfs_fields with 
# 536 |                      | Some (`Assoc classical_fields) ->
# 537 |                          match List.assoc_opt "games" classical_fields with Some (`Int games) ->
# ...
# 541 |                            else 1500
# 542 |                          | _ -> 1500
# 543 |                      | _ -> 1500
# 544 |                | _ -> 1500...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 550-556, characters 25-36:
# 550 | .........................match List.assoc_opt "best" classical_fields with 
# 551 |                            | Some (`Assoc best_fields) ->
# 552 |                                match List.assoc_opt "rating" best_fields with Some (`Int rating) -> rating
# 553 |                                | _ -> current_rating
# 554 |                            | _ -> current_rating
# 555 |                      | _ -> current_rating
# 556 |                | _ -> current_rating...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 548-556, characters 19-36:
# 548 | ...................match List.assoc_opt "classical" perfs_fields with 
# 549 |                      | Some (`Assoc classical_fields) ->
# 550 |                          match List.assoc_opt "best" classical_fields with 
# 551 |                            | Some (`Assoc best_fields) ->
# 552 |                                match List.assoc_opt "rating" best_fields with Some (`Int rating) -> rating
# 553 |                                | _ -> current_rating
# 554 |                            | _ -> current_rating
# 555 |                      | _ -> current_rating
# 556 |                | _ -> current_rating...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 546-556, characters 31-36:
# 546 | ...............................match List.assoc_opt "perfs" fields with 
# 547 |                | Some (`Assoc perfs_fields) ->
# 548 |                    match List.assoc_opt "classical" perfs_fields with 
# 549 |                      | Some (`Assoc classical_fields) ->
# 550 |                          match List.assoc_opt "best" classical_fields with 
# ...
# 553 |                                | _ -> current_rating
# 554 |                            | _ -> current_rating
# 555 |                      | _ -> current_rating
# 556 |                | _ -> current_rating...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", line 573, characters 4-5:
# 573 |   | _ ->
#           ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", lines 505-574, characters 2-21:
# 505 | ..match Cohttp.Response.status response with
# 506 |   | `OK ->
# 507 |       try
# 508 |         let json = Yojson.Basic.from_string body_str in
# 509 |         match json with
# ...
# 571 |         | _ -> Lwt.return_none
# 572 |       with _ -> Lwt.return_none
# 573 |   | _ ->
# 574 |       Lwt.return_none
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     (`Request_timeout|`Temporary_redirect|`Checkpoint|`Expectation_failed|
#     `Partial_content|`Client_closed_request|`Not_extended|
#     `Precondition_required|`Bandwidth_limit_exceeded|`Gone|
#     `Network_connect_timeout_error|`Code _|`Gateway_timeout|
#     `Wrong_exchange_server|`Retry_with|`Unprocessable_entity|`Accepted|
#     `Failed_dependency|`Permanent_redirect|`I_m_a_teapot|`Found|
#     `Moved_permanently|`Requested_range_not_satisfiable|`Unauthorized|
#     `Precondition_failed|`See_other|`Locked|`No_response|`Continue|
#     `Loop_detected|`Insufficient_storage|`Non_authoritative_information|
#     `Too_many_requests|`Request_entity_too_large|`Multiple_choices|
#     `Method_not_allowed|`Proxy_authentication_required|
#     `Network_authentication_required|`Conflict|`Network_read_timeout_error|
#     `Bad_request|`Not_acceptable|`Switch_proxy|`Length_required|
#     `Reset_content|`Im_used|`Already_reported|`Not_found|`Not_modified|
#     `Use_proxy|`Forbidden|`Unsupported_media_type|`Not_implemented|
#     `No_content|`Created|`Variant_also_negotiates|`Payment_required|
#     `Internal_server_error|`Service_unavailable|`Enhance_your_calm|
#     `Processing|`Upgrade_required|`Multi_status|`Bad_gateway|
#     `Http_version_not_supported|`Switching_protocols|`Request_uri_too_long|
#     `Blocked_by_windows_parental_controls|`Request_header_fields_too_large)
# 
# File "lib/lichess_api.ml", line 339, characters 15-16:
# 339 |              | _ -> "Unknown" in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 343, characters 15-16:
# 343 |              | _ -> "Unknown" in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 350, characters 15-16:
# 350 |              | _ -> None in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 354, characters 15-16:
# 354 |              | _ -> None in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 358, characters 15-16:
# 358 |              | _ -> None in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 514, characters 17-18:
# 514 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 519, characters 17-18:
# 519 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 524, characters 17-18:
# 524 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 529, characters 17-18:
# 529 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 543, characters 23-24:
# 543 |                      | _ -> 1500
#                              ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 544, characters 17-18:
# 544 |                | _ -> 1500 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 554, characters 29-30:
# 554 |                            | _ -> current_rating
#                                    ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 555, characters 23-24:
# 555 |                      | _ -> current_rating
#                              ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 556, characters 17-18:
# 556 |                | _ -> current_rating in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# (cd _build/default && /home/opam/.opam/5.5~beta1/bin/ocamlc.opt -w -40 -warn-error -A -g -bin-annot -bin-annot-occurrences -I lib/.lichess_api.objs/byte -I /home/opam/.opam/5.5~beta1/lib/angstrom -I /home/opam/.opam/5.5~beta1/lib/astring -I /home/opam/.opam/5.5~beta1/lib/base64 -I /home/opam/.opam/5.5~beta1/lib/bigstringaf -I /home/opam/.opam/5.5~beta1/lib/biniou -I /home/opam/.opam/5.5~beta1/lib/bytes -I /home/opam/.opam/5.5~beta1/lib/camlp-streams -I /home/opam/.opam/5.5~beta1/lib/cohttp -I /home/opam/.opam/5.5~beta1/lib/cohttp-lwt -I /home/opam/.opam/5.5~beta1/lib/cohttp-lwt-unix -I /home/opam/.opam/5.5~beta1/lib/conduit -I /home/opam/.opam/5.5~beta1/lib/conduit-lwt -I /home/opam/.opam/5.5~beta1/lib/conduit-lwt-unix -I /home/opam/.opam/5.5~beta1/lib/domain-name -I /home/opam/.opam/5.5~beta1/lib/easy-format -I /home/opam/.opam/5.5~beta1/lib/fmt -I /home/opam/.opam/5.5~beta1/lib/ipaddr -I /home/opam/.opam/5.5~beta1/lib/ipaddr-sexp -I /home/opam/.opam/5.5~beta1/lib/ipaddr/unix -I /home/opam/.opam/5.5~beta1/lib/logs -I /home/opam/.opam/5.5~beta1/lib/lwt -I /home/opam/.opam/5.5~beta1/lib/lwt/unix -I /home/opam/.opam/5.5~beta1/lib/macaddr -I /home/opam/.opam/5.5~beta1/lib/magic-mime -I /home/opam/.opam/5.5~beta1/lib/ocaml/threads -I /home/opam/.opam/5.5~beta1/lib/ocaml/unix -I /home/opam/.opam/5.5~beta1/lib/ocplib-endian -I /home/opam/.opam/5.5~beta1/lib/ocplib-endian/bigstring -I /home/opam/.opam/5.5~beta1/lib/parsexp -I /home/opam/.opam/5.5~beta1/lib/ppx_sexp_conv/runtime-lib -I /home/opam/.opam/5.5~beta1/lib/re -I /home/opam/.opam/5.5~beta1/lib/seq -I /home/opam/.opam/5.5~beta1/lib/sexplib -I /home/opam/.opam/5.5~beta1/lib/sexplib0 -I /home/opam/.opam/5.5~beta1/lib/stringext -I /home/opam/.opam/5.5~beta1/lib/uri -I /home/opam/.opam/5.5~beta1/lib/uri-sexp -I /home/opam/.opam/5.5~beta1/lib/uri/services -I /home/opam/.opam/5.5~beta1/lib/yojson -intf-suffix .ml -no-alias-deps -o lib/.lichess_api.objs/byte/lichess_api.cmo -c -impl lib/lichess_api.ml)
# File "lib/lichess_api.ml", lines 336-339, characters 33-29:
# 336 | .................................match List.assoc_opt "white" fields with 
# 337 |              | Some (`Assoc white_fields) ->
# 338 |                  match List.assoc_opt "name" white_fields with Some (`String s) -> s | _ -> "Unknown"
# 339 |              | _ -> "Unknown"...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 340-343, characters 23-29:
# 340 | .......................match List.assoc_opt "black" fields with 
# 341 |              | Some (`Assoc black_fields) ->
# 342 |                  match List.assoc_opt "name" black_fields with Some (`String s) -> s | _ -> "Unknown"
# 343 |              | _ -> "Unknown"...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 346-350, characters 40-24:
# 346 | ........................................match List.assoc_opt "clock" fields with 
# 347 |              | Some (`Assoc clock_fields) ->
# 348 |                  match List.assoc_opt "initial" clock_fields with Some (`Int i) -> Some (string_of_int i)
# 349 |                  | _ -> None
# 350 |              | _ -> None...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 351-354, characters 30-24:
# 351 | ..............................match List.assoc_opt "white" fields with 
# 352 |              | Some (`Assoc white_fields) ->
# 353 |                  match List.assoc_opt "rating" white_fields with Some (`Int i) -> Some i | _ -> None
# 354 |              | _ -> None...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 355-358, characters 30-24:
# 355 | ..............................match List.assoc_opt "black" fields with 
# 356 |              | Some (`Assoc black_fields) ->
# 357 |                  match List.assoc_opt "rating" black_fields with Some (`Int i) -> Some i | _ -> None
# 358 |              | _ -> None...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 511-514, characters 43-23:
# 511 | ...........................................match List.assoc_opt "count" fields with 
# 512 |                | Some (`Assoc count_fields) ->
# 513 |                    match List.assoc_opt "all" count_fields with Some (`Int i) -> i | _ -> 0
# 514 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 516-519, characters 24-23:
# 516 | ........................match List.assoc_opt "count" fields with 
# 517 |                | Some (`Assoc count_fields) ->
# 518 |                    match List.assoc_opt "win" count_fields with Some (`Int i) -> i | _ -> 0
# 519 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 521-524, characters 26-23:
# 521 | ..........................match List.assoc_opt "count" fields with 
# 522 |                | Some (`Assoc count_fields) ->
# 523 |                    match List.assoc_opt "loss" count_fields with Some (`Int i) -> i | _ -> 0
# 524 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 526-529, characters 25-23:
# 526 | .........................match List.assoc_opt "count" fields with 
# 527 |                | Some (`Assoc count_fields) ->
# 528 |                    match List.assoc_opt "draw" count_fields with Some (`Int i) -> i | _ -> 0
# 529 |                | _ -> 0...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 535-544, characters 19-26:
# 535 | ...................match List.assoc_opt "classical" perfs_fields with 
# 536 |                      | Some (`Assoc classical_fields) ->
# 537 |                          match List.assoc_opt "games" classical_fields with Some (`Int games) ->
# 538 |                            if games > 0 then
# 539 |                              match List.assoc_opt "rating" classical_fields with Some (`Int rating) -> rating
# 540 |                              | _ -> 1500
# 541 |                            else 1500
# 542 |                          | _ -> 1500
# 543 |                      | _ -> 1500
# 544 |                | _ -> 1500...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 533-544, characters 46-26:
# 533 | ..............................................match List.assoc_opt "perfs" fields with 
# 534 |                | Some (`Assoc perfs_fields) ->
# 535 |                    match List.assoc_opt "classical" perfs_fields with 
# 536 |                      | Some (`Assoc classical_fields) ->
# 537 |                          match List.assoc_opt "games" classical_fields with Some (`Int games) ->
# ...
# 541 |                            else 1500
# 542 |                          | _ -> 1500
# 543 |                      | _ -> 1500
# 544 |                | _ -> 1500...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 550-556, characters 25-36:
# 550 | .........................match List.assoc_opt "best" classical_fields with 
# 551 |                            | Some (`Assoc best_fields) ->
# 552 |                                match List.assoc_opt "rating" best_fields with Some (`Int rating) -> rating
# 553 |                                | _ -> current_rating
# 554 |                            | _ -> current_rating
# 555 |                      | _ -> current_rating
# 556 |                | _ -> current_rating...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 548-556, characters 19-36:
# 548 | ...................match List.assoc_opt "classical" perfs_fields with 
# 549 |                      | Some (`Assoc classical_fields) ->
# 550 |                          match List.assoc_opt "best" classical_fields with 
# 551 |                            | Some (`Assoc best_fields) ->
# 552 |                                match List.assoc_opt "rating" best_fields with Some (`Int rating) -> rating
# 553 |                                | _ -> current_rating
# 554 |                            | _ -> current_rating
# 555 |                      | _ -> current_rating
# 556 |                | _ -> current_rating...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", lines 546-556, characters 31-36:
# 546 | ...............................match List.assoc_opt "perfs" fields with 
# 547 |                | Some (`Assoc perfs_fields) ->
# 548 |                    match List.assoc_opt "classical" perfs_fields with 
# 549 |                      | Some (`Assoc classical_fields) ->
# 550 |                          match List.assoc_opt "best" classical_fields with 
# ...
# 553 |                                | _ -> current_rating
# 554 |                            | _ -> current_rating
# 555 |                      | _ -> current_rating
# 556 |                | _ -> current_rating...
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     Some (`Null|`List _|`Bool _|`Float _|`Int _|`String _)
# 
# File "lib/lichess_api.ml", line 573, characters 4-5:
# 573 |   | _ ->
#           ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", lines 505-574, characters 2-21:
# 505 | ..match Cohttp.Response.status response with
# 506 |   | `OK ->
# 507 |       try
# 508 |         let json = Yojson.Basic.from_string body_str in
# 509 |         match json with
# ...
# 571 |         | _ -> Lwt.return_none
# 572 |       with _ -> Lwt.return_none
# 573 |   | _ ->
# 574 |       Lwt.return_none
# Warning 8 [partial-match]: this pattern-matching is not exhaustive.
#   Here is an example of a case that is not matched:
#     (`Request_timeout|`Temporary_redirect|`Checkpoint|`Expectation_failed|
#     `Partial_content|`Client_closed_request|`Not_extended|
#     `Precondition_required|`Bandwidth_limit_exceeded|`Gone|
#     `Network_connect_timeout_error|`Code _|`Gateway_timeout|
#     `Wrong_exchange_server|`Retry_with|`Unprocessable_entity|`Accepted|
#     `Failed_dependency|`Permanent_redirect|`I_m_a_teapot|`Found|
#     `Moved_permanently|`Requested_range_not_satisfiable|`Unauthorized|
#     `Precondition_failed|`See_other|`Locked|`No_response|`Continue|
#     `Loop_detected|`Insufficient_storage|`Non_authoritative_information|
#     `Too_many_requests|`Request_entity_too_large|`Multiple_choices|
#     `Method_not_allowed|`Proxy_authentication_required|
#     `Network_authentication_required|`Conflict|`Network_read_timeout_error|
#     `Bad_request|`Not_acceptable|`Switch_proxy|`Length_required|
#     `Reset_content|`Im_used|`Already_reported|`Not_found|`Not_modified|
#     `Use_proxy|`Forbidden|`Unsupported_media_type|`Not_implemented|
#     `No_content|`Created|`Variant_also_negotiates|`Payment_required|
#     `Internal_server_error|`Service_unavailable|`Enhance_your_calm|
#     `Processing|`Upgrade_required|`Multi_status|`Bad_gateway|
#     `Http_version_not_supported|`Switching_protocols|`Request_uri_too_long|
#     `Blocked_by_windows_parental_controls|`Request_header_fields_too_large)
# 
# File "lib/lichess_api.ml", line 339, characters 15-16:
# 339 |              | _ -> "Unknown" in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 343, characters 15-16:
# 343 |              | _ -> "Unknown" in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 350, characters 15-16:
# 350 |              | _ -> None in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 354, characters 15-16:
# 354 |              | _ -> None in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 358, characters 15-16:
# 358 |              | _ -> None in
#                      ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 514, characters 17-18:
# 514 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 519, characters 17-18:
# 519 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 524, characters 17-18:
# 524 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 529, characters 17-18:
# 529 |                | _ -> 0 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 543, characters 23-24:
# 543 |                      | _ -> 1500
#                              ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 544, characters 17-18:
# 544 |                | _ -> 1500 in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 554, characters 29-30:
# 554 |                            | _ -> current_rating
#                                    ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 555, characters 23-24:
# 555 |                      | _ -> current_rating
#                              ^
# Warning 11 [redundant-case]: this match case is unused.
# 
# File "lib/lichess_api.ml", line 556, characters 17-18:
# 556 |                | _ -> current_rating in
#                        ^
# Warning 11 [redundant-case]: this match case is unused.



<><> Error report <><><><><><><><><><><><><><><><><><><><><><><><><><><><><><><>
+- The following actions failed
| - build lichess_api 1.0.2
+- 
+- The following changes have been performed
| - remove    digestif                1.3.0
| - remove    http                    6.2.1
| - remove    kdf                     1.0.0
| - remove    lichess_api             1.0.2
| - remove    mirage-crypto-ec        2.1.0
| - remove    ocaml-syntax-shims      1.0.0
| - remove    ohex                    0.2.0
| - downgrade angstrom                0.16.1 to 0.14.0
| - downgrade asn1-combinators        0.3.2 to 0.2.6
| - downgrade base                    v0.17.3 to v0.17.0
| - downgrade base64                  3.5.2 to 3.1.0
| - downgrade bigstringaf             0.10.0 to 0.5.0
| - downgrade bos                     0.3.0 to 0.2.1
| - downgrade ca-certs                1.0.1 to 0.2.0
| - downgrade cmdliner                2.1.1 to 1.0.4
| - downgrade cohttp                  6.2.1 to 5.1.0
| - downgrade cohttp-lwt              6.2.1 to 5.1.0
| - downgrade cohttp-lwt-unix         6.2.1 to 5.1.0
| - downgrade conduit                 8.0.0 to 6.1.0
| - downgrade conduit-lwt             8.0.0 to 6.1.0
| - downgrade conduit-lwt-unix        8.0.0 to 6.1.0
| - downgrade conf-pkg-config         4 to 1.0
| - downgrade cppo                    1.8.0 to 1.6.7
| - downgrade csexp                   1.5.2 to 1.3.1
| - downgrade domain-name             0.5.0 to 0.3.0
| - downgrade dune                    3.22.2 to 3.19.0
| - downgrade dune-configurator       3.22.2 to 2.9.3
| - downgrade duration                0.3.1 to 0.2.1
| - downgrade eqaf                    0.10 to 0.9
| - downgrade fmt                     0.11.0 to 0.9.0
| - downgrade ipaddr                  5.6.2 to 5.6.0
| - downgrade ipaddr-sexp             5.6.2 to 5.6.0
| - downgrade logs                    0.10.0 to 0.7.0
| - downgrade lwt_ppx                 6.1.0 to 6.0.0
| - downgrade macaddr                 5.6.2 to 5.6.0
| - downgrade magic-mime              1.3.1 to 1.1.2
| - downgrade mirage-crypto           2.1.0 to 0.10.7
| - downgrade mirage-crypto-pk        2.1.0 to 0.10.7
| - downgrade mirage-crypto-rng       2.1.0 to 0.10.7
| - downgrade ocaml_intrinsics_kernel v0.17.1 to v0.17.0
| - downgrade ocamlbuild              0.16.1 to 0.14.3
| - downgrade ocamlfind               1.9.8 to 1.9.6
| - downgrade ocplib-endian           1.2 to 1.1
| - downgrade pgn_parser              1.0.2 to 1.0.0
| - downgrade ppxlib                  0.38.0 to 0.38.0~5.5preview
| - downgrade re                      1.14.0 to 1.9.0
| - downgrade stdlib-shims            0.3.0 to 0.1.0
| - downgrade topkg                   1.1.1 to 1.0.8
| - downgrade uri                     4.4.0 to 4.0.0
| - downgrade uri-sexp                4.4.0 to 4.0.0
| - downgrade x509                    1.0.6 to 0.11.2
| - downgrade yojson                  3.0.0 to 1.7.0
| - downgrade zarith                  1.14 to 1.7-1
| - recompile base-bytes              base
| - recompile gmap                    0.3.0
| - recompile lwt                     6.1.1
| - recompile ocaml-compiler-libs     v0.17.0
| - recompile ppx_derivers            1.2.1
| - recompile ppx_sexp_conv           v0.17.1
| - recompile ppxlib_jane             v0.17.4
| - recompile sexplib0                v0.17.0
| - recompile stringext               1.6.0
| - install   bigarray-compat         1.1.0
| - install   biniou                  1.2.2
| - install   camlp-streams           5.0.1
| - install   conf-perl               1
| - install   cstruct                 6.0.0
| - install   easy-format             1.3.3
| - install   jsonm                   1.0.2
| - install   mirage-no-solo5         1
| - install   mirage-no-xen           1
| - install   mtime                   1.3.0
| - install   num                     1.6
| - install   ounit2                  2.2.6
| - install   parsexp                 v0.17.0
| - install   qcheck                  0.25
| - install   qcheck-core             0.25
| - install   qcheck-ounit            0.25
| - install   result                  1.5
| - install   seq                     0.3
| - install   sexplib                 v0.17.0
| - install   uutf                    1.0.3
+- 

<><> mirage-no-xen.1 installed successfully <><><><><><><><><><><><><><><><><><>
=> Note: This package is deprecated.

<><> mirage-no-solo5.1 installed successfully <><><><><><><><><><><><><><><><><>
=> Note: This package is deprecated.
# To update the current shell environment, run: eval $(opam env)

The former state can be restored with:
    /usr/bin/opam switch import "/home/opam/.opam/5.5~beta1/.opam-switch/backup/state-20260427080417.export"
Or you can retry to install your package selection with:
    /usr/bin/opam install --restore
[WARNING] OPAMCONFIRMLEVEL was ignored because CLI 2.0 was requested and it was introduced in 2.1.
"/usr/bin/env" "bash" "-c" "opam reinstall lichess_api.1.0.2;
        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" != 'lichess_api.1.0.2' && partial_fails="$partial_fails $pkg";
        done;
        test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}";
        exit 1" failed with exit status 1
2026-04-27 08:05.54: Job failed: Failed: Build failed
2026-04-27 08:05.54: Log analysis:
2026-04-27 08:05.54: >>> 
[ERROR] The compilation of lichess_api.1.0.2 failed at "dune build -p lichess_api -j 71 @install".
 (score = 20)
2026-04-27 08:05.54: >>> 
# Error: Library "pgn_parser" not found.
 (score = 48)
2026-04-27 08:05.54: >>> 
# Error: Library "pgn_parser" not found.
 (score = 48)
2026-04-27 08:05.54: >>> 
# Error: Library "pgn_parser" not found.
 (score = 48)
2026-04-27 08:05.54: Library "pgn_parser" not found.