(for PR #28521)

2026-04-27 07:45.26: New job: test lichess_api.1.0.2, 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
RUN (opam reinstall --with-test lichess_api.1.0.2) || true
RUN opam reinstall --with-test --verbose 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"))
 (run (network host)
      (shell "(opam reinstall --with-test lichess_api.1.0.2) || true"))
 (run (shell  "opam reinstall --with-test --verbose 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.52: Waiting for worker…
2026-04-27 08:02.11: 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.15 ---> 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.15 ---> 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.15 ---> 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.15 ---> 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.15 ---> 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: (run (network host)
                 (shell "(opam reinstall --with-test lichess_api.1.0.2) || true"))
The following actions will be performed:
=== recompile 1 package
  - recompile lichess_api  1.0.2 (pinned)
=== install 5 packages
  - install   ounit2       2.2.7          [required by qcheck-ounit]
  - install   qcheck       0.91           [required by lichess_api]
  - install   qcheck-core  0.91           [required by qcheck]
  - install   qcheck-ounit 0.91           [required by qcheck]
  - install   seq          base           [required by ounit2]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved ounit2.2.2.7  (https://opam.ocaml.org/cache)
-> retrieved qcheck.0.91, qcheck-core.0.91, qcheck-ounit.0.91  (https://opam.ocaml.org/cache)
-> retrieved seq.base  (2 extra sources)
-> retrieved seq.base  (2 extra sources)
-> installed seq.base
-> installed ounit2.2.2.7
-> removed   lichess_api.1.0.2
-> installed qcheck-core.0.91
-> installed qcheck-ounit.0.91
-> installed qcheck.0.91
-> installed lichess_api.1.0.2
Done.
# To update the current shell environment, run: eval $(opam env)
2026-04-27 08:04.27 ---> saved as "9fc0cb542e57fde47c3e3d65f59f2195e74969aba45f2869253579a2297d2def"

/home/opam: (run (shell  "opam reinstall --with-test --verbose 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:
=== recompile 1 package
  - recompile lichess_api 1.0.2 (pinned)

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing  2/4: [lichess_api: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "lichess_api" "-j" "71" "@install" "@runtest" (CWD=/home/opam/.opam/5.5~beta1/.opam-switch/build/lichess_api.1.0.2)
- (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/bytes -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/fmt -I /home/opam/.opam/5.5~beta1/lib/http -H /home/opam/.opam/5.5~beta1/lib/http/__private__/http_bytebuffer -H /home/opam/.opam/5.5~beta1/lib/http/__private__/http_bytebuffer/.public_cmi -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/logs/fmt -I /home/opam/.opam/5.5~beta1/lib/logs/lwt -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/ppx_sexp_conv/runtime-lib -I /home/opam/.opam/5.5~beta1/lib/re -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 -cmi-file lib/.lichess_api.objs/byte/lichess_api.cmi -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.
- (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/bytes -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/fmt -I /home/opam/.opam/5.5~beta1/lib/http -I /home/opam/.opam/5.5~beta1/lib/http/__private__/http_bytebuffer -H /home/opam/.opam/5.5~beta1/lib/http/__private__/http_bytebuffer/.public_cmi -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/logs/fmt -I /home/opam/.opam/5.5~beta1/lib/logs/lwt -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/ppx_sexp_conv/runtime-lib -I /home/opam/.opam/5.5~beta1/lib/re -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 -cmi-file lib/.lichess_api.objs/byte/lichess_api.cmi -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/test && ./test_pgn_parser.exe)
- === Running Property-Based Tests ===
- 
- 
random seed: 515595785
- generated error fail pass / total     time test name
- 
[ ]    0    0    0    0 /  100     0.0s piece_generation
[✓]  100    0    0  100 /  100     0.0s piece_generation
- 
[ ]    0    0    0    0 /  100     0.0s square_generation
[✓]  100    0    0  100 /  100     0.0s square_generation
- 
[ ]    0    0    0    0 /  100     0.0s result_generation
[✓]  100    0    0  100 /  100     0.0s result_generation
- 
[ ]    0    0    0    0 /  100     0.0s simple_move_generation
[✓]  100    0    0  100 /  100     0.0s simple_move_generation
- 
[ ]    0    0    0    0 /   50     0.0s generated_pgn_structure
[✓]   50    0    0   50 /   50     0.0s generated_pgn_structure
- 
[ ]    0    0    0    0 /   30     0.0s generated_pgn_parsing
[✓]   30    0    0   30 /   30     0.0s generated_pgn_parsing
- 
[ ]    0    0    0    0 /   20     0.0s roundtrip_property
[✓]   20    0    0   20 /   20     0.0s roundtrip_property
- 
[ ]    0    0    0    0 /   50     0.0s parser_robustness
[✓]   50    0    0   50 /   50     0.0s parser_robustness
- 
[ ]    0    0    0    0 /  100     0.0s move_properties
[✓]  100    0    0  100 /  100     0.0s move_properties
- ================================================================================
- success (ran 9 tests)
- 
- 🎉 Property-based tests completed!
- (cd _build/default/test && ./test_zobrist.exe)
- === Comprehensive Zobrist Hash Tests ===
- 
- Hash1: 5973866749138151475, Hash2: 5973866749138151475, Hash3: 5973866749138151475
- ✓ Hash determinism test passed
- ✓ Hash uniqueness test passed
- ✓ Move integrity test passed
- ✓ Castling test passed
- ✓ Promotion test passed
- ✓ Transposition test passed
- ✓ Board visualization test passed
- ✓ Parsing board consistency test passed
- Generated 6 positions, 6 unique hashes
- Position 0: 5973866749138151475
- Position 1: 0
- Position 2: 4102231131927469148
- Position 3: 6062934264345594682
- Position 4: 3729644824639999795
- Position 5: 7169190867319171561
- ✓ Hash collision resistance test passed
- 
- === Testing Zobrist Hash with Fixed Piece Positions ===
- Starting position hash: 5973866749138151475
- ✅ Knight to e3: Ne3 -> from c4 to e3 (VALID)
-    Hash: 5528355590083076651
- ✅ Bishop to g7: Bg7 -> from f6 to g7 (VALID)
-    Hash: 9206269617448157711
- ✅ Knight to f3: Nf3 -> from d4 to f3 (VALID)
-    Hash: 7688626286539919417
- ✅ Bishop to e4: Be4 -> from d5 to e4 (VALID)
-    Hash: 8015949090927842022
- ✅ Knight captures on e4: Nxe4 -> from c3 to e4 (VALID)
-    Hash: 2729069438004083103
- ✅ Bishop captures on f7: Bxf7 -> from e6 to f7 (VALID)
-    Hash: 6533094332387490985
- ✓ Fixed piece positions Zobrist test passed
- ✅ All position hashes are unique
- 
- === Testing Hash Consistency for Move Sequences ===
- ✅ Knight to e3: Hash changed from 5973866749138151475 to 5528355590083076651
- ✅ Bishop to g7: Hash changed from 5528355590083076651 to 7033751008051185687
- ✅ Knight to f3: Hash changed from 7033751008051185687 to 6469680013774630941
- ✅ Bishop to e4: Hash changed from 6469680013774630941 to 7210760686190725832
- ✅ Knight captures on e4: Hash changed from 7210760686190725832 to 3382205142446449073
- ✅ Bishop captures on f7: Hash changed from 3382205142446449073 to 2791465608862135595
- ✓ Hash consistency for move sequences test passed
- 
- === All Zobrist tests passed! ===
- (cd _build/default/test && ./test_lichess_api_pbt.exe)
- 
- === Running Lichess API Property-Based Tests ===
- 
random seed: 315929120
- generated error fail pass / total     time test name
- 
[ ]    0    0    0    0 /  100     0.0s Game ID is not empty
[✓]  100    0    0  100 /  100     0.0s Game ID is not empty
- 
[ ]    0    0    0    0 /  100     0.0s Username has valid format
[✓]  100    0    0  100 /  100     0.0s Username has valid format
- 
[ ]    0    0    0    0 /  100     0.0s Rating is in valid range
[✓]  100    0    0  100 /  100     0.0s Rating is in valid range
- 
[ ]    0    0    0    0 /  100     0.0s Game has both players
[✓]  100    0    0  100 /  100     0.0s Game has both players
- 
[ ]    0    0    0    0 /  100     0.0s Game PGN contains player names
[✓]  100    0    0  100 /  100     0.0s Game PGN contains player names
- 
[ ]    0    0    0    0 /  100     0.0s Game PGN contains result
[✓]  100    0    0  100 /  100     0.0s Game PGN contains result
- 
[ ]    0    0    0    0 /  100     0.0s Lichess game to PGN roundtrip
[✓]  100    0    0  100 /  100     0.0s Lichess game to PGN roundtrip
- 
[ ]    0    0    0    0 /  100     0.0s Lichess game to PGN conversion is valid
[✓]  100    0    0  100 /  100     0.0s Lichess game to PGN conversion is valid
- ================================================================================
- success (ran 8 tests)
-> compiled  lichess_api.1.0.2
-> removed   lichess_api.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.33 ---> saved as "236c794ddcb2174ac32b56d0fac6d289c28c691bf7acbddb2b5e343dad2d3f8d"
Job succeeded
2026-04-27 08:04.43: Job succeeded