(for PR #28521)

2025-11-10 11:00.51: New job: test pgn_parser.1.0.2, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/28521/head (d524ea6c8a2ed6050068c8cedb293e595330dc67)
                              on centos-9-ocaml-4.14/amd64

To reproduce locally:

cd $(mktemp -d)
git clone --recursive "https://github.com/ocaml/opam-repository.git" && cd "opam-repository" && git fetch origin "refs/pull/28521/head" && git reset --hard d524ea6c
git fetch origin master
git merge --no-edit 21f97b2e6d7c617fc0a79cc8e59b2e10690960e1
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:centos-9-ocaml-4.14@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2
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 pgn_parser.1.0.2 1.0.2
RUN opam reinstall pgn_parser.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 "\"centos-9\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'pgn_parser.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 pgn_parser.1.0.2) || true
RUN opam reinstall --with-test --verbose pgn_parser.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 "\"centos-9\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'pgn_parser.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 .

2025-11-10 11:00.51: Using cache hint "ocaml/opam:centos-9-ocaml-4.14@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2-pgn_parser.1.0.2-d524ea6c8a2ed6050068c8cedb293e595330dc67"
2025-11-10 11:00.51: Using OBuilder spec:
((from ocaml/opam:centos-9-ocaml-4.14@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2)
 (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 pgn_parser.1.0.2 1.0.2"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall pgn_parser.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 \"\\\"centos-9\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'pgn_parser.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 pgn_parser.1.0.2) || true"))
 (run (shell  "opam reinstall --with-test --verbose pgn_parser.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 \"\\\"centos-9\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'pgn_parser.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"))
)

2025-11-10 11:00.51: Waiting for resource in pool OCluster
2025-11-10 11:44.32: Waiting for worker…
2025-11-10 11:48.08: Got resource from pool OCluster
Building on asteria.caelum.ci.dev
All commits already cached
HEAD is now at 21f97b2e6d Merge pull request #28836 from dbuenzli/b0-publish-bytesrw.0.3.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:centos-9-ocaml-4.14@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2)
Unable to find image 'ocaml/opam:centos-9-ocaml-4.14@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2' locally
docker.io/ocaml/opam@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2: Pulling from ocaml/opam
57b9d01e960d: Already exists
da52121e5e0b: Already exists
c05df575a06c: Already exists
8cfc90e460aa: Already exists
c60a1e8f5888: Already exists
ca0e671ea73e: Already exists
e54b92dc9e35: Already exists
7d4d3d6e6c4a: Already exists
9cd615a5705c: Already exists
217e727fdb67: Already exists
c616fd6f9fe5: Already exists
749e4a8d7aa8: Already exists
887d75ac7460: Already exists
c21eab48b10c: Already exists
cfa8b743b537: Already exists
a8b55ebe1144: Already exists
6277abf0fa65: Already exists
6277abf0fa65: Already exists
fed75d1b612a: Already exists
837723d4ad87: Already exists
7bcd03e2514d: Already exists
a69850e6646e: Already exists
4f4fb700ef54: Already exists
efccd7c97283: Already exists
31f216d9d3b3: Already exists
c4573d4bbe34: Already exists
e06c70a4f3ef: Already exists
460db5e656f6: Already exists
a83f006fe519: Already exists
e1a027d5760a: Already exists
c38907b9f7dc: Already exists
7cdc0adb205c: Already exists
a7902f56f5a2: Already exists
e5d4a6f522db: Already exists
3474abb8d0a9: Already exists
b29181a67751: Already exists
db07ca603c12: Already exists
e49d51456537: Already exists
dad0df8ee568: Already exists
ebb259a4580a: Already exists
96b1f5e97da2: Already exists
40708957bafc: Pulling fs layer
7404c9c2a2e3: Pulling fs layer
15865dbb3fc8: Pulling fs layer
6208f4c0676b: Pulling fs layer
6208f4c0676b: Waiting
7404c9c2a2e3: Verifying Checksum
7404c9c2a2e3: Download complete
15865dbb3fc8: Verifying Checksum
15865dbb3fc8: Download complete
6208f4c0676b: Verifying Checksum
6208f4c0676b: Download complete
40708957bafc: Download complete
40708957bafc: Pull complete
7404c9c2a2e3: Pull complete
15865dbb3fc8: Pull complete
6208f4c0676b: Pull complete
Digest: sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2
Status: Downloaded newer image for ocaml/opam@sha256:df239cf501a436b58c13dea53dae5b381edd0d24cba69a7b18877b15e8042ba2
2025-11-10 12:15.00 ---> using "a61290d9305af924156940aede364fc050ca1c9cd3822fa26dd3573c88b69bf8" from cache

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

/: (workdir /home/opam)

/home/opam: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2025-11-10 12:15.00 ---> using "c3eb43ea4e34354e10a9ecffe056142a5bd621b1695cc56266726966a51e09e5" from cache

/home/opam: (run (network host)
                 (shell "opam init --reinit --config .opamrc-sandbox -ni"))
Configuring from /home/opam/.opamrc-sandbox, then /home/opam/.opamrc, and finally from built-in defaults.
Checking for available remotes: rsync and local, git.
  - you won't be able to use mercurial repositories unless you install the hg command on your system.
  - you won't be able to use darcs repositories unless you install the darcs command on your system.

This version of opam requires an update to the layout of /home/opam/.opam from version 2.0 to version 2.2, which can't be reverted.
You may want to back it up before going further.

Continue? [Y/n] y
[NOTE] The 'jobs' option was reset, its value was 71 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using:
           opam option jobs=71 --global
Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2025-11-10 12:15.00 ---> using "2044d4e1e99b0f2a6f91fae600bafb74352034dcb18b60d2e603db99ff932b74" from cache

/home/opam: (run (shell "opam option solver=builtin-0install && opam config report"))
Set to 'builtin-0install' the field solver in global configuration
# opam config report
# opam-version         2.5.0~alpha1
# self-upgrade         no
# system               arch=x86_64 os=linux os-distribution=centos os-version=9
# solver               builtin-0install
# install-criteria     -changed,-count[avoid-version,solution]
# upgrade-criteria     -count[avoid-version,solution]
# jobs                 255
# repositories         1 (version-controlled)
# pinned               1 (version)
# current-switch       4.14
# invariant            ["ocaml-base-compiler" {= "4.14.2"}]
# compiler-packages    ocaml-base-compiler.4.14.2, ocaml-options-vanilla.1
# ocaml:native         true
# ocaml:native-tools   true
# ocaml:native-dynlink true
# ocaml:stubsdir       /home/opam/.opam/4.14/lib/ocaml/stublibs:/home/opam/.opam/4.14/lib/ocaml
# ocaml:preinstalled   false
# ocaml:compiler       4.14.2
2025-11-10 12:15.00 ---> using "7be05fd2741d66962183a1a4330fd04a1d750ad8e2d10384e5410a8018c86178" 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/"))
2025-11-10 12:15.00 ---> using "0ffd4a3d875e715dca42b0c8d18691025ed7ac5cd6f7249827a77da5e04b193f" from cache

/home/opam: (copy (src .) (dst opam-repository/))
2025-11-10 12:15.01 ---> using "6446f7c0bb5ddeb190428f142c6ad286856b3f438522c93da8fae0dac5969680" from cache

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2025-11-10 12:15.01 ---> using "7f9fbeedeb80da591509b2c428326f2f8899d0aea9dd5cb404988f683167eba3" from cache

/home/opam: (run (network host)
                 (shell "opam update --depexts || true"))
+ /usr/bin/sudo "yum" "makecache"
- CentOS Stream 9 - BaseOS                        103 kB/s |  15 kB     00:00    
- CentOS Stream 9 - AppStream                     139 kB/s |  15 kB     00:00    
- CentOS Stream 9 - CRB                           138 kB/s |  14 kB     00:00    
- CentOS Stream 9 - Extras packages               134 kB/s |  16 kB     00:00    
- Metadata cache created.
2025-11-10 12:15.01 ---> using "725f79aab3ee0a9cbe4b32c55623c7ea4497be90748563198b94c203b615ce02" from cache

/home/opam: (run (shell "opam pin add -k version -yn pgn_parser.1.0.2 1.0.2"))
pgn_parser is now pinned to version 1.0.2
2025-11-10 12:15.01 ---> using "84f245ae36f24f909214ef0b900661da9f4a4ccc2f4345988f04dce3a92b251b" from cache

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall pgn_parser.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 \"\\\"centos-9\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'pgn_parser.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"))
pgn_parser.1.0.2 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 65 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.16.4        [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.2.1          [required by ca-certs]
  - install ca-certs            1.0.1          [required by conduit-lwt-unix]
  - install cmdliner            2.0.0          [required by cohttp-lwt-unix]
  - install cohttp              6.1.1          [required by cohttp-lwt-unix]
  - install cohttp-lwt          6.1.1          [required by cohttp-lwt-unix]
  - install cohttp-lwt-unix     6.1.1          [required by pgn_parser]
  - 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.20.2         [required by pgn_parser]
  - install dune-configurator   3.20.2         [required by base, lwt, mirage-crypto]
  - install duration            0.2.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.1.1          [required by cohttp-lwt-unix]
  - install ipaddr              5.6.1          [required by cohttp-lwt, conduit-lwt-unix]
  - install ipaddr-sexp         5.6.1          [required by conduit-lwt-unix]
  - install kdf                 1.0.0          [required by x509]
  - install logs                0.10.0         [required by cohttp-lwt-unix]
  - install lwt                 5.9.2          [required by pgn_parser]
  - install lwt_ppx             5.9.1          [required by pgn_parser]
  - install macaddr             5.6.1          [required by ipaddr]
  - install magic-mime          1.3.1          [required by cohttp-lwt-unix]
  - install mirage-crypto       2.0.2          [required by ca-certs]
  - install mirage-crypto-ec    2.0.2          [required by x509]
  - install mirage-crypto-pk    2.0.2          [required by x509]
  - install mirage-crypto-rng   2.0.2          [required by x509]
  - install ocaml-compiler-libs v0.12.4        [required by ppxlib]
  - install ocaml-syntax-shims  1.0.0          [required by angstrom]
  - 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 (pinned)
  - install ppx_derivers        1.2.1          [required by ppxlib]
  - install ppx_sexp_conv       v0.16.0        [required by cohttp-lwt-unix]
  - install ppxlib              0.35.0         [required by lwt_ppx]
  - 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.16.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 pgn_parser]
  - install zarith              1.14           [required by mirage-crypto-pk]

The following system packages will first need to be installed:
    gmp-devel

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

opam believes some required external dependencies are missing. opam can:
> 1. Run yum to install them (may need root/sudo access)
  2. Display the recommended yum 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 "yum" "install" "-y" "gmp-devel"
- Last metadata expiration check: 0:00:05 ago on Mon Nov 10 12:14:58 2025.
- Dependencies resolved.
- ================================================================================
-  Package          Architecture  Version                  Repository        Size
- ================================================================================
- Installing:
-  gmp-devel        x86_64        1:6.2.0-13.el9           appstream        174 k
- Installing dependencies:
-  gmp-c++          x86_64        1:6.2.0-13.el9           appstream         19 k
- 
- Transaction Summary
- ================================================================================
- Install  2 Packages
- 
- Total download size: 193 k
- Installed size: 382 k
- Downloading Packages:
- (1/2): gmp-c++-6.2.0-13.el9.x86_64.rpm          462 kB/s |  19 kB     00:00    
- (2/2): gmp-devel-6.2.0-13.el9.x86_64.rpm        2.9 MB/s | 174 kB     00:00    
- --------------------------------------------------------------------------------
- Total                                           1.1 MB/s | 193 kB     00:00     
- Running transaction check
- Transaction check succeeded.
- Running transaction test
- Transaction test succeeded.
- Running transaction
-   Preparing        :                                                        1/1
-  
-   Installing       : gmp-c++-1:6.2.0-13.el9.x86_64                          1/2 
-   Installing       : gmp-devel-1:6.2.0-13.el9.x86_64                        2/2 
-   Running scriptlet: gmp-devel-1:6.2.0-13.el9.x86_64                        2/2 
-   Verifying        : gmp-c++-1:6.2.0-13.el9.x86_64                          1/2 
-   Verifying        : gmp-devel-1:6.2.0-13.el9.x86_64                        2/2 
- 
- Installed:
-   gmp-c++-1:6.2.0-13.el9.x86_64         gmp-devel-1:6.2.0-13.el9.x86_64        
- 
- Complete!
+ /usr/bin/rpm "-q" "--whatprovides" "gmp-devel"
- gmp-devel-6.2.0-13.el9.x86_64

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved angstrom.0.16.1  (cached)
-> retrieved asn1-combinators.0.3.2  (cached)
-> retrieved astring.0.8.5  (cached)
-> retrieved base.v0.16.4  (cached)
-> retrieved base64.3.5.2  (cached)
-> retrieved bigstringaf.0.10.0  (cached)
-> retrieved bos.0.2.1  (cached)
-> retrieved ca-certs.1.0.1  (cached)
-> retrieved cmdliner.2.0.0  (cached)
-> retrieved cohttp.6.1.1, cohttp-lwt.6.1.1, cohttp-lwt-unix.6.1.1, http.6.1.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-pkg-config.4
-> installed conf-gmp.5
-> installed conf-gmp-powm-sec.4
-> retrieved digestif.1.3.0  (cached)
-> retrieved domain-name.0.5.0  (cached)
-> retrieved dune.3.20.2, dune-configurator.3.20.2  (cached)
-> retrieved duration.0.2.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.1, ipaddr-sexp.5.6.1, macaddr.5.6.1  (cached)
-> retrieved kdf.1.0.0  (cached)
-> retrieved logs.0.10.0  (cached)
-> retrieved lwt.5.9.2  (cached)
-> retrieved lwt_ppx.5.9.1  (cached)
-> installed cmdliner.2.0.0
-> retrieved magic-mime.1.3.1  (cached)
-> retrieved mirage-crypto.2.0.2, mirage-crypto-ec.2.0.2, mirage-crypto-pk.2.0.2, mirage-crypto-rng.2.0.2  (cached)
-> retrieved ocaml-compiler-libs.v0.12.4  (cached)
-> retrieved ocaml-syntax-shims.1.0.0  (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 pgn_parser.1.0.2  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved ppx_sexp_conv.v0.16.0  (cached)
-> retrieved ppxlib.0.35.0  (cached)
-> retrieved ptime.1.2.0  (cached)
-> retrieved re.1.14.0  (cached)
-> retrieved rresult.0.7.0  (cached)
-> retrieved sexplib0.v0.16.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.20.2
-> installed base64.3.5.2
-> installed duration.0.2.1
-> installed gmap.0.3.0
-> installed ppx_derivers.1.2.1
-> installed ohex.0.2.0
-> installed stdlib-shims.0.3.0
-> installed domain-name.0.5.0
-> installed csexp.1.5.2
-> installed asn1-combinators.0.3.2
-> installed cppo.1.8.0
-> installed eqaf.0.10
-> installed http.6.1.1
-> installed macaddr.5.6.1
-> installed magic-mime.1.3.1
-> installed ocaml-compiler-libs.v0.12.4
-> installed ocaml-syntax-shims.1.0.0
-> installed re.1.14.0
-> installed sexplib0.v0.16.0
-> installed stringext.1.6.0
-> installed yojson.3.0.0
-> installed ocplib-endian.1.2
-> installed ipaddr.5.6.1
-> installed digestif.1.3.0
-> installed dune-configurator.3.20.2
-> installed bigstringaf.0.10.0
-> installed angstrom.0.16.1
-> installed mirage-crypto.2.0.2
-> installed kdf.1.0.0
-> installed uri.4.4.0
-> installed lwt.5.9.2
-> installed logs.0.10.0
-> installed base.v0.16.4
-> installed mirage-crypto-rng.2.0.2
-> installed mirage-crypto-pk.2.0.2
-> installed bos.0.2.1
-> installed mirage-crypto-ec.2.0.2
-> installed ppxlib.0.35.0
-> installed x509.1.0.6
-> installed ca-certs.1.0.1
-> installed lwt_ppx.5.9.1
-> installed ppx_sexp_conv.v0.16.0
-> installed ipaddr-sexp.5.6.1
-> installed uri-sexp.4.4.0
-> installed conduit.8.0.0
-> installed cohttp.6.1.1
-> installed conduit-lwt.8.0.0
-> installed cohttp-lwt.6.1.1
-> installed conduit-lwt-unix.8.0.0
-> installed cohttp-lwt-unix.6.1.1
-> installed pgn_parser.1.0.2
Done.
# To update the current shell environment, run: eval $(opam env)
2025-11-10 12:15.51 ---> saved as "6e966a371306103efd06bd0d4c08c2ade63d38d95d000c28446d1cbcffc92bfb"

/home/opam: (run (network host)
                 (shell "(opam reinstall --with-test pgn_parser.1.0.2) || true"))
The following actions will be performed:
=== recompile 1 package
  - recompile pgn_parser   1.0.2 (pinned)
=== install 5 packages
  - install   ounit2       2.2.7          [required by qcheck-ounit]
  - install   qcheck       0.27           [required by pgn_parser]
  - install   qcheck-core  0.27           [required by qcheck]
  - install   qcheck-ounit 0.27           [required by qcheck]
  - install   seq          base           [required by ounit2]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved ounit2.2.2.7  (https://opam.ocaml.org/cache)
-> retrieved qcheck.0.27, qcheck-core.0.27, qcheck-ounit.0.27  (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   pgn_parser.1.0.2
-> installed qcheck-core.0.27
-> installed qcheck-ounit.0.27
-> installed qcheck.0.27
-> installed pgn_parser.1.0.2
Done.
# To update the current shell environment, run: eval $(opam env)
2025-11-10 12:15.57 ---> saved as "6aca4fa911ffb5e1757926c78ca386c46d59d2ce038b01f416b1002bcb1c5f77"

/home/opam: (run (shell  "opam reinstall --with-test --verbose pgn_parser.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 \"\\\"centos-9\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'pgn_parser.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 pgn_parser 1.0.2 (pinned)

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing  2/4: [pgn_parser: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "pgn_parser" "-j" "255" "@install" "@runtest" (CWD=/home/opam/.opam/4.14/.opam-switch/build/pgn_parser.1.0.2)
- (cd _build/default/test && ./test_zobrist.exe)
- === Comprehensive Zobrist Hash Tests ===
- 
- Hash1: 5772101514740079962, Hash2: 5772101514740079962, Hash3: 5772101514740079962
- ✓ 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: 5772101514740079962
- Position 1: 0
- Position 2: 9042506488591766566
- Position 3: 8856359066952549562
- Position 4: 6337390051904276023
- Position 5: 4617376919235899402
- ✓ Hash collision resistance test passed
- 
- === Testing Zobrist Hash with Fixed Piece Positions ===
- Starting position hash: 5772101514740079962
- ✅ Knight to e3: Ne3 -> from c4 to e3 (VALID)
-    Hash: 2645981637543937422
- ✅ Bishop to g7: Bg7 -> from f6 to g7 (VALID)
-    Hash: 8706856501344119087
- ✅ Knight to f3: Nf3 -> from d4 to f3 (VALID)
-    Hash: 6446234675365363343
- ✅ Bishop to e4: Be4 -> from d5 to e4 (VALID)
-    Hash: 6281065456808016343
- ✅ Knight captures on e4: Nxe4 -> from c3 to e4 (VALID)
-    Hash: 5367105883569971746
- ✅ Bishop captures on f7: Bxf7 -> from e6 to f7 (VALID)
-    Hash: 2486284408414507195
- ✓ Fixed piece positions Zobrist test passed
- ✅ All position hashes are unique
- 
- === Testing Hash Consistency for Move Sequences ===
- ✅ Knight to e3: Hash changed from 5772101514740079962 to 2645981637543937422
- ✅ Bishop to g7: Hash changed from 2645981637543937422 to 897907521924788731
- ✅ Knight to f3: Hash changed from 897907521924788731 to 367392826274402862
- ✅ Bishop to e4: Hash changed from 367392826274402862 to 155780645577815715
- ✅ Knight captures on e4: Hash changed from 155780645577815715 to 2267677000776265046
- ✅ Bishop captures on f7: Hash changed from 2267677000776265046 to 7918447405998514359
- ✓ Hash consistency for move sequences test passed
- 
- === All Zobrist tests passed! ===
- (cd _build/default/test && ./test_pgn_parser.exe)
- === Running Property-Based Tests ===
- 
- 
random seed: 386929682
- 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!
-> compiled  pgn_parser.1.0.2
-> removed   pgn_parser.1.0.2
-> installed pgn_parser.1.0.2
Done.
# To update the current shell environment, run: eval $(opam env)
2025-11-10 12:16.01 ---> saved as "4d54c5585fbfe53b6357e5d9f819f8a74a8f5cf3fba83fe5532d2686fa331516"
Job succeeded
2025-11-10 12:16.11: Job succeeded